



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 32MHz                                                                      |
| Connectivity               | LINbus, UART/USART                                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 12                                                                         |
| Program Memory Size        | 7KB (4K x 14)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 512 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                |
| Data Converters            | A/D 8x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 16-UQFN Exposed Pad                                                        |
| Supplier Device Package    | 16-UQFN (4x4)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1574t-i-jq |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

#### TABLE 2: PACKAGES

| Packages      | PDIP | SOIC | TSSOP SSOP |   | UQFN |
|---------------|------|------|------------|---|------|
| PIC16(L)F1574 | •    | •    | •          |   | •    |
| PIC16(L)F1575 | •    | •    | •          |   | •    |
| PIC16(L)F1578 | •    | •    |            | • | •    |
| PIC16(L)F1579 | •    | •    |            | • | •    |

Note: Pin details are subject to change.

# PIC16(L)F1574/5/8/9





## 4.7 Register Definitions: Device ID

#### R R R R R R DEV<13:8> bit 13 bit 8 R R R R R R R R DEV<7:0> bit 7 bit 0

#### REGISTER 4-3: DEVICEID: DEVICE ID REGISTER<sup>(1)</sup>

#### Legend:

| R = Readable bit |  |
|------------------|--|
| R = Readable bit |  |

| '0' = Bit is cleared | '1' = Bit is set | x = Bit is unknown |  |
|----------------------|------------------|--------------------|--|
|                      |                  |                    |  |

## bit 13-0 **DEV<13:0>:** Device ID bits

Refer to Table 4-1 to determine what these bits will read on which device. A value of 3FFFh is invalid.

Note 1: This location cannot be written.

## REGISTER 4-4: REVISIONID: REVISION ID REGISTER<sup>(1)</sup>

|   | R      | R | R        | R    | R | R     |
|---|--------|---|----------|------|---|-------|
|   |        |   | REV<1    | 3:8> |   |       |
|   | bit 13 |   |          |      |   | bit 8 |
|   |        |   |          |      |   |       |
| - | -      | - | <b>D</b> | -    | - |       |

| R     | R | R | R    | R    | R | R | R |
|-------|---|---|------|------|---|---|---|
|       |   |   | REV< | 7:0> |   |   |   |
| bit 7 |   |   |      |      |   |   |   |

| Legend:              |                  |                    |  |
|----------------------|------------------|--------------------|--|
| R = Readable bit     |                  |                    |  |
| '0' = Bit is cleared | '1' = Bit is set | x = Bit is unknown |  |

bit 13-0 **REV<13:0>:** Revision ID bits These bits are used to identify the device revision.

**Note 1:** This location cannot be written.

#### TABLE 4-1: DEVICE ID VALUES

| DEVICE      | Device ID | Revision ID |
|-------------|-----------|-------------|
| PIC16F1574  | 3000h     | 2xxxh       |
| PIC16F1575  | 3001h     | 2xxxh       |
| PIC16F1578  | 3002h     | 2xxxh       |
| PIC16F1579  | 3003h     | 2xxxh       |
| PIC16LF1574 | 3004h     | 2xxxh       |
| PIC16LF1575 | 3005h     | 2xxxh       |
| PIC16LF1578 | 3006h     | 2xxxh       |
| PIC16LF1579 | 3007h     | 2xxxh       |

# PIC16(L)F1574/5/8/9

| FIGURE 5-3:            | INTERNAL OSCILLATOR SWITCH TIMING                              |
|------------------------|----------------------------------------------------------------|
| HPN/TOBC/<br>MPN/TOBC/ |                                                                |
| HFINTOSC/              | Craviliana Onlay <sup>(9)</sup> 2 cycle Syre. Running          |
| LFINTOSC               |                                                                |
| IRCF <3:0>             | $\neq 0$ $= 0$                                                 |
| System Clock           |                                                                |
| SSINTOSC/              | LENYXXXX (WET enabled)                                         |
| HFINTOSC/<br>MENNECOSC |                                                                |
| LFINTOSC               |                                                                |
| IRCF <3:0>             | $\neq 0$ $\chi = 0$                                            |
| System Clock           |                                                                |
| LEINTORC               | HFINYOSC/NFINYOSC<br>URINTOSO hims off unless WOT is enabled   |
| 1989090                |                                                                |
| HFRATOSO/<br>SAFINTOSO |                                                                |
|                        |                                                                |
| System Clock           |                                                                |
| Note () See            | Table 5-1, "Craditutor Switching Dalays" for more information. |



## 9.1 Independent Clock Source

The WDT derives its time base from the 31 kHz LFINTOSC internal oscillator. Time intervals in this chapter are based on a nominal interval of 1 ms. See **Section 27.0 "Electrical Specifications"** for the LFINTOSC tolerances.

## 9.2 WDT Operating Modes

The Watchdog Timer module has four operating modes controlled by the WDTE<1:0> bits in Configuration Words. See Table 9-1.

#### 9.2.1 WDT IS ALWAYS ON

When the WDTE bits of Configuration Words are set to '11', the WDT is always on.

WDT protection is active during Sleep.

#### 9.2.2 WDT IS OFF IN SLEEP

When the WDTE bits of Configuration Words are set to '10', the WDT is on, except in Sleep.

WDT protection is not active during Sleep.

#### 9.2.3 WDT CONTROLLED BY SOFTWARE

When the WDTE bits of Configuration Words are set to '01', the WDT is controlled by the SWDTEN bit of the WDTCON register.

WDT protection is unchanged by Sleep. See Table 9-1 for more details.

| WDTE<1:0> | SWDTEN | Device<br>Mode | WDT<br>Mode |
|-----------|--------|----------------|-------------|
| 11        | Х      | Х              | Active      |
| 10        |        | Awake          | Active      |
| 10        | X      | Sleep          | Disabled    |
| 0.1       | 1      | х              | Active      |
| LO        | 0      | х              | Disabled    |
| 00        | х      | х              | Disabled    |

#### TABLE 9-1: WDT OPERATING MODES

#### 9.3 Time-Out Period

The WDTPS bits of the WDTCON register set the time-out period from 1 ms to 256 seconds (nominal). After a Reset, the default time-out period is two seconds.

## 9.4 Clearing the WDT

The WDT is cleared when any of the following conditions occur:

- · Any Reset
- CLRWDT instruction is executed
- · Device enters Sleep
- Device wakes up from Sleep
- Oscillator fail
- · WDT is disabled
- Oscillator Start-up Timer (OST) is running

See Table 9-2 for more information.

### 9.5 Operation During Sleep

When the device enters Sleep, the WDT is cleared. If the WDT is enabled during Sleep, the WDT resumes counting. When the device exits Sleep, the WDT is cleared again.

The WDT remains clear until the OST, if enabled, completes. See **Section 5.0 "Oscillator Module"** for more information on the OST.

When a WDT time-out occurs while the device is in Sleep, no Reset is generated. Instead, the device wakes up and resumes operation. The  $\overline{TO}$  and  $\overline{PD}$  bits in the STATUS register are changed to indicate the event. The RWDT bit in the PCON register can also be used. See **Section 3.0 "Memory Organization"** for more information.

### TABLE 9-2: WDT CLEARING CONDITIONS

| Conditions                                        | WDT        |
|---------------------------------------------------|------------|
| WDTE<1:0> = 00                                    |            |
| WDTE<1:0> = 01 and SWDTEN = 0                     |            |
| WDTE<1:0> = 10 and enter Sleep                    | Clearad    |
| CLRWDT Command                                    | Cleared    |
| Oscillator Fail Detected                          |            |
| Exit Sleep + System Clock = EXTRC, INTOSC, EXTCLK |            |
| Change INTOSC divider (IRCF bits)                 | Unaffected |

| Name                 | Bit 7                 | Bit 6                 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|----------------------|-----------------------|-----------------------|--------|--------|--------|--------|--------|--------|---------------------|
| ANSELA               | —                     | —                     | —      | ANSA4  | —      | ANSA2  | ANSA1  | ANSA0  | 121                 |
| INTCON               | GIE                   | PEIE                  | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF  | 86                  |
| IOCAF                | —                     | _                     | IOCAF5 | IOCAF4 | IOCAF3 | IOCAF2 | IOCAF1 | IOCAF0 | 143                 |
| IOCAN                | _                     | _                     | IOCAN5 | IOCAN4 | IOCAN3 | IOCAN2 | IOCAN1 | IOCAN0 | 143                 |
| IOCAP                | _                     | —                     | IOCAP5 | IOCAP4 | IOCAP3 | IOCAP2 | IOCAP1 | IOCAP0 | 143                 |
| IOCBP <sup>(2)</sup> | IOCBP7                | IOCBP6                | IOCBP5 | IOCBP4 | _      | _      | _      | _      | 144                 |
| IOCBN <sup>(2)</sup> | IOCBN7                | IOCBN6                | IOCBN5 | IOCBN4 | _      | -      | -      | _      | 144                 |
| IOCBF <sup>(2)</sup> | IOCBF7                | IOCBF6                | IOCBF5 | IOCBF4 | _      | -      | -      | _      | 144                 |
| IOCCP                | IOCCP7 <sup>(2)</sup> | IOCCP6 <sup>(2)</sup> | IOCCP5 | IOCCP4 | IOCCP3 | IOCCP2 | IOCCP1 | IOCCP0 | 145                 |
| IOCCN                | IOCCN7 <sup>(2)</sup> | IOCCN6 <sup>(2)</sup> | IOCCN5 | IOCCN4 | IOCCN3 | IOCCN2 | IOCCN1 | IOCCN0 | 145                 |
| IOCCF                | IOCCF7 <sup>(2)</sup> | IOCCF6 <sup>(2)</sup> | IOCCF5 | IOCCF4 | IOCCF3 | IOCCF2 | IOCCF1 | IOCCF0 | 145                 |
| TRISA                | —                     | _                     | TRISA5 | TRISA4 | —(1)   | TRISA2 | TRISA1 | TRISA0 | 120                 |
| TRISC                | TRISC7 <sup>(2)</sup> | TRISC7 <sup>(2)</sup> | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 131                 |
|                      |                       |                       |        |        |        |        |        |        |                     |

## TABLE 13-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPT-ON-CHANGE

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by interrupt-on-change.

Note 1: Unimplemented, read as '1'.

2: PIC16(L)F1578/9 only.

## 14.3 Register Definitions: FVR Control

| R/W-0/       | 0 R-q/q                                                                                                                                                                                                                                                                                                                                                                          | R/W-0/0                                                                                                                                       | R/W-0/0                                                                     | R/W-0/0                                                                        | R/W-0/0                                                  | R/W-0/0          | R/W-0/0              |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------|----------------------------------------------------------|------------------|----------------------|--|
| FVREN        | <sup>(1)</sup> FVRRDY <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                             | TSEN <sup>(3)</sup>                                                                                                                           | TSRNG <sup>(3)</sup>                                                        | CDAFV                                                                          | R<1:0> <sup>(1)</sup>                                    | ADFVR            | <1:0> <sup>(1)</sup> |  |
| bit 7        |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                               |                                                                             |                                                                                |                                                          |                  | bit C                |  |
|              |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                               |                                                                             |                                                                                |                                                          |                  |                      |  |
| Legend:      |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                               |                                                                             |                                                                                |                                                          |                  |                      |  |
| R = Reada    | able bit                                                                                                                                                                                                                                                                                                                                                                         | W = Writable                                                                                                                                  | bit                                                                         | U = Unimplen                                                                   | nented bit, read                                         | as '0'           |                      |  |
| u = Bit is ι | unchanged                                                                                                                                                                                                                                                                                                                                                                        | x = Bit is unk                                                                                                                                | nown                                                                        | -n/n = Value a                                                                 | at POR and BO                                            | R/Value at all o | other Resets         |  |
| '1' = Bit is | set                                                                                                                                                                                                                                                                                                                                                                              | '0' = Bit is cle                                                                                                                              | ared                                                                        | q = Value dep                                                                  | ends on condit                                           | ion              |                      |  |
| bit 7        | FVREN: Fixed<br>1 = Fixed Vol<br>0 = Fixed Vol                                                                                                                                                                                                                                                                                                                                   | d Voltage Refe<br>tage Referenc<br>tage Referenc                                                                                              | rence Enable l<br>e is enabled<br>e is disabled                             | bit <sup>(1)</sup>                                                             |                                                          |                  |                      |  |
| bit 6        | <b>FVRRDY:</b> Fixe<br>1 = Fixed Vol<br>0 = Fixed Vol                                                                                                                                                                                                                                                                                                                            | ed Voltage Re<br>tage Referenc<br>tage Referenc                                                                                               | ference Ready<br>e output is rea<br>e output is not                         | <sup>,</sup> Flag bit <sup>(2)</sup><br>dy for use<br>ready or not e           | nabled                                                   |                  |                      |  |
| bit 5        | <b>TSEN:</b> Tempe<br>1 = Temperat<br>0 = Temperat                                                                                                                                                                                                                                                                                                                               | <b>TSEN:</b> Temperature Indicator Enable bit <sup>(3)</sup><br>1 = Temperature Indicator is enabled<br>0 = Temperature Indicator is disabled |                                                                             |                                                                                |                                                          |                  |                      |  |
| bit 4        | <b>TSRNG:</b> Temp<br>1 = VOUT = V<br>0 = VOUT = V                                                                                                                                                                                                                                                                                                                               | perature Indica<br>DD - 4V⊤ (High<br>DD - 2V⊤ (Low                                                                                            | ator Range Sel<br>n Range)<br>Range)                                        | lection bit <sup>(3)</sup>                                                     |                                                          |                  |                      |  |
| bit 3-2      | -2 <b>CDAFVR&lt;1:0&gt;:</b> Comparator FVR Buffer Gain Selection bits <sup>(1)</sup><br>11 = Comparator FVR Buffer Gain is 4x, with output VCDAFVR = 4x VFVR <sup>(4)</sup><br>10 = Comparator FVR Buffer Gain is 2x, with output VCDAFVR = 2x VFVR <sup>(4)</sup><br>01 = Comparator FVR Buffer Gain is 1x, with output VCDAFVR = 1x VFVR<br>00 = Comparator FVR Buffer is off |                                                                                                                                               |                                                                             |                                                                                |                                                          |                  |                      |  |
| bit 1-0      | ADFVR<1:0><br>11 = ADC FVI<br>10 = ADC FVI<br>01 = ADC FVI<br>00 = ADC FVI                                                                                                                                                                                                                                                                                                       | : ADC FVR Bu<br>R Buffer Gain<br>R Buffer Gain<br>R Buffer Gain<br>R Buffer is off                                                            | Iffer Gain Sele<br>is 4x, with outp<br>is 2x, with outp<br>is 1x, with outp | ction bit <sup>(1)</sup><br>but VADFVR = 4<br>but VADFVR = 2<br>but VADFVR = 1 | x Vfvr <sup>(4)</sup><br>x Vfvr <sup>(4)</sup><br>x Vfvr |                  |                      |  |
| Note 1:      | <ol> <li>To minimize current consumption when the FVR is disabled, the FVR buffers should be turned off by cleating the Buffer Gain Selection bits.</li> </ol>                                                                                                                                                                                                                   |                                                                                                                                               |                                                                             |                                                                                |                                                          |                  |                      |  |

## **REGISTER 14-1:** FVRCON: FIXED VOLTAGE REFERENCE CONTROL REGISTER

- 2: FVRRDY is always '1' for the PIC16F1574/5/8/9 devices.
- 3: See Section 15.0 "Temperature Indicator Module" for additional information.
- 4: Fixed Voltage Reference output cannot exceed VDD.

#### TABLE 14-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE FIXED VOLTAGE REFERENCE

| Name   | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3       | Bit 2 | Bit 1 | Bit 0  | Register<br>on page |
|--------|-------|--------|-------|-------|-------------|-------|-------|--------|---------------------|
| FVRCON | FVREN | FVRRDY | TSEN  | TSRNG | CDAFVR>1:0> |       | ADFV  | २<1:0> | 149                 |

**Legend:** Shaded cells are unused by the Fixed Voltage Reference module.

#### 16.2.6 ADC CONVERSION PROCEDURE

This is an example procedure for using the ADC to perform an Analog-to-Digital conversion:

- 1. Configure Port:
  - Disable pin output driver (Refer to the TRIS register)
  - Configure pin as analog (Refer to the ANSEL register)
  - Disable weak pull-ups either globally (Refer to the OPTION\_REG register) or individually (Refer to the appropriate WPUx register)
- 2. Configure the ADC module:
  - Select ADC conversion clock
  - Configure voltage reference
  - · Select ADC input channel
  - Turn on ADC module
- 3. Configure ADC interrupt (optional):
  - Clear ADC interrupt flag
  - · Enable ADC interrupt
  - Enable peripheral interrupt
  - Enable global interrupt<sup>(1)</sup>
- 4. Wait the required acquisition time<sup>(2)</sup>.
- 5. Start conversion by setting the GO/DONE bit.
- 6. Wait for ADC conversion to complete by one of the following:
  - Polling the GO/DONE bit
  - Waiting for the ADC interrupt (interrupts enabled)
- 7. Read ADC Result.
- 8. Clear the ADC interrupt flag (required if interrupt is enabled).

**Note 1:** The global interrupt can be disabled if the user is attempting to wake-up from Sleep and resume in-line code execution.

2: Refer to Section 16.4 "ADC Acquisition Requirements".

#### EXAMPLE 16-1: ADC CONVERSION

| <pre>;This code block configures the ADC ;for polling, Vdd and Vss references, FRC ;oscillator and AN0 input. ; ; ;Conversion start &amp; polling for completion ; are included.</pre> |                      |                      |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------|--|--|--|--|
|                                                                                                                                                                                        | 100011               |                      |  |  |  |  |
| BANKSEL                                                                                                                                                                                | ADCONI               |                      |  |  |  |  |
| MOVLW                                                                                                                                                                                  | B.11110000.          | Right Justily, FRC   |  |  |  |  |
| MOUTUE                                                                                                                                                                                 | 100011               | , oscillator         |  |  |  |  |
| MOVWF                                                                                                                                                                                  | ADCONI               | , vad and vss vrei+  |  |  |  |  |
| BANKSEL                                                                                                                                                                                | TRISA<br>TRISA       | '                    |  |  |  |  |
| BSF                                                                                                                                                                                    | IRISA, U             | , Set RAU to input   |  |  |  |  |
| BANKSEL                                                                                                                                                                                | ANSEL                | '                    |  |  |  |  |
| BSF                                                                                                                                                                                    | ANSEL,U              | , Set RAU to analog  |  |  |  |  |
| BANKSEL                                                                                                                                                                                | WPUA<br>WDUA O       |                      |  |  |  |  |
| BCF                                                                                                                                                                                    | WPUA,U               | , Disable weak       |  |  |  |  |
| DANKCET                                                                                                                                                                                | A DOOMO              | ,pull-up on RAU      |  |  |  |  |
| BANKSEL                                                                                                                                                                                | ADCONU<br>D(0000001) |                      |  |  |  |  |
| MOVLW                                                                                                                                                                                  | B,0000001,           | Select channel ANU   |  |  |  |  |
| MOVWE                                                                                                                                                                                  | ADCONU               | Furn ADC On          |  |  |  |  |
| CALL                                                                                                                                                                                   | SampleTime           | Acquisiton delay     |  |  |  |  |
| BSF                                                                                                                                                                                    | ADCONU, ADGO         | Start conversion     |  |  |  |  |
| BTFSC                                                                                                                                                                                  | ADCON0, ADGO         | ;Is conversion done? |  |  |  |  |
| GOTO                                                                                                                                                                                   | Ş-1                  | ;No, test again      |  |  |  |  |
| BANKSEL                                                                                                                                                                                | ADRESH               | i                    |  |  |  |  |
| MOVF                                                                                                                                                                                   | ADRESH,W             | ;Read upper 2 bits   |  |  |  |  |
| MOVWF                                                                                                                                                                                  | RESULTHI             | ;store in GPR space  |  |  |  |  |
| BANKSEL                                                                                                                                                                                | ADRESL               | ;                    |  |  |  |  |
| MOVF                                                                                                                                                                                   | ADRESL,W             | ;Read lower 8 bits   |  |  |  |  |
| MOVWF                                                                                                                                                                                  | RESULTLO             | ;Store in GPR space  |  |  |  |  |

### 16.4 ADC Acquisition Requirements

For the ADC to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The Analog Input model is shown in Figure 16-5. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), refer to Figure 16-5. The maximum recommended impedance for analog sources is 10 k $\Omega$ . As the

source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an ADC acquisition must be done before the conversion can be started. To calculate the minimum acquisition time, Equation 16-1 may be used. This equation assumes that 1/2 LSb error is used (1,024 steps for the ADC). The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution.

#### EQUATION 16-1: ACQUISITION TIME EXAMPLE

Assumptions: Temperature = 50°C and external impedance of  $10k\Omega 5.0V VDD$  TACQ = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient<math>= TAMP + TC + TCOFF  $= 2\mu s + TC + [(Temperature - 25°C)(0.05\mu s/°C)]$ The value for TC can be approximated with the following equations:  $VAPPLIED\left(1 - \frac{1}{(2^{n+1}) - 1}\right) = VCHOLD$ ;[1] VCHOLD charged to within 1/2 lsb  $VAPPLIED\left(1 - e^{\frac{-TC}{RC}}\right) = VCHOLD$ ;[2] VCHOLD charge response to VAPPLIED  $VAPPLIED\left(1 - e^{\frac{-TC}{RC}}\right) = VCHOLD$ ;[2] VCHOLD charge response to VAPPLIED  $VAPPLIED\left(1 - e^{\frac{-TC}{RC}}\right) = VAPPLIED\left(1 - \frac{1}{(2^{n+1}) - 1}\right)$ ; combining [1] and [2] Note: Where n = number of bits of the ADC. Solving for TC:  $TC = -CHOLD(RIC + RSS + RS) \ln(1/2047)$ 

$$= -12.5pF(1k\Omega + 7k\Omega + 10k\Omega) \ln(0.0004885)$$
  
= 1.715µs

Therefore:

$$TACQ = 2\mu s + 1.715\mu s + [(50^{\circ}C - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$$
  
= 4.96\mu s

Note 1: The reference voltage (VRPOS) has no effect on the equation, since it cancels itself out.

- 2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
- **3:** The maximum recommended impedance for analog sources is 10 k $\Omega$ . This is required to meet the pin leakage specification.

## 20.6 Timer1 Interrupt

The Timer1 register pair (TMR1H:TMR1L) increments to FFFFh and rolls over to 0000h. When Timer1 rolls over, the Timer1 interrupt flag bit of the PIR1 register is set. To enable the interrupt on rollover, you must set these bits:

- TMR1ON bit of the T1CON register
- TMR1IE bit of the PIE1 register
- · PEIE bit of the INTCON register
- · GIE bit of the INTCON register

The interrupt is cleared by clearing the TMR1IF bit in the Interrupt Service Routine.

**Note:** The TMR1H:TMR1L register pair and the TMR1IF bit should be cleared before enabling interrupts.

## 20.7 Timer1 Operation During Sleep

Timer1 can only operate during Sleep when setup in Asynchronous Counter mode. In this mode, an external crystal or clock source can be used to increment the counter. To set up the timer to wake the device:

- TMR1ON bit of the T1CON register must be set
- · TMR1IE bit of the PIE1 register must be set
- · PEIE bit of the INTCON register must be set
- T1SYNC bit of the T1CON register must be set
- TMR1CS bits of the T1CON register must be configured

The device will wake-up on an overflow and execute the next instructions. If the GIE bit of the INTCON register is set, the device will call the Interrupt Service Routine.

Timer1 oscillator will continue to operate in Sleep regardless of the T1SYNC bit setting.





### FIGURE 20-3: TIMER1 GATE ENABLE MODE



#### 22.4 EUSART Baud Rate Generator (BRG)

The Baud Rate Generator (BRG) is an 8-bit or 16-bit timer that is dedicated to the support of both the asynchronous and synchronous EUSART operation. By default, the BRG operates in 8-bit mode. Setting the BRG16 bit of the BAUDCON register selects 16-bit mode.

The SPBRGH, SPBRGL register pair determines the period of the free running baud rate timer. In Asynchronous mode the multiplier of the baud rate period is determined by both the BRGH bit of the TXSTA register and the BRG16 bit of the BAUDCON register. In Synchronous mode, the BRGH bit is ignored.

Table 22-3 contains the formulas for determining the baud rate. Example 22-1 provides a sample calculation for determining the baud rate and baud rate error.

Typical baud rates and error values for various Asynchronous modes have been computed for your convenience and are shown in Table 22-3. It may be advantageous to use the high baud rate (BRGH = 1), or the 16-bit BRG (BRG16 = 1) to reduce the baud rate error. The 16-bit BRG mode is used to achieve slow baud rates for fast oscillator frequencies.

Writing a new value to the SPBRGH, SPBRGL register pair causes the BRG timer to be reset (or cleared). This ensures that the BRG does not wait for a timer overflow before outputting the new baud rate.

If the system clock is changed during an active receive operation, a receive error or data loss may result. To avoid this problem, check the status of the RCIDL bit to make sure that the receive operation is idle before changing the system clock.

#### EXAMPLE 22-1: CALCULATING BAUD **RATE ERROR**

For a device with Fosc of 16 MHz, desired baud rate of 9600, Asynchronous mode, 8-bit BRG:

Fosc Desired Baud Rate =  $\frac{1}{64([SPBRGH:SPBRGL] + 1)}$ Solving for SPBRGH:SPBRGL: FOSC  $X = \frac{Desired Baud Rate}{-1}$ 64 16000000 = [25.042] = 25 Calculated Baud Rate =  $\frac{10000000}{64(25+1)}$ 16000000 = 9615  $Error = \frac{Calc. Baud Rate - Desired}{Baud Rate}$ Desired Baud Rate  $= \frac{(9615 - 9600)}{2000} = 0.16\%$ 

9600

## **REGISTER 23-15: PWMxTMRH: PWMx TIMER HIGH REGISTER**

| R/W-x/u                       | R/W-x/u | R/W-x/u            | R/W-x/u | R/W-x/u        | R/W-x/u         | R/W-x/u        | R/W-x/u      |
|-------------------------------|---------|--------------------|---------|----------------|-----------------|----------------|--------------|
|                               |         |                    | TMR     | <15:8>         |                 |                |              |
| bit 7                         |         |                    |         |                |                 |                | bit 0        |
|                               |         |                    |         |                |                 |                |              |
| Legend:                       |         |                    |         |                |                 |                |              |
| R = Readable bit W = Writable |         | W = Writable I     | bit     | U = Unimpler   | nented bit, rea | d as '0'       |              |
| u = Bit is unchanged          |         | x = Bit is unknown |         | -n/n = Value a | at POR and BC   | R/Value at all | other Resets |
| '1' = Bit is set              |         | '0' = Bit is clea  | ared    |                |                 |                |              |

bit 7-0 TMR<15:8>: PWM Timer High bits Upper eight bits of PWM timer counter

#### **REGISTER 23-16: PWMxTMRL: PWMx TIMER LOW REGISTER**

| R/W-x/u |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | TMR<    | <7:0>   |         |         |         |
| bit 7   |         |         |         |         |         |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-0 TMR<7:0>: PWM Timer Low bits Lower eight bits of PWM timer counter ٦



### FIGURE 24-2: TYPICAL CWG OPERATION WITH PWM1 (NO AUTO-SHUTDOWN)

## 24.5 Dead-Band Control

Dead-band control provides for non-overlapping output signals to prevent shoot-through current in power switches. The CWG contains two 6-bit dead-band counters. One dead-band counter is used for the rising edge of the input source control. The other is used for the falling edge of the input source control.

Dead band is timed by counting CWG clock periods from zero up to the value in the rising or falling deadband counter registers. See CWGxDBR and CWGxDBF registers (Register 24-4 and Register 24-5, respectively).

## 24.6 Rising Edge Dead Band

The rising edge dead-band delays the turn-on of the CWGxA output from when the CWGxB output is turned off. The rising edge dead-band time starts when the rising edge of the input source signal goes true. When this happens, the CWGxB output is immediately turned off and the rising edge dead-band delay time starts. When the rising edge dead-band delay time is reached, the CWGxA output is turned on.

The CWGxDBR register sets the duration of the deadband interval on the rising edge of the input source signal. This duration is from 0 to 64 counts of dead band.

Dead band is always counted off the edge on the input source signal. A count of 0 (zero), indicates that no dead band is present.

If the input source signal is not present for enough time for the count to be completed, no output will be seen on the respective output.

## 24.7 Falling Edge Dead Band

The falling edge dead band delays the turn-on of the CWGxB output from when the CWGxA output is turned off. The falling edge dead-band time starts when the falling edge of the input source goes true. When this happens, the CWGxA output is immediately turned off and the falling edge dead-band delay time starts. When the falling edge dead-band delay time is reached, the CWGxB output is turned on.

The CWGxDBF register sets the duration of the deadband interval on the falling edge of the input source signal. This duration is from 0 to 64 counts of dead band.

Dead band is always counted off the edge on the input source signal. A count of 0 (zero), indicates that no dead band is present.

If the input source signal is not present for enough time for the count to be completed, no output will be seen on the respective output.

Refer to Figure 24-3 and Figure 24-4 for examples.

| SWAPF            | Swap Nibbles in f                                                                                                                                                                 |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] SWAPF f,d                                                                                                                                                        |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                   |  |  |  |  |  |
| Operation:       | $(f<3:0>) \rightarrow (destination<7:4>),$<br>$(f<7:4>) \rightarrow (destination<3:0>)$                                                                                           |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                              |  |  |  |  |  |
| Description:     | The upper and lower nibbles of regis-<br>ter 'f' are exchanged. If 'd' is '0', the<br>result is placed in the W register. If 'd'<br>is '1', the result is placed in register 'f'. |  |  |  |  |  |

| XORLW            | Exclusive OR literal with W                                                                                   |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] XORLW k                                                                                      |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                             |  |  |  |  |  |
| Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                 |  |  |  |  |  |
| Status Affected: | Z                                                                                                             |  |  |  |  |  |
| Description:     | The contents of the W register are XOR'ed with the 8-bit literal 'k'. The result is placed in the W register. |  |  |  |  |  |

| TRIS             | Load TRIS Register with W                                                                                                                            |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] TRIS f                                                                                                                              |
| Operands:        | $5 \leq f \leq 7$                                                                                                                                    |
| Operation:       | (W) $\rightarrow$ TRIS register 'f'                                                                                                                  |
| Status Affected: | None                                                                                                                                                 |
| Description:     | Move data from W register to TRIS<br>register.<br>When 'f' = 5, TRISA is loaded.<br>When 'f' = 6, TRISB is loaded.<br>When 'f' = 7, TRISC is loaded. |

| XORWF            | Exclusive OR W with f                                                                                                                                                                       |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] XORWF f,d                                                                                                                                                                  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                                           |  |  |  |  |  |
| Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                                   |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                                           |  |  |  |  |  |
| Description:     | Exclusive OR the contents of the W<br>register with register 'f'. If 'd' is '0', the<br>result is stored in the W register. If 'd'<br>is '1', the result is stored back in<br>register 'f'. |  |  |  |  |  |

## TABLE 27-3: POWER-DOWN CURRENTS (IPD)<sup>(1,2)</sup> (CONTINUED)

| PIC16LF1574/5/8/9 |                        | Operating Conditions: (unless otherwise stated)<br>Low-Power Sleep Mode |                                  |       |        |       |            |                                    |  |  |  |
|-------------------|------------------------|-------------------------------------------------------------------------|----------------------------------|-------|--------|-------|------------|------------------------------------|--|--|--|
| PIC16F15          | 74/5/8/9               | Low-Po                                                                  | Low-Power Sleep Mode, VREGPM = 1 |       |        |       |            |                                    |  |  |  |
| Param.            |                        | Min                                                                     |                                  | Max.  | Max.   |       | Conditions |                                    |  |  |  |
| No.               | Device Characteristics | Min.                                                                    | турт                             | +85°C | +125°C | Units | Vdd        | Note                               |  |  |  |
| D027              |                        | —                                                                       | 5                                | 22    | 25     | μA    | 1.8        | Comparator,                        |  |  |  |
|                   |                        | —                                                                       | 5                                | 23    | 27     | μA    | 3.0        | CxSP = 0                           |  |  |  |
| D027              |                        | —                                                                       | 15                               | 23    | 25     | μA    | 2.3        | Comparator,                        |  |  |  |
|                   |                        | —                                                                       | 17                               | 27    | 29     | μA    | 3.0        | CxSP = 0                           |  |  |  |
|                   |                        | —                                                                       | 19                               | 28    | 30     | μA    | 5.0        |                                    |  |  |  |
| D028A             |                        | _                                                                       | 23                               | 41    | 42     | μA    | 1.8        | Comparator,                        |  |  |  |
|                   |                        | —                                                                       | 25                               | 42    | 44     | μA    | 3.0        | Normal Power, CxSP = 1<br>(Note 1) |  |  |  |
| D028A             |                        | —                                                                       | 33                               | 55    | 56     | μA    | 2.3        | Comparator,                        |  |  |  |
|                   |                        | _                                                                       | 34                               | 59    | 60     | μA    | 3.0        | Normal Power, $CxSP = 1$           |  |  |  |
|                   |                        | _                                                                       | 36                               | 60    | 61     | μA    | 5.0        |                                    |  |  |  |

These parameters are characterized but not tested.

† Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: The peripheral △ current can be determined by subtracting the base IPD current from this limit. Max. values should be used when calculating total current consumption.

2: The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impedance state and tied to Vss.

**3:** ADC clock source is FRC.

\*

| Standard Operating Conditions (unless otherwise stated) |           |                                        |       |       |                                                          |  |  |  |
|---------------------------------------------------------|-----------|----------------------------------------|-------|-------|----------------------------------------------------------|--|--|--|
| Param.<br>No.                                           | Sym.      | Characteristic                         | Тур.  | Units | Conditions                                               |  |  |  |
| TH01                                                    | θJA       | Thermal Resistance Junction to Ambient | 70    | °C/W  | 14-pin PDIP package                                      |  |  |  |
|                                                         |           |                                        | 95.3  | °C/W  | 14-pin SOIC package                                      |  |  |  |
|                                                         |           |                                        | 100   | °C/W  | 14-pin TSSOP package                                     |  |  |  |
|                                                         |           |                                        | 31.8  | °C/W  | 16-pin UQFN 4x4mm package                                |  |  |  |
|                                                         |           |                                        | 62.2  | °C/W  | 20-pin PDIP package                                      |  |  |  |
|                                                         |           |                                        | 77.7  | °C/W  | 20-pin SOIC package                                      |  |  |  |
|                                                         |           |                                        | 87.3  | °C/W  | 20-pin SSOP package                                      |  |  |  |
|                                                         |           |                                        | 32.8  | °C/W  | 20-pin UQFN 4x4mm package                                |  |  |  |
| TH02                                                    | θJC       | Thermal Resistance Junction to Case    | 32.75 | °C/W  | 14-pin PDIP package                                      |  |  |  |
|                                                         |           |                                        | 31    | °C/W  | 14-pin SOIC package                                      |  |  |  |
|                                                         |           |                                        | 24.4  | °C/W  | 14-pin TSSOP package                                     |  |  |  |
|                                                         |           |                                        | 24.4  | °C/W  | 16-pin UQFN 4x4mm package                                |  |  |  |
|                                                         |           |                                        | 27.5  | °C/W  | 20-pin PDIP package                                      |  |  |  |
|                                                         |           |                                        | 23.1  | °C/W  | 20-pin SOIC package                                      |  |  |  |
|                                                         |           |                                        | 31.1  | °C/W  | 20-pin SSOP package                                      |  |  |  |
|                                                         |           |                                        | 27.4  | °C/W  | 20-pin UQFN 4x4mm package                                |  |  |  |
| TH03                                                    | Тјмах     | Maximum Junction Temperature           | 150   | °C    |                                                          |  |  |  |
| TH04                                                    | PD        | Power Dissipation                      | -     | W     | PD = PINTERNAL + PI/O                                    |  |  |  |
| TH05                                                    | PINTERNAL | Internal Power Dissipation             | —     | W     | PINTERNAL = IDD x VDD <sup>(1)</sup>                     |  |  |  |
| TH06                                                    | Pi/o      | I/O Power Dissipation                  | —     | W     | $PI/O = \Sigma (IOL * VOL) + \Sigma (IOH * (VDD - VOH))$ |  |  |  |
| TH07                                                    | Pder      | Derated Power                          |       | W     | Pder = PDmax (Tj - Ta)/θja <sup>(2)</sup>                |  |  |  |

## TABLE 27-6: THERMAL CHARACTERISTICS

**Note 1:** IDD is current to run the chip alone without driving any load on the output pins.

2: TA = Ambient Temperature; TJ = Junction Temperature

## 27.4 AC Characteristics

Timing Parameter Symbology has been created with one of the following formats:

- 1. TppS2ppS
- 2. TppS

| Т                                          |                          |     |                |
|--------------------------------------------|--------------------------|-----|----------------|
| F                                          | Frequency                | Т   | Time           |
| Lowercase letters (pp) and their meanings: |                          |     |                |
| рр                                         |                          |     |                |
| СС                                         | CCP1                     | OSC | CLKIN          |
| ck                                         | CLKOUT                   | rd  | RD             |
| CS                                         | CS                       | rw  | RD or WR       |
| di                                         | SDIx                     | SC  | SCKx           |
| do                                         | SDO                      | SS  | SS             |
| dt                                         | Data in                  | t0  | ТОСКІ          |
| io                                         | I/O PORT                 | t1  | T1CKI          |
| mc                                         | MCLR                     | wr  | WR             |
| Uppercase letters and their meanings:      |                          |     |                |
| S                                          |                          |     |                |
| F                                          | Fall                     | Р   | Period         |
| Н                                          | High                     | R   | Rise           |
| I                                          | Invalid (High-impedance) | V   | Valid          |
| L                                          | Low                      | Z   | High-impedance |

## FIGURE 27-4: LOAD CONDITIONS





FIGURE 28-7: IDD Typical, EC Oscillator, Medium Power Mode, PIC16F1574/5/8/9 Only.



FIGURE 28-8: IDD Maximum, EC Oscillator, Medium Power Mode, PIC16F1574/5/8/9 Only.



FIGURE 28-9: IDD Typical, EC Oscillator, High-Power Mode, Fosc = 32 kHz, PIC16LF1574/5/8/9 Only.



**FIGURE 28-10:** IDD Typical, EC Oscillator, High-Power Mode, Fosc = 32 kHz, PIC16F1574/5/8/9 Only.



FIGURE 28-12: IDD, LFINTOSC Mode, Fosc = 31 kHz, PIC16F1574/5/8/9 Only.

12 (**V**rl) 10 8 Typical 4 2 0 3.4 3.6 1.8 2.0 2.2 2.4 2.6 2.8 3.0 3.2 3.8 1.6 VDD (V) FIGURE 28-11: IDD, LFINTOSC Mode,

Max.

Fosc = 31 kHz, PIC16LF1574/5/8/9 Only.

18

16

14

Max: 85°C + 3o Typical: 25°C

#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, flexPWR, JukeBlox, KEELOQ, KEELOQ logo, Kleer, LANCheck, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC<sup>32</sup> logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

The Embedded Control Solutions Company and mTouch are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, ECAN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, RightTouch logo, REAL ICE, SQI, Serial Quad I/O, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2016, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-0190-2

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and mulfacture of development systems is ISO 9001:2000 certified.