

#### 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

E·XFI

| Product Status             | Active                                                                      |
|----------------------------|-----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 32MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, POR, PSMC, PWM, WDT                                 |
| Number of I/O              | 24                                                                          |
| Program Memory Size        | 3.5KB (2K x 14)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 256 x 8                                                                     |
| RAM Size                   | 256 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 11x12b; D/A 1x8b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                              |
| Supplier Device Package    | 28-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1782t-i-so |

Email: info@E-XFL.COM

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

| _                                               |         |                              |               |       |       | <u> </u> |       | /     |           |                      |                                 |
|-------------------------------------------------|---------|------------------------------|---------------|-------|-------|----------|-------|-------|-----------|----------------------|---------------------------------|
| Addr                                            | Name    | Bit 7                        | Bit 6         | Bit 5 | Bit 4 | Bit 3    | Bit 2 | Bit 1 | Bit 0     | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
| Ban                                             | k 7     |                              |               |       |       |          |       |       |           |                      |                                 |
| 38Ch                                            | INLVLA  | Input Type Control for PORTA |               |       |       |          |       |       |           | 0000 0000            | 0000 0000                       |
| 38Dh                                            | INLVLB  | Input Type Co                | ntrol for POR | ТВ    |       |          |       |       |           | 0000 0000            | 0000 0000                       |
| 38Eh                                            | INLVLC  | Input Type Co                | ntrol for POR | тс    |       |          |       |       |           | 1111 1111            | 1111 1111                       |
| 38Fh                                            | —       | Unimplemente                 | ed            |       |       |          |       |       |           | —                    | —                               |
| 390h                                            | INLVLE  | —                            | —             | —     | _     | INLVLE3  | —     | —     | —         | 1                    | 1                               |
| 391h                                            | IOCAP   |                              |               |       | IOCAP | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 392h                                            | IOCAN   |                              |               |       | IOCAN | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 393h                                            | IOCAF   |                              |               |       | IOCAF | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 394h                                            | IOCBP   |                              |               |       | IOCBP | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 395h                                            | IOCBN   |                              |               |       | IOCBN | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 396h                                            | IOCBF   | IOCBF<7:0>                   |               |       |       |          |       |       | 0000 0000 | 0000 0000            |                                 |
| 397h                                            | IOCCP   | IOCCP<7:0>                   |               |       |       |          |       |       | 0000 0000 | 0000 0000            |                                 |
| 398h                                            | IOCCN   |                              |               |       | IOCCN | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 399h                                            | IOCCF   |                              |               |       | IOCCF | <7:0>    |       |       |           | 0000 0000            | 0000 0000                       |
| 39Ah<br>39Ch                                    | _       | Unimplemente                 | ed            |       |       |          |       |       |           | _                    | _                               |
| 39Dh                                            | IOCEP   | —                            | _             | _     | _     | IOCEP3   | _     | _     | —         | 0                    | 0                               |
| 39Eh                                            | IOCEN   | _                            | _             | _     | _     | IOCEN3   | _     | _     | _         | 0                    | 0                               |
| 39Fh                                            | IOCEF   | —                            | _             | _     | _     | IOCEF3   | _     | _     | _         | 0                    | 0                               |
| Ban                                             | k 8-9   |                              |               |       |       |          |       |       |           |                      |                                 |
| 40Ch<br>or<br>41Fh<br>and<br>48Ch<br>or<br>49Fh | _       | Unimplemented                |               |       |       |          |       | _     | _         |                      |                                 |
| Ban                                             | k 10    |                              |               |       |       |          |       |       |           |                      |                                 |
| 50Ch<br>510h                                    | _       | Unimplemented                |               |       |       |          |       |       | _         | _                    |                                 |
| 511h                                            | OPA1CON | OPA1EN                       | OPA1SP        | _     | _     | _        | _     | OPA1P | CH<1:0>   | 0000                 | 0000                            |

#### **TABLE 3-8:** SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

| 40Ch<br>or<br>41Fh<br>and<br>48Ch<br>or<br>49Fh | Unimplemented | _ | _ |
|-------------------------------------------------|---------------|---|---|
|-------------------------------------------------|---------------|---|---|

| Dali             | K IU    |                 |                   |         |       |        |   |              |           |           |
|------------------|---------|-----------------|-------------------|---------|-------|--------|---|--------------|-----------|-----------|
| 50Ch<br>510h     | _       | Unimplemente    | d                 |         |       |        |   |              | -         | _         |
| 511h             | OPA1CON | OPA1EN          | OPA1SP            |         | -     | —      | — | OPA1PCH<1:0> | 0000      | 0000      |
| 512h             | —       | Unimplemented — |                   |         |       |        |   | —            | —         |           |
| 513h             | OPA2CON | OPA2EN          | OPA2SP            | _       | _     | _      | _ | OPA2PCH<1:0> | 0000      | 0000      |
| 514h<br>519h     | —       | Unimplemente    | Unimplemented — — |         |       |        |   |              |           |           |
| 51Ah             | CLKRCON | CLKREN          | CLKROE            | CLKRSLR | CLKRD | C<1:0> | ( | CLKRDIV<2:0> | 0011 0000 | 0011 0000 |
| 51Bh<br><br>51Fh | _       | Unimplemente    | d                 |         |       |        |   |              | _         | _         |

x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. These registers can be addressed from any bank. Unimplemented, read as '1'. PIC16F1782/3 only. Legend:

1: 2:

3:

Note

| Name   | Bit 7  | Bit 6  | Bit 5      | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Register<br>on Page |
|--------|--------|--------|------------|-------|-------|-------|-------|--------|---------------------|
| BORCON | SBOREN | BORFS  |            |       | _     | _     | _     | BORRDY | 47                  |
| PCON   | STKOVF | STKUNF | _          | RWDT  | RMCLR | RI    | POR   | BOR    | 51                  |
| STATUS | —      | _      | _          | TO    | PD    | Z     | DC    | С      | 18                  |
| WDTCON | —      |        | WDTPS<4:0> |       |       |       |       | SWDTEN | 94                  |

#### TABLE 5-5: SUMMARY OF REGISTERS ASSOCIATED WITH RESETS

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by Resets.

### 8.0 INTERRUPTS

The interrupt feature allows certain events to preempt normal program flow. Firmware is used to determine the source of the interrupt and act accordingly. Some interrupts can be configured to wake the MCU from Sleep mode.

This chapter contains the following information for Interrupts:

- · Operation
- Interrupt Latency
- · Interrupts During Sleep
- INT Pin
- · Automatic Context Saving

Many peripherals produce interrupts. Refer to the corresponding chapters for details.

A block diagram of the interrupt logic is shown in Figure 8-1.

#### FIGURE 8-1: INTERRUPT LOGIC



#### 12.3.2 ERASING FLASH PROGRAM MEMORY

While executing code, program memory can only be erased by rows. To erase a row:

- 1. Load the EEADRH:EEADRL register pair with the address of new row to be erased.
- 2. Clear the CFGS bit of the EECON1 register.
- 3. Set the EEPGD, FREE, and WREN bits of the EECON1 register.
- 4. Write 55h, then AAh, to EECON2 (Flash programming unlock sequence).
- 5. Set control bit WR of the EECON1 register to begin the erase operation.
- Poll the FREE bit in the EECON1 register to determine when the row erase has completed.

#### See Example 12-4.

After the "BSF EECON1, WR" instruction, the processor requires two cycles to set up the erase operation. The user must place two NOP instructions after the WR bit is set. The processor will halt internal operations for the typical 2 ms erase time. This is not Sleep mode as the clocks and peripherals will continue to run. After the erase cycle, the processor will resume operation with the third instruction after the EECON1 write instruction.

### 12.3.3 WRITING TO FLASH PROGRAM MEMORY

Program memory is programmed using the following steps:

- 1. Load the starting address of the word(s) to be programmed.
- 2. Load the write latches with data.
- 3. Initiate a programming operation.
- 4. Repeat steps 1 through 3 until all data is written.

Before writing to program memory, the word(s) to be written must be erased or previously unwritten. Program memory can only be erased one row at a time. No automatic erase occurs upon the initiation of the write.

Program memory can be written one or more words at a time. The maximum number of words written at one time is equal to the number of write latches. See Figure 12-2 (block writes to program memory with 32 write latches) for more details. The write latches are aligned to the address boundary defined by EEADRL as shown in Table 12-1. Write operations do not cross these boundaries. At the completion of a program memory write operation, the write latches are reset to contain 0x3FFF.

The following steps should be completed to load the write latches and program a block of program memory. These steps are divided into two parts. First, all write latches are loaded with data except for the last program memory location. Then, the last write latch is loaded and the programming sequence is initiated. A special

unlock sequence is required to load a write latch with data or initiate a Flash programming operation. This unlock sequence should not be interrupted.

- 1. Set the EEPGD and WREN bits of the EECON1 register.
- 2. Clear the CFGS bit of the EECON1 register.
- Set the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '1', the write sequence will only load the write latches and will not initiate the write to Flash program memory.
- 4. Load the EEADRH:EEADRL register pair with the address of the location to be written.
- 5. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- 6. Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The write latch is now loaded.
- 7. Increment the EEADRH:EEADRL register pair to point to the next location.
- 8. Repeat steps 5 through 7 until all but the last write latch has been loaded.
- Clear the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '0', the write sequence will initiate the write to Flash program memory.
- 10. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- 11. Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The entire latch block is now written to Flash program memory.

It is not necessary to load the entire write latch block with user program data. However, the entire write latch block will be written to program memory.

An example of the complete write sequence for eight words is shown in Example 12-5. The initial address is loaded into the EEADRH:EEADRL register pair; the eight words of data are loaded using indirect addressing.

After the "BSF EECON1, WR" instruction, the processor requires two cycles to set up the write operation. The user must place two NOP instructions after the WR bit is set. The processor will halt internal operations for the typical 2 ms, only during the cycle in which the write takes place (i.e., the last word of the block write). This is not Sleep mode as the clocks and peripherals will continue to run. The processor does not stall when LWLO = 1, loading the write latches. After the write cycle, the processor will resume operation with the third instruction after the EECON1 WRITE instruction.

#### 13.2 Register Definitions: Alternate Pin Function Control

#### REGISTER 13-1: APFCON: ALTERNATE PIN FUNCTION CONTROL REGISTER

| R/W-0/0          | R/W-0/0                     | R/W-0/0                      | R/W-0/0        | R/W-0/0         | R/W-0/0          | R/W-0/0          | R/W-0/0      |
|------------------|-----------------------------|------------------------------|----------------|-----------------|------------------|------------------|--------------|
| C2OUTSEL         | CCP1SEL                     | SDOSEL                       | SCKSEL         | SDISEL          | TXSEL            | RXSEL            | CCP2SEL      |
| bit 7            |                             |                              |                |                 |                  |                  | bit 0        |
|                  |                             |                              |                |                 |                  |                  |              |
| Legend:          |                             |                              |                |                 |                  |                  |              |
| R = Readable     | bit                         | W = Writable                 | bit            | U = Unimpler    | nented bit, read | as '0'           |              |
| u = bit is uncha | anged                       | x = Bit is unkr              | nown           | -n/n = Value a  | at POR and BOI   | R/Value at all c | other Resets |
| '1' = Bit is set |                             | '0' = Bit is clea            | ared           |                 |                  |                  |              |
|                  |                             |                              |                |                 |                  |                  |              |
| bit /            |                             | C2OUT Pin Se                 | lection bit    |                 |                  |                  |              |
|                  | 1 = C20011<br>0 = C20011    | s on pin RA6<br>s on pin RA5 |                |                 |                  |                  |              |
| bit 6            | CCP1SEL: C                  | CP1 Input/Outr               | out Pin Select | ion bit         |                  |                  |              |
|                  | 1 = CCP1 is                 | on pin RB0                   |                |                 |                  |                  |              |
|                  | 0 = CCP1 is                 | on pin RC2                   |                |                 |                  |                  |              |
| bit 5            | SDOSEL: MS                  | SSP SDO Pin S                | election bit   |                 |                  |                  |              |
|                  | 1 = SDO is o                | n pin RB5                    |                |                 |                  |                  |              |
|                  | 0 = SDO is o                | n pin RC5                    |                |                 |                  |                  |              |
| bit 4            | SCKSEL: MS                  | SP Serial Cloc               | k (SCL/SCK)    | Pin Selection I | bit              |                  |              |
|                  | 1 = SCL/SCR                 | Lis on pin RB7               |                |                 |                  |                  |              |
| hit 3            |                             | SP Serial Data               |                | utnut Pin Selec | tion bit         |                  |              |
| bit o            | 1 = SDA/SDI                 | is on pin RB6                | (02/1021) 0    |                 |                  |                  |              |
|                  | 0 = SDA/SDI                 | is on pin RC4                |                |                 |                  |                  |              |
| bit 2            | TXSEL: TX P                 | in Selection bit             |                |                 |                  |                  |              |
|                  | 1 = TX is on pin RB6        |                              |                |                 |                  |                  |              |
|                  | 0 = TX is on                | 0 = TX is on pin RC6         |                |                 |                  |                  |              |
| bit 1            | RXSEL: RX Pin Selection bit |                              |                |                 |                  |                  |              |
|                  | 1 = RX is on pin RB7        |                              |                |                 |                  |                  |              |
| L:1 0            |                             |                              |                | : h:4           |                  |                  |              |
| DIT U            |                             | CP2 Input/Outp               | out Pin Select | ion bit         |                  |                  |              |
|                  | 1 = CCP2 IS $0 = CCP2 ic$   | on pin RC1                   |                |                 |                  |                  |              |
|                  | 0 - 001 2 13                |                              |                |                 |                  |                  |              |

#### 13.8 Register Definitions: PORTC

#### REGISTER 13-18: PORTC: PORTC 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     |
|------------------|---------|------------------|---------|----------------|------------------|------------------|-------------|
| RC7              | RC6     | RC5              | RC4     | RC3            | RC2              | RC1              | RC0         |
| bit 7            | ÷       | ·                |         |                |                  | •                | bit 0       |
|                  |         |                  |         |                |                  |                  |             |
| Legend:          |         |                  |         |                |                  |                  |             |
| R = Readable     | bit     | W = Writable     | bit     | U = Unimpler   | nented bit, read | l as '0'         |             |
| u = Bit is unch  | anged   | x = Bit is unkr  | nown    | -n/n = Value a | at POR and BO    | R/Value at all o | ther Resets |
| '1' = Bit is set |         | '0' = Bit is cle | ared    |                |                  |                  |             |

bit 7-0 RC<7:0>: PORTC General Purpose I/O Pin bits<sup>(1)</sup> 1 = Port pin is ≥ VIH 0 = Port pin is ≤ VIL

**Note 1:** Writes to PORTC are actually written to corresponding LATC register. Reads from PORTC register is return of actual I/O pin values.

#### REGISTER 13-19: TRISC: PORTC TRI-STATE REGISTER

| R/W-1/1 |
|---------|---------|---------|---------|---------|---------|---------|---------|
| TRISC7  | TRISC6  | TRISC5  | TRISC4  | TRISC3  | TRISC2  | TRISC1  | TRISC0  |
| 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

TRISC<7:0>: PORTC Tri-State Control bits

 $\ensuremath{\mathtt{1}}$  = PORTC pin configured as an input (tri-stated)

0 = PORTC pin configured as an output

#### REGISTER 13-20: LATC: PORTC DATA LATCH REGISTER

| R/W-x/u |
|---------|---------|---------|---------|---------|---------|---------|---------|
| LATC7   | LATC6   | LATC5   | LATC4   | LATC3   | LATC2   | LATC1   | LATC0   |
| 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 LATC<7:0>: PORTC Output Latch Value bits<sup>(1)</sup>

**Note 1:** Writes to PORTC are actually written to corresponding LATC register. Reads from PORTC register is return of actual I/O pin values.

| 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 | —     | _     | ADFVR<1:0> |       | 136                 |

Legend: Shaded cells are unused by the temperature indicator module.

#### 18.4 Register Definitions: Op Amp Control

#### REGISTER 18-1: OPAxCON: OPERATIONAL AMPLIFIERS (OPAx) CONTROL REGISTERS

| R/W-0/0   | R/W-0/0 | U-0 | U-0 | U-0 | U-0 | R/W-0/0     | R/W-0/0 |
|-----------|---------|-----|-----|-----|-----|-------------|---------|
| OPAxEN    | OPAxSP  | —   | —   | —   | —   | OPAxCH<1:0> |         |
| bit 7 bit |         |     |     |     |     |             |         |
|           |         |     |     |     |     |             |         |
|           |         |     |     |     |     |             |         |

| 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 | q = Value depends on condition                        |

| bit 7   | OPAxEN: Op Amp Enable bit                                |  |  |  |  |
|---------|----------------------------------------------------------|--|--|--|--|
|         | 1 = Op amp is enabled                                    |  |  |  |  |
|         | 0 = Op amp is disabled and consumes no active power      |  |  |  |  |
| bit 6   | OPAxSP: Op Amp Speed/Power Select bit                    |  |  |  |  |
|         | 1 = Comparator operates in high GBWP mode                |  |  |  |  |
|         | 0 = Reserved. Do not use.                                |  |  |  |  |
| bit 5-2 | Unimplemented: Read as '0'                               |  |  |  |  |
| bit 1-0 | OPAxCH<1:0>: Non-inverting Channel Selection bits        |  |  |  |  |
|         | 11 = Non-inverting input connects to FVR Buffer 2 output |  |  |  |  |
|         | 10 = Non-inverting input connects to DAC_output          |  |  |  |  |
|         | 0x = Non-inverting input connects to OPAxIN+ pin         |  |  |  |  |

#### TABLE 18-1: SUMMARY OF REGISTERS ASSOCIATED WITH OP AMPS

| Name    | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0   | Register<br>on Page |
|---------|--------|--------|--------|--------|--------|--------|--------|---------|---------------------|
| ANSELA  | ANSA7  | _      | ANSA5  | ANSA4  | ANSA3  | ANSA2  | ANSA1  | ANSA0   | 115                 |
| ANSELB  | —      | _      | ANSB5  | ANSB4  | ANSB3  | ANSB2  | ANSB1  | ANSB0   | 121                 |
| DACCON0 | DACEN  | _      | DACOE1 | DACOE2 | DACPS  | S<1:0> | _      | DACNSS  | 161                 |
| DACCON1 |        |        |        | DAC    | R<7:0> |        |        |         | 161                 |
| OPA1CON | OPA1EN | OPA1SP | -      | _      | _      | _      | OPA1P0 | 157     |                     |
| OPA2CON | OPA2EN | OPA2SP | -      | _      | _      | _      | OPA2P0 | CH<1:0> | 157                 |
| TRISA   | TRISA7 | TRISA6 | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0  | 114                 |
| TRISB   | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0  | 120                 |
| TRISC   | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0  | 125                 |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by op amps.

Note 1: PIC16(L)F1783 only

### 21.0 TIMER0 MODULE

The Timer0 module is an 8-bit timer/counter with the following features:

- 8-bit timer/counter register (TMR0)
- 8-bit prescaler (independent of Watchdog Timer)
- Programmable internal or external clock source
- Programmable external clock edge selection
- · Interrupt on overflow
- TMR0 can be used to gate Timer1

Figure 21-1 is a block diagram of the Timer0 module.

#### 21.1 Timer0 Operation

The Timer0 module can be used as either an 8-bit timer or an 8-bit counter.

#### 21.1.1 8-BIT TIMER MODE

The Timer0 module will increment every instruction cycle, if used without a prescaler. 8-bit Timer mode is selected by clearing the TMR0CS bit of the OPTION\_REG register.

When TMR0 is written, the increment is inhibited for two instruction cycles immediately following the write.

**Note:** The value written to the TMR0 register can be adjusted, in order to account for the two instruction cycle delay when TMR0 is written.

#### FIGURE 21-1: BLOCK DIAGRAM OF THE TIMER0

#### 21.1.2 8-BIT COUNTER MODE

In 8-Bit Counter mode, the Timer0 module will increment on every rising or falling edge of the T0CKI pin.

8-Bit Counter mode using the T0CKI pin is selected by setting the TMR0CS bit in the OPTION\_REG register to '1'.

The rising or falling transition of the incrementing edge for either input source is determined by the TMR0SE bit in the OPTION\_REG register.



#### 22.6.2 TIMER1 GATE SOURCE SELECTION

Timer1 gate source selections are shown in Table 22-4. Source selection is controlled by the T1GSS bits of the T1GCON register. The polarity for each available source is also selectable. Polarity selection is controlled by the T1GPOL bit of the T1GCON register.

| <b>TABLE 22-4</b> : | TIMER1 | GATE | SOURCES |
|---------------------|--------|------|---------|
|---------------------|--------|------|---------|

| T1GSS | Timer1 Gate Source                                                        |
|-------|---------------------------------------------------------------------------|
| 00    | Timer1 Gate Pin                                                           |
| 01    | Overflow of Timer0<br>(TMR0 increments from FFh to 00h)                   |
| 10    | Comparator 1 Output sync_C1OUT<br>(optionally Timer1 synchronized output) |
| 11    | Comparator 2 Output sync_C2OUT<br>(optionally Timer1 synchronized output) |

#### 22.6.2.1 T1G Pin Gate Operation

The T1G pin is one source for Timer1 gate control. It can be used to supply an external source to the Timer1 gate circuitry.

#### 22.6.2.2 Timer0 Overflow Gate Operation

When Timer0 increments from FFh to 00h, a low-to-high pulse will automatically be generated and internally supplied to the Timer1 gate circuitry.

#### 22.6.2.3 Comparator C1 Gate Operation

The output resulting from a Comparator 1 operation can be selected as a source for Timer1 gate control. The Comparator 1 output (sync\_C1OUT) can be synchronized to the Timer1 clock or left asynchronous. For more information see Section 20.4.1 "Comparator Output Synchronization".

#### 22.6.2.4 Comparator C2 Gate Operation

The output resulting from a Comparator 2 operation can be selected as a source for Timer1 gate control. The Comparator 2 output (sync\_C2OUT) can be synchronized to the Timer1 clock or left asynchronous. For more information see Section 20.4.1 "Comparator Output Synchronization".

#### 22.6.3 TIMER1 GATE TOGGLE MODE

When Timer1 Gate Toggle mode is enabled, it is possible to measure the full-cycle length of a Timer1 gate signal, as opposed to the duration of a single level pulse.

The Timer1 gate source is routed through a flip-flop that changes state on every incrementing edge of the signal. See Figure 22-4 for timing details.

Timer1 Gate Toggle mode is enabled by setting the T1GTM bit of the T1GCON register. When the T1GTM bit is cleared, the flip-flop is cleared and held clear. This is necessary in order to control which edge is measured.

| Note: | Enabling Toggle mode at the same time       |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|
|       | as changing the gate polarity may result in |  |  |  |  |  |  |
|       | indeterminate operation.                    |  |  |  |  |  |  |

### 22.6.4 TIMER1 GATE SINGLE-PULSE MODE

When Timer1 Gate Single-Pulse mode is enabled, it is possible to capture a single-pulse gate event. Timer1 Gate Single-Pulse mode is enabled by first setting the T1GSPM bit in the T1GCON register. Next, the T1GGO/DONE bit in the T1GCON register must be set. The Timer1 will be fully enabled on the next incrementing edge. On the next trailing edge of the pulse, the T1GGO/DONE bit will automatically be cleared. No other gate events will be allowed to increment Timer1 until the T1GGO/DONE bit is once again set in software. See Figure 22-5 for timing details.

If the Single-Pulse Gate mode is disabled by clearing the T1GSPM bit in the T1GCON register, the T1GGO/DONE bit should also be cleared.

Enabling the Toggle mode and the Single-Pulse mode simultaneously will permit both sections to work together. This allows the cycle times on the Timer1 gate source to be measured. See Figure 22-6 for timing details.

#### 22.6.5 TIMER1 GATE VALUE

When Timer1 Gate Value Status is utilized, it is possible to read the most current level of the gate control value. The value is accessible by reading the T1GVAL bit in the T1GCON register. The T1GVAL bit is valid even when the Timer1 gate is not enabled (TMR1GE bit is cleared).

#### 22.6.6 TIMER1 GATE EVENT INTERRUPT

When Timer1 Gate Event Interrupt is enabled, it is possible to generate an interrupt upon the completion of a gate event. When the falling edge of T1GVAL occurs, the TMR1GIF flag bit in the PIR1 register will be set. If the TMR1GIE bit in the PIE1 register is set, then an interrupt will be recognized.

The TMR1GIF flag bit operates even when the Timer1 gate is not enabled (TMR1GE bit is cleared).

#### 24.3.8 PULSE-SKIPPING PWM WITH COMPLEMENTARY OUTPUTS

The pulse-skipping PWM is used to generate a series of fixed-length pulses that may or not be triggered at each period event. If any of the sources enabled to generate a rising edge event are high when a period event occurs, a pulse will be generated. If the rising edge sources are low at the period event, no pulse will be generated.

The rising edge occurs based upon the value in the PSMCxPH register pair.

The falling edge event always occurs according to the enabled event inputs without qualification between any two inputs.

#### 24.3.8.1 Mode Features

- · Dead-band control is available
- · No steering control available
- · Primary PWM is output on only PSMCxA.
- · Complementary PWM is output on only PSMCxB.

#### 24.3.8.2 Waveform Generation

#### Rising Edge Event

If any enabled asynchronous rising edge event = 1 when there is a period event, then upon the next synchronous rising edge event:

- · Complementary output is set inactive
- Dead-band rising is activated (if enabled)
- · Primary output is set active

#### Falling Edge Event

- · Primary output is set inactive
- Dead-band falling is activated (if enabled)
- · Complementary output is set active

Note: To use this mode, an external source must be used for the determination of whether or not to generate the set pulse. If the phase time base is used, it will either always generate a pulse or never generate a pulse based on the PSMCxPH value.

#### FIGURE 24-11: PULSE-SKIPPING WITH COMPLEMENTARY OUTPUT PWM WAVEFORM



#### REGISTER 24-5: PSMCxCLK: PSMC CLOCK CONTROL REGISTER

| U-0              | U-0                          | R/W-0/0          | R/W-0/0        | U-0                                | U-0              | R/W-0/0          | R/W-0/0     |
|------------------|------------------------------|------------------|----------------|------------------------------------|------------------|------------------|-------------|
| _                | —                            | PxCPR            | E<1:0>         | —                                  | —                | PxCSRC<1:0>      |             |
| bit 7            |                              |                  |                |                                    |                  |                  | bit 0       |
|                  |                              |                  |                |                                    |                  |                  |             |
| Legend:          |                              |                  |                |                                    |                  |                  |             |
| R = Readable     | bit                          | W = Writable     | bit            | U = Unimpler                       | mented bit, read | as '0'           |             |
| u = Bit is uncha | anged                        | x = Bit is unkr  | nown           | -n/n = Value a                     | at POR and BO    | R/Value at all o | ther Resets |
| '1' = Bit is set |                              | '0' = Bit is cle | ared           |                                    |                  |                  |             |
|                  |                              |                  |                |                                    |                  |                  |             |
| bit 7-6          | Unimplement                  | ted: Read as '   | 0'             |                                    |                  |                  |             |
| bit 5-4          | PxCPRE<1:0                   | >: PSMCx Clo     | ck Prescaler S | Selection bits                     |                  |                  |             |
|                  | 11 = PSMCx                   | Clock frequent   | cy/8           |                                    |                  |                  |             |
|                  | 10 = PSMCx                   | Clock frequend   | cy/4           |                                    |                  |                  |             |
|                  | 01 = PSMCx                   | Clock frequent   | cy/2           |                                    |                  |                  |             |
| hit 3-2          |                              | tod: Pead as '   | -y/ĭ<br>∩'     |                                    |                  |                  |             |
| bit 3-2          |                              |                  |                | 4 <sup>1</sup> 1- <sup>1</sup> 4 - |                  |                  |             |
| DIT 1-0          | PXCSRC<1:0                   |                  | CK Source Sei  | ection bits                        |                  |                  |             |
|                  | 11 = Reserve                 | 0<br>CLK nin     |                |                                    |                  |                  |             |
|                  | 10 = PSIVICX(<br>01 = 64 MHz | clock in from F  | 21             |                                    |                  |                  |             |
|                  | 00 = Fosc system             | stem clock       |                |                                    |                  |                  |             |

#### REGISTER 24-6: PSMCxOEN: PSMC OUTPUT ENABLE CONTROL REGISTER

| U-0   | U-0 | R/W-0/0              | R/W-0/0              | R/W-0/0              | R/W-0/0              | R/W-0/0 | R/W-0/0 |
|-------|-----|----------------------|----------------------|----------------------|----------------------|---------|---------|
| —     | _   | PxOEF <sup>(1)</sup> | PxOEE <sup>(1)</sup> | PxOED <sup>(1)</sup> | PxOEC <sup>(1)</sup> | PxOEB   | PxOEA   |
| 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-6 Unimplemented: Read as '0'

bit 5-0 **PxOEy:** PSMCx Output y Enable bit<sup>(1)</sup>

- 1 = PWM output is active on PSMCx output y pin
- 0 = PWM output is not active, normal port functions in control of pin
- **Note 1:** These bits are not implemented on PSMC2.

| R/W-0/0          | R/W-0/0                       | R/W-0/0                                                                                                                                                      | U-0                            | U-0                          | U-0                             | U-0                         | R/W-0/0           |  |
|------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------|---------------------------------|-----------------------------|-------------------|--|
| PxASE            | PxASDEN                       | PxARSEN                                                                                                                                                      | —                              | —                            | _                               | —                           | PxASDOV           |  |
| bit 7            |                               |                                                                                                                                                              |                                |                              |                                 |                             | bit 0             |  |
|                  |                               |                                                                                                                                                              |                                |                              |                                 |                             |                   |  |
| Legend:          |                               |                                                                                                                                                              |                                |                              |                                 |                             |                   |  |
| R = Readable     | e bit                         | W = Writable                                                                                                                                                 | bit                            | U = Unimple                  | mented bit, read                | d as '0'                    |                   |  |
| u = Bit is unc   | hanged                        | x = Bit is unkr                                                                                                                                              | iown                           | -n/n = Value                 | at POR and BO                   | R/Value at all              | other Resets      |  |
| '1' = Bit is set | t                             | '0' = Bit is clea                                                                                                                                            | ared                           |                              |                                 |                             |                   |  |
| hit 7            |                               | M Auto-Shutdov                                                                                                                                               | un Event Stat                  | us bit(1)                    |                                 |                             |                   |  |
| Dit 7            | $1 = \Delta $ shutd           | own event has                                                                                                                                                |                                | /M outputs are               | inactive and in                 | their shutdow               | n states          |  |
|                  | 0 = PWM o                     | outputs are oper                                                                                                                                             | ating normall                  | y                            |                                 |                             | 11 512105         |  |
| bit 6            | PxASDEN: F                    | WM Auto-Shut                                                                                                                                                 | down Enable                    | bit                          |                                 |                             |                   |  |
|                  | 1 = Auto-sh<br>puts wil       | utdown is enab<br>I go into their au                                                                                                                         | led. If any of<br>ito-shutdown | the sources in state and PSN | PSMCxASDS a<br>MCxSIF flag will | issert a logic '<br>be set. | 1', then the out- |  |
|                  | 0 = Auto-sh                   | utdown is disab                                                                                                                                              | led                            |                              | · ·                             |                             |                   |  |
| bit 5            | PxARSEN: F                    | PWM Auto-Rest                                                                                                                                                | art Enable bit                 | t                            |                                 |                             |                   |  |
|                  | 1 = PWM re                    | estarts automati                                                                                                                                             | cally when th                  | e shutdown co                | ondition is remov               | /ed.                        |                   |  |
|                  | 0 = The Px/<br>cleared        | ASE bit must be                                                                                                                                              | e cleared in fi                | rmware to rest               | art PWM after th                | ne auto-shutdo              | own condition is  |  |
| bit 4-1          | Unimplemer                    | nted: Read as '                                                                                                                                              | )'                             |                              |                                 |                             |                   |  |
| bit 0            | PxASDOV: F                    | PWM Auto-Shut                                                                                                                                                | down Overric                   | le bit                       |                                 |                             |                   |  |
|                  | <u>PxASDEN =</u>              | <u>1:</u>                                                                                                                                                    |                                |                              |                                 |                             |                   |  |
|                  | 1 = Force F<br>0 = Normal     | <ul> <li>1 = Force PxASDL[n] levels on the PSMCx[n] pins without causing a PSMCxSIF interrupt</li> <li>0 = Normal PWM and auto-shutdown execution</li> </ul> |                                |                              |                                 |                             |                   |  |
|                  | <u>PxASDEN =</u><br>No effect | <u>0:</u>                                                                                                                                                    |                                |                              |                                 |                             |                   |  |
| Note 1: P/       | ASE hit may be                | set in software                                                                                                                                              | When this or                   | cure the functi              | onality is the sa               | me as that ca               | used by           |  |

#### REGISTER 24-14: PSMCxASDC: PSMC AUTO-SHUTDOWN CONTROL REGISTER

**Note 1:** PASE bit may be set in software. When this occurs the functionality is the same as that caused by hardware.

| R/W-0/0          | R/W-0/0                                                        | R/W-0/0                                               | R/W-0/0                          | R/W-0/0                                               | R/W-0/0      | R/W-0/0 | R/W-0/0 |  |  |  |
|------------------|----------------------------------------------------------------|-------------------------------------------------------|----------------------------------|-------------------------------------------------------|--------------|---------|---------|--|--|--|
| PxTOVIE          | PxTPHIE                                                        | PxTDCIE                                               | PxTPRIE                          | PxTOVIF                                               | PxTPHIF      | PxTDCIF | PxTPRIF |  |  |  |
| bit 7            |                                                                |                                                       |                                  |                                                       |              |         | bit 0   |  |  |  |
|                  |                                                                |                                                       |                                  |                                                       |              |         |         |  |  |  |
| Legend:          |                                                                |                                                       |                                  |                                                       |              |         |         |  |  |  |
| R = Readable     | bit                                                            | W = Writable                                          | bit                              | U = Unimplemented bit, read as '0'                    |              |         |         |  |  |  |
| u = Bit is unch  | anged                                                          | x = Bit is unkr                                       | nown                             | -n/n = Value at POR and BOR/Value at all other Resets |              |         |         |  |  |  |
| '1' = Bit is set |                                                                | '0' = Bit is cle                                      | ared                             |                                                       |              |         |         |  |  |  |
|                  |                                                                |                                                       |                                  |                                                       |              |         |         |  |  |  |
| bit 7            | PxTOVIE: PS                                                    | SMC Time Base                                         | e Counter Ove                    | rflow Interrupt                                       | Enable bit   |         |         |  |  |  |
|                  | 1 = Time ba                                                    | ise counter ove                                       | rflow interrupt                  | s are enabled                                         |              |         |         |  |  |  |
|                  | 0 = Time ba                                                    | ise counter ove                                       | rflow interrupt                  | s are disabled                                        |              |         |         |  |  |  |
| bit 6            | PXTPHIE: PS                                                    | SMC Time Base                                         | Phase Interru                    | upt Enable bit                                        |              |         |         |  |  |  |
|                  | 1 = 1 ime ba                                                   | ise phase matc                                        | h interrupts ar                  | e enabled                                             |              |         |         |  |  |  |
| bit 5            |                                                                |                                                       | n interrupts an<br>Duty Cycle Ir | e disabled                                            | a bit        |         |         |  |  |  |
| bit 5            | 1 = Time ba                                                    | ise duty cycle r                                      | natch interrunt                  | ts are enabled                                        |              |         |         |  |  |  |
|                  | 0 = Time ba                                                    | ise duty cycle n                                      | natch interrupt                  | ts are disabled                                       |              |         |         |  |  |  |
| bit 4            | PxTPRIE: PS                                                    | SMC Time Base                                         | Period Interr                    | upt Enable bit                                        |              |         |         |  |  |  |
|                  | 1 = Time ba                                                    | se period match interrupts are enabled                |                                  |                                                       |              |         |         |  |  |  |
|                  | 0 = Time ba                                                    | base period match Interrupts are disabled             |                                  |                                                       |              |         |         |  |  |  |
| bit 3            | PxTOVIF: PS                                                    | SMC Time Base                                         | e Counter Ove                    | rflow Interrupt                                       | Flag bit     |         |         |  |  |  |
|                  | 1 = The 16-bit PSMCxTMR has overflowed from FFFFh to 0000h     |                                                       |                                  |                                                       |              |         |         |  |  |  |
|                  | 0 = The 16-                                                    | bit PSMCxTMF                                          | R counter has                    | not overflowed                                        |              |         |         |  |  |  |
| bit 2            | bit 2 <b>PxTPHIF</b> : PSMC Time Base Phase Interrupt Flag bit |                                                       |                                  |                                                       |              |         |         |  |  |  |
|                  | 1 = 1he 16-                                                    |                                                       | R counter has                    | matched PSM                                           | CXPH<15:0>   | _       |         |  |  |  |
| hit 1            |                                                                |                                                       |                                  | not matched F                                         |              |         |         |  |  |  |
| DIL I            |                                                                |                                                       |                                  |                                                       |              |         |         |  |  |  |
|                  | 0 = The  16-                                                   | bit PSMCxTMF                                          | R counter has                    | not matched P                                         | SMCxDC<15:02 | >       |         |  |  |  |
| bit 0            | PxTPRIF: PS                                                    | MC Time Base                                          | Period Interru                   | upt Flag bit                                          |              |         |         |  |  |  |
|                  | 1 = The 16-                                                    | The 16-bit PSMCxTMR counter has matched PSMCxPR<15:0> |                                  |                                                       |              |         |         |  |  |  |
|                  | 0 = The 16-                                                    | bit PSMCxTMF                                          | R counter has                    | not matched P                                         | SMCxPR<15:0  | >       |         |  |  |  |
|                  |                                                                |                                                       |                                  |                                                       |              |         |         |  |  |  |

#### REGISTER 24-32: PSMCxINT: PSMC TIME BASE INTERRUPT CONTROL REGISTER

#### 26.2.4 SPI SLAVE MODE

In Slave mode, the data is transmitted and received as external clock pulses appear on SCK. When the last bit is latched, the SSP1IF interrupt flag bit is set.

Before enabling the module in SPI Slave mode, the clock line must match the proper Idle state. The clock line can be observed by reading the SCK pin. The Idle state is determined by the CKP bit of the SSPCON1 register.

While in Slave mode, the external clock is supplied by the external clock source on the SCK pin. This external clock must meet the minimum high and low times as specified in the electrical specifications.

While in Sleep mode, the slave can transmit/receive data. The shift register is clocked from the SCK pin input and when a byte is received, the device will generate an interrupt. If enabled, the device will wake-up from Sleep.

#### 26.2.4.1 Daisy-Chain Configuration

The SPI bus can sometimes be connected in a daisy-chain configuration. The first slave output is connected to the second slave input, the second slave output is connected to the third slave input, and so on. The final slave output is connected to the master input. Each slave sends out, during a second group of clock pulses, an exact copy of what was received during the first group of clock pulses. The whole chain acts as one large communication shift register. The daisy-chain feature only requires a single Slave Select line from the master device.

Figure 26-7 shows the block diagram of a typical daisy-chain connection when operating in SPI mode.

In a daisy-chain configuration, only the most recent byte on the bus is required by the slave. Setting the BOEN bit of the SSPCON3 register will enable writes to the SSPBUF register, even if the previous byte has not been read. This allows the software to ignore data that may not apply to it.

#### 26.2.5 SLAVE SELECT SYNCHRONIZATION

The Slave Select can also be used to synchronize communication. The Slave Select line is held high until the master device is ready to communicate. When the Slave Select line is pulled low, the slave knows that a new transmission is starting.

If the slave fails to receive the communication properly, it will be reset at the end of the transmission, when the Slave Select line returns to a high state. The slave is then ready to receive a new transmission when the Slave Select line is pulled low again. If the Slave Select line is not used, there is a risk that the slave will eventually become out of sync with the master. If the slave misses a bit, it will always be one bit off in future transmissions. Use of the Slave Select line allows the slave and master to align themselves at the beginning of each transmission.

The  $\overline{SS}$  pin allows a Synchronous Slave mode. The SPI must be in Slave mode with  $\overline{SS}$  pin control enabled (SSPCON1<3:0> = 0100).

When the  $\overline{SS}$  pin is low, transmission and reception are enabled and the SDO pin is driven.

When the  $\overline{SS}$  pin goes high, the SDO pin is no longer driven, even if in the middle of a transmitted byte and becomes a floating output. External pull-up/pull-down resistors may be desirable depending on the application.

| Note 1: | When the SPI is in Slave mode with $\overline{SS}$ pin<br>control enabled (SSPCON1<3:0> =<br>0100), the SPI module will reset if the $\overline{SS}$<br>pin is set to VDD. |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:      | When the SPI is used in Slave mode with CKE set; the user must enable $\overline{SS}$ pin control.                                                                         |
| 3:      | While operated in SPI Slave mode the                                                                                                                                       |

SMP bit of the SSPSTAT register must remain clear.

When the SPI module resets, the bit counter is forced to '0'. This can be done by either forcing the  $\overline{SS}$  pin to a high level or clearing the SSPEN bit.



#### 27.2 Clock Accuracy with Asynchronous Operation

The factory calibrates the internal oscillator block output (INTOSC). However, the INTOSC frequency may drift as VDD or temperature changes, and this directly affects the asynchronous baud rate. Two methods may be used to adjust the baud rate clock, but both require a reference clock source of some kind.

The first (preferred) method uses the OSCTUNE register to adjust the INTOSC output. Adjusting the value in the OSCTUNE register allows for fine resolution changes to the system clock source. See Section 6.2.2 "Internal Clock Sources" for more information.

The other method adjusts the value in the Baud Rate Generator. This can be done automatically with the Auto-Baud Detect feature (see Section 27.4.1 "Auto-Baud Detect"). There may not be fine enough resolution when adjusting the Baud Rate Generator to compensate for a gradual change in the peripheral clock frequency.

#### 27.4.1 AUTO-BAUD DETECT

The EUSART module supports automatic detection and calibration of the baud rate.

In the Auto-Baud Detect (ABD) mode, the clock to the BRG is reversed. Rather than the BRG clocking the incoming RX signal, the RX signal is timing the BRG. The Baud Rate Generator is used to time the period of a received 55h (ASCII "U") which is the Sync character for the LIN bus. The unique feature of this character is that it has five rising edges including the Stop bit edge.

Setting the ABDEN bit of the BAUDCON register starts the auto-baud calibration sequence (Figure 27-6). While the ABD sequence takes place, the EUSART state machine is held in idle. On the first rising edge of the receive line, after the Start bit, the SPBRG begins counting up using the BRG counter clock as shown in Table 27-6. The fifth rising edge will occur on the RX pin at the end of the eighth bit period. At that time, an accumulated value totaling the proper BRG period is left in the SPBRGH, SPBRGL register pair, the ABDEN bit is automatically cleared and the RCIF interrupt flag is set. The value in the RCREG needs to be read to clear the RCIF interrupt. RCREG content should be discarded. When calibrating for modes that do not use the SPBRGH register the user can verify that the SPBRGL register did not overflow by checking for 00h in the SPBRGH register.

The BRG auto-baud clock is determined by the BRG16 and BRGH bits as shown in Table 27-6. During ABD, both the SPBRGH and SPBRGL registers are used as a 16-bit counter, independent of the BRG16 bit setting. While calibrating the baud rate period, the SPBRGH and SPBRGL registers are clocked at 1/8th the BRG base clock rate. The resulting byte measurement is the average bit time when clocked at full speed.

- Note 1: If the WUE bit is set with the ABDEN bit, auto-baud detection will occur on the byte <u>following</u> the Break character (see <u>Section 27.4.3</u> "Auto-Wake-up on Break").
  - 2: It is up to the user to determine that the incoming character baud rate is within the range of the selected BRG clock source. Some combinations of oscillator frequency and EUSART baud rates are not possible.
  - 3: During the auto-baud process, the auto-baud counter starts counting at 1. Upon completion of the auto-baud sequence, to achieve maximum accuracy, subtract 1 from the SPBRGH:SPBRGL register pair.

| <b>FABLE 27-6</b> : | <b>BRG COUNTER CLOCK RATES</b> |
|---------------------|--------------------------------|
|---------------------|--------------------------------|

| BRG16 | BRGH | BRG Base<br>Clock | BRG ABD<br>Clock |  |  |  |
|-------|------|-------------------|------------------|--|--|--|
| 0     | 0    | Fosc/64           | Fosc/512         |  |  |  |
| 0     | 1    | Fosc/16           | Fosc/128         |  |  |  |
| 1     | 0    | Fosc/16           | Fosc/128         |  |  |  |
| 1     | 1    | Fosc/4            | Fosc/32          |  |  |  |

**Note:** During the ABD sequence, SPBRGL and SPBRGH registers are both used as a 16-bit counter, independent of BRG16 setting.



#### FIGURE 27-6: AUTOMATIC BAUD RATE CALIBRATION

#### TABLE 29-3: INSTRUCTION SET (CONTINUED)

| Mnemonic,<br>Operands |               | Description                                   | Cycles | 14-Bit Opcode |       |      |      | Status   | Notoo |
|-----------------------|---------------|-----------------------------------------------|--------|---------------|-------|------|------|----------|-------|
|                       |               | Description                                   |        | MSb           |       |      | LSb  | Affected | Notes |
|                       | CONTROL OPERA |                                               |        |               |       |      |      |          |       |
| BRA                   | k             | Relative Branch                               | 2      | 11            | 001k  | kkkk | kkkk |          |       |
| BRW                   | _             | Relative Branch with W                        | 2      | 00            | 0000  | 0000 | 1011 |          |       |
| CALL                  | k             | Call Subroutine                               | 2      | 10            | 0 kkk | kkkk | kkkk |          |       |
| CALLW                 | _             | Call Subroutine with W                        | 2      | 00            | 0000  | 0000 | 1010 |          |       |
| GOTO                  | k             | Go to address                                 | 2      | 10            | 1kkk  | kkkk | kkkk |          |       |
| RETFIE                | k             | Return from interrupt                         | 2      | 00            | 0000  | 0000 | 1001 |          |       |
| RETLW                 | k             | Return with literal in W                      | 2      | 11            | 0100  | kkkk | kkkk |          |       |
| RETURN                | -             | Return from Subroutine                        | 2      | 00            | 0000  | 0000 | 1000 |          |       |
| INHERENT OPERATIONS   |               |                                               |        |               |       |      |      |          |       |
| CLRWDT                | -             | Clear Watchdog Timer                          | 1      | 00            | 0000  | 0110 | 0100 | TO, PD   |       |
| NOP                   | _             | No Operation                                  | 1      | 00            | 0000  | 0000 | 0000 |          |       |
| OPTION                | _             | Load OPTION_REG register with W               | 1      | 00            | 0000  | 0110 | 0010 |          |       |
| RESET                 | _             | Software device Reset                         | 1      | 00            | 0000  | 0000 | 0001 |          |       |
| SLEEP                 | _             | Go into Standby mode                          | 1      | 00            | 0000  | 0110 | 0011 | TO, PD   |       |
| TRIS                  | f             | Load TRIS register with W                     | 1      | 00            | 0000  | 0110 | Offf |          |       |
| C-COMPILER OPTIMIZED  |               |                                               |        |               |       |      |      |          |       |
| ADDFSR                | n, k          | Add Literal k to FSRn                         | 1      | 11            | 0001  | 0nkk | kkkk |          |       |
| MOVIW                 | n mm          | Move Indirect FSRn to W with pre/post inc/dec | 1      | 00            | 0000  | 0001 | 0nmm | Z        | 2, 3  |
|                       |               | modifier, mm                                  |        |               |       |      |      |          |       |
|                       | k[n]          | Move INDFn to W, Indexed Indirect.            | 1      | 11            | 1111  | Onkk | kkkk | Z        | 2     |
| MOVWI                 | n mm          | Move W to Indirect FSRn with pre/post inc/dec | 1      | 00            | 0000  | 0001 | 1nmm |          | 2, 3  |
|                       |               | modifier, mm                                  |        |               |       |      |      |          |       |
|                       | k[n]          | Move W to INDFn, Indexed Indirect.            | 1      | 11            | 1111  | 1nkk | kkkk |          | 2     |

**Note 1:** If the Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

2: If this instruction addresses an INDF register and the MSb of the corresponding FSR is set, this instruction will require one additional instruction cycle.

**3:** See Table in the MOVIW and MOVWI instruction descriptions.

Note: Unless otherwise noted, VIN = 5V, Fosc = 300 kHz, CIN = 0.1  $\mu$ F, TA = 25°C.



**FIGURE 31-121:** Comparator Response Time Over Voltage, NP Mode (CxSP = 1), Typical Measured Values, PIC16F1782/3 Only.



**FIGURE 31-123:** Comparator Output Filter Delay Time Over Temp., NP Mode (CxSP = 1), Typical Measured Values, PIC16F1782/3 Only.



**FIGURE 31-125:** Typical DAC INL Error, VDD = 3.0V, VREF = External 3V.



**FIGURE 31-122:** Comparator Output Filter Delay Time Over Temp., NP Mode (CxSP = 1), Typical Measured Values, PIC16LF1782/3 Only.



**FIGURE 31-124:** Typical DAC DNL Error, VDD = 3.0V, VREF = External 3V.



**FIGURE 31-126:** Typical DAC INL Error, VDD = 5.0V, VREF = External 5V, PIC16F1782/3 Only.