



#### 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               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                |
| Peripherals                | Brown-out Detect/Reset, POR, PSMC, PWM, WDT                              |
| Number of I/O              | 35                                                                       |
| Program Memory Size        | 28KB (16K x 14)                                                          |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 256 x 8                                                                  |
| RAM Size                   | 2K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                              |
| Data Converters            | A/D 14x12b; D/A 1x8b, 3x5b                                               |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                       |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                 |
| Supplier Device Package    | 40-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1789-e-p |

Email: info@E-XFL.COM

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

#### Pin Diagram – 44-Pin TQFP



#### TABLE 1-2: PIC16(L)F1788 PINOUT DESCRIPTION (CONTINUED)

| Name                   | Function | Input<br>Type    | Output<br>Type | Description                         |
|------------------------|----------|------------------|----------------|-------------------------------------|
| RC3/PSMC1D/PSMC4A/SCK/ | RC3      | TTL/ST           | CMOS           | General purpose I/O.                |
| SCL                    | PSMC1D   | —                | CMOS           | PSMC1 output D.                     |
|                        | PSMC4A   | —                | CMOS           | PSMC4 output A.                     |
|                        | SCK      | ST               | CMOS           | SPI clock.                          |
|                        | SCL      | l <sup>2</sup> C | OD             | I <sup>2</sup> C clock.             |
| RC4/PSMC1E/PSMC4B/SDI/ | RC4      | TTL/ST           | CMOS           | General purpose I/O.                |
| SDA                    | PSMC1E   | —                | CMOS           | PSMC1 output E.                     |
|                        | PSMC4B   | —                | CMOS           | PSMC4 output B.                     |
|                        | SDI      | ST               |                | SPI data input.                     |
|                        | SDA      | l <sup>2</sup> C | OD             | I <sup>2</sup> C data input/output. |
| RC5/PSMC1F/PSMC3A/SDO  | RC5      | TTL/ST           | CMOS           | General purpose I/O.                |
|                        | PSMC1F   | —                | CMOS           | PSMC1 output F.                     |
|                        | PSMC3A   | —                | CMOS           | PSMC3 output A.                     |
|                        | SDO      | —                | CMOS           | SPI data output.                    |
| RC6/PSMC2A/TX/CK/CCP3  | RC6      | TTL/ST           | CMOS           | General purpose I/O.                |
|                        | PSMC2A   | —                | CMOS           | PSMC2 output A.                     |
|                        | ТΧ       | —                | CMOS           | EUSART asynchronous transmit.       |
|                        | СК       | ST               | CMOS           | EUSART synchronous clock.           |
|                        | CCP3     | ST               | CMOS           | Capture/Compare/PWM3.               |
| RC7/C4OUT/PSMC2B/RX/DT | RC7      | TTL/ST           | CMOS           | General purpose I/O.                |
|                        | C4OUT    | _                | CMOS           | Comparator C4 output.               |
|                        | PSMC2B   | —                | CMOS           | PSMC2 output B.                     |
|                        | RX       | ST               |                | EUSART asynchronous input.          |
|                        | DT       | ST               | CMOS           | EUSART synchronous data.            |
| RE3/MCLR/VPP           | RE3      | TTL/ST           |                | General purpose input.              |
|                        | MCLR     | ST               | _              | Master Clear with internal pull-up. |
|                        | Vpp      | HV               | —              | Programming voltage.                |
| Vdd                    | Vdd      | Power            | —              | Positive supply.                    |
| Vss                    | Vss      | Power            | _              | Ground reference.                   |

Legend: AN = Analog input or output CMOS = CMOS compatible input or output OD = Open-Drain

TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels  $I^2C$  = Schmitt Trigger input with  $I^2C$ HV = High Voltage XTAL = Crystal levels

Note 1: Pin functions can be assigned to one of two locations via software. See Register 13-1.

**2:** All pins have interrupt-on-change functionality.

The memory maps for Bank 0 through Bank 31 are shown in the tables in this section.

### TABLE 3-3: PIC16(L)F1788 MEMORY MAP (BANKS 0-7)

|              | BANK 0                                     |              | BANK 1                                     |              | BANK 2                                     |              | BANK 3                                     |              | BANK 4 BANK 5                              |              |                                            |              | BANK 6                                     | BANK 7       |                                            |
|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|--------------|--------------------------------------------|
| 000h         | Core Registers<br>(Table 3-2)              | 080h         | Core Registers<br>(Table 3-2)              | 100h         | Core Registers<br>(Table 3-2)              | 180h         | Core Registers<br>(Table 3-2)              | 200h         | Core Registers<br>(Table 3-2)              | 280h         | Core Registers<br>(Table 3-2)              | 300h         | Core Registers<br>(Table 3-2)              | 380h         | Core Registers<br>(Table 3-2)              |
| 00Bh         |                                            | 08Bh         |                                            | 10Bh         |                                            | 18Bh         |                                            | 20Bh         |                                            | 28Bh         |                                            | 30Bh         |                                            | 38Bh         |                                            |
| 00Ch         | PORTA                                      | 08Ch         | TRISA                                      | 10Ch         | LATA                                       | 18Ch         | ANSELA                                     | 20Ch         | WPUA                                       | 28Ch         | ODCONA                                     | 30Ch         | SLRCONA                                    | 38Ch         | INLVLA                                     |
| 00Dh         | PORTB                                      | 08Dh         | TRISB                                      | 10Dh         | LATB                                       | 18Dh         | ANSELB                                     | 20Dh         | WPUB                                       | 28Dh         | ODCONB                                     | 30Dh         | SLRCONB                                    | 38Dh         | INLVLB                                     |
| 00Eh         | PORTC                                      | 08Eh         | TRISC                                      | 10Eh         | LATC                                       | 18Eh         | ANSELC                                     | 20Eh         | WPUC                                       | 28Eh         | ODCONC                                     | 30Eh         | SLRCONC                                    | 38Eh         | INLVLC                                     |
| 00Fh         | —                                          | 08Fh         | —                                          | 10Fh         | —                                          | 18Fh         | —                                          | 20Fh         | —                                          | 28Fh         | —                                          | 30Fh         | —                                          | 38Fh         | —                                          |
| 010h         | PORTE                                      | 090h         | TRISE                                      | 110h         | _                                          | 190h         | —                                          | 210h         | WPUE                                       | 290h         | —                                          | 310h         | —                                          | 390h         | INLVLE                                     |
| 011h         | PIR1                                       | 091h         | PIE1                                       | 111h         | CM1CON0                                    | 191h         | EEADRL                                     | 211h         | SSP1BUF                                    | 291h         | CCPR1L                                     | 311h         | CCPR3L                                     | 391h         | IOCAP                                      |
| 012h         | PIR2                                       | 092h         | PIE2                                       | 112h         | CM1CON1                                    | 192h         | EEADRH                                     | 212h         | SSP1ADD                                    | 292h         | CCPR1H                                     | 312h         | CCPR3H                                     | 392h         | IOCAN                                      |
| 013h         | PIR3                                       | 093h         | PIE3                                       | 113h         | CM2CON0                                    | 193h         | EEDATL                                     | 213h         | SSP1MSK                                    | 293h         | CCP1CON                                    | 313h         | CCP3CON                                    | 393h         | IOCAF                                      |
| 014h         | PIR4                                       | 094h         | PIE4                                       | 114h         | CM2CON1                                    | 194h         | EEDATH                                     | 214h         | SSP1STAT                                   | 294h         | —                                          | 314h         | —                                          | 394h         | IOCBP                                      |
| 015h         | TMR0                                       | 095h         | OPTION_REG                                 | 115h         | CMOUT                                      | 195h         | EECON1                                     | 215h         | SSP1CON1                                   | 295h         | —                                          | 315h         | —                                          | 395h         | IOCBN                                      |
| 016h         | TMR1L                                      | 096h         | PCON                                       | 116h         | BORCON                                     | 196h         | EECON2                                     | 216h         | SSP1CON2                                   | 296h         | —                                          | 316h         | —                                          | 396h         | IOCBF                                      |
| 017h         | TMR1H                                      | 097h         | WDTCON                                     | 117h         | FVRCON                                     | 197h         | VREGCON <sup>(1)</sup>                     | 217h         | SSP1CON3                                   | 297h         | _                                          | 317h         | _                                          | 397h         | IOCCP                                      |
| 018h         | T1CON                                      | 098h         | OSCTUNE                                    | 118h         | DAC1CON0                                   | 198h         | —                                          | 218h         | —                                          | 298h         | CCPR2L                                     | 318h         | —                                          | 398h         | IOCCN                                      |
| 019h         | T1GCON                                     | 099h         | OSCCON                                     | 119h         | DAC1CON1                                   | 199h         | RC1REG                                     | 219h         | —                                          | 299h         | CCPR2H                                     | 319h         | —                                          | 399h         | IOCCF                                      |
| 01Ah         | TMR2                                       | 09Ah         | OSCSTAT                                    | 11Ah         | CM4CON0                                    | 19Ah         | TX1REG                                     | 21Ah         | —                                          | 29Ah         | CCP2CON                                    | 31Ah         | —                                          | 39Ah         | _                                          |
| 01Bh         | PR2                                        | 09Bh         | ADRESL                                     | 11Bh         | CM4CON1                                    | 19Bh         | SP1BRGL                                    | 21Bh         | —                                          | 29Bh         | —                                          | 31Bh         | —                                          | 39Bh         | —                                          |
| 01Ch         | T2CON                                      | 09Ch         | ADRESH                                     | 11Ch         | APFCON2                                    | 19Ch         | SP1BRGH                                    | 21Ch         | —                                          | 29Ch         | —                                          | 31Ch         | —                                          | 39Ch         | —                                          |
| 01Dh         | —                                          | 09Dh         | ADCON0                                     | 11Dh         | APFCON1                                    | 19Dh         | RC1STA                                     | 21Dh         | —                                          | 29Dh         | —                                          | 31Dh         | —                                          | 39Dh         | —                                          |
| 01Eh         | —                                          | 09Eh         | ADCON1                                     | 11Eh         | CM3CON0                                    | 19Eh         | TX1STA                                     | 21Eh         | —                                          | 29Eh         | —                                          | 31Eh         | —                                          | 39Eh         | —                                          |
| 01Fh         | _                                          | 09Fh         | ADCON2                                     | 11Fh         | CM3CON1                                    | 19Fh         | BAUD1CON                                   | 21Fh         | _                                          | 29Fh         | —                                          | 31Fh         | —                                          | 39Fh         | —                                          |
| 020h         |                                            | 0A0h         |                                            | 120h         |                                            | 1A0h         |                                            | 220h         |                                            | 2A0h         |                                            | 320h         |                                            | 3A0h         |                                            |
|              | General<br>Purpose<br>Register<br>80 Bytes |
| 06Fh         |                                            | 0EFh         |                                            | 16Fh         |                                            | 1EFh         |                                            | 26Fh         |                                            | 2EFh         |                                            | 36Fh         |                                            | 3EFh         |                                            |
| 070h<br>07Fh | Common RAM<br>70h – 7Fh                    | 0F0h<br>0FFh | Accesses<br>70h – 7Fh                      | 170h<br>17Fh | Accesses<br>70h – 7Fh                      | 1F0h<br>1FFh | Accesses<br>70h – 7Fh                      | 270h<br>27Fh | Accesses<br>70h – 7Fh                      | 2F0h<br>2FFh | Accesses<br>70h – 7Fh                      | 370h<br>37Fh | Accesses<br>70h – 7Fh                      | 3F0h<br>3FFh | Accesses<br>70h – 7Fh                      |

**Legend:** = Unimplemented data memory locations, read as '0'.

Note 1: PIC16F1788 only.

|                    |                                                                                                                                                                                                                                       | R/P-1                                                                                                                   | R/P-1                                                                                                | R/P-1                                                           | R/P-1                                                     | R/P-1                                          | R/P-1 |  |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------|-------|--|--|--|
|                    |                                                                                                                                                                                                                                       | LVP                                                                                                                     | DEBUG                                                                                                | LPBOR                                                           | BORV                                                      | STVREN                                         | PLLEN |  |  |  |
|                    |                                                                                                                                                                                                                                       | bit 13                                                                                                                  | •                                                                                                    |                                                                 |                                                           | •                                              | bit 8 |  |  |  |
|                    |                                                                                                                                                                                                                                       |                                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| U-1                | U-1                                                                                                                                                                                                                                   | R/P-1                                                                                                                   | U-1                                                                                                  | U-1                                                             | U-1                                                       | R/P-1                                          | R/P-1 |  |  |  |
| —                  | —                                                                                                                                                                                                                                     | VCAPEN                                                                                                                  | —                                                                                                    | —                                                               | —                                                         | WRT                                            | <1:0> |  |  |  |
| bit 7              |                                                                                                                                                                                                                                       | •                                                                                                                       |                                                                                                      |                                                                 |                                                           | •                                              | bit 0 |  |  |  |
|                    |                                                                                                                                                                                                                                       |                                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| Legend:            |                                                                                                                                                                                                                                       |                                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| R = Readable       | bit                                                                                                                                                                                                                                   | P = Programma                                                                                                           | able bit                                                                                             | U = Unimpleme                                                   | ented bit, read as                                        | ·'1'                                           |       |  |  |  |
| '0' = Bit is clea  | ared                                                                                                                                                                                                                                  | '1' = Bit is set                                                                                                        |                                                                                                      | -n = Value whe                                                  | n blank or after E                                        | ulk Erase                                      |       |  |  |  |
| bit 13             | LVP: Low-Volta<br>1 = Low-voltage<br>0 = High-voltag                                                                                                                                                                                  | age Programming<br>e pro <u>gramm</u> ing e<br>e on MCLR mus                                                            | g Enable bit <sup>(1)</sup><br>nabled<br>t be used for pro                                           | ogramming                                                       |                                                           |                                                |       |  |  |  |
| bit 12             | <b>DEBUG:</b> In-Circuit Debugger Mode bit <sup>(3)</sup><br>1 = In-Circuit Debugger disabled, ICSPCLK and ICSPDAT are general purpose I/O pins<br>0 = In-Circuit Debugger enabled, ICSPCLK and ICSPDAT are dedicated to the debugger |                                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| bit 11             | <b>LPBOR</b> : Low-Power BOR Enable bit<br>1 = Low-Power Brown-out Reset is disabled<br>0 = Low-Power Brown-out Reset is enabled                                                                                                      |                                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| bit 10             | BORV: Brown-out I<br>1 = Brown-out I<br>0 = Brown-out I                                                                                                                                                                               | out Reset Voltage<br>Reset voltage (Vi<br>Reset voltage (Vi                                                             | e Selection bit <sup>(4)</sup><br>BOR), low trip po<br>BOR), high trip p                             | )<br>vint selected.<br>oint selected.                           |                                                           |                                                |       |  |  |  |
| bit 9              | STVREN: Stack<br>1 = Stack Over<br>0 = Stack Over                                                                                                                                                                                     | k Overflow/Unde<br>flow or Underflow<br>flow or Underflow                                                               | rflow Reset Ena<br>/ will cause a Re<br>/ will not cause =                                           | ible bit<br>eset<br>a Reset                                     |                                                           |                                                |       |  |  |  |
| bit 8              | <b>PLLEN:</b> PLL En<br>1 = 4xPLL enat<br>0 = 4xPLL disal                                                                                                                                                                             | nable bit<br>bled<br>bled                                                                                               |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| bit 7-6            | Unimplemente                                                                                                                                                                                                                          | ed: Read as '1'                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| bit 5              | VCAPEN: Volta<br>1 = VCAP functi<br>0 = VCAP functi                                                                                                                                                                                   | age Regulator Ca<br>onality is disable<br>onality is enabled                                                            | ipacitor Enable<br>d on RA6<br>d on RA6                                                              | bit <sup>(2)</sup>                                              |                                                           |                                                |       |  |  |  |
| bit 4-2            | Unimplemente                                                                                                                                                                                                                          | ed: Read as '1'                                                                                                         |                                                                                                      |                                                                 |                                                           |                                                |       |  |  |  |
| bit 1-0            | WRT<1:0>: Fla<br><u>8 kW Flash mer</u><br>11 = Wri<br>10 = 000<br>01 = 000<br>00 = 000                                                                                                                                                | ash Memory Self-<br>mory (PIC16(L)F<br>te protection off<br>00h to 01FFh writ<br>00h to 0FFFh writ<br>00h to 1FFFh writ | Write Protectior<br><u>1788/9 only</u> ):<br>e-protected, 020<br>e-protected, 100<br>e-protected, no | n bits<br>00h to 1FFFh ma<br>00h to 1FFFh ma<br>addresses may l | y be modified by<br>y be modified by<br>be modified by Ef | EECON control<br>EECON control<br>ECON control |       |  |  |  |
| Note 1: TI<br>2: N | he LVP bit cannot<br>ot implemented or                                                                                                                                                                                                | be programmed<br>1 "LF" devices.                                                                                        | to '0' when Proo                                                                                     | gramming mode i                                                 | s entered via LVF                                         | <b>D</b> .                                     |       |  |  |  |

#### REGISTER 4-2: CONFIG2: CONFIGURATION WORD 2

3: The DEBUG bit in Configuration Words is managed automatically by device development tools including debuggers

and programmers. For normal device operation, this bit should be maintained as a '1'.

4: See VBOR parameter for specific trip point voltages.

#### 6.5 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the device to continue operating should the external oscillator fail. The FSCM can detect oscillator failure any time after the Oscillator Start-up Timer (OST) has expired. The FSCM is enabled by setting the FCMEN bit in the Configuration Words. The FSCM is applicable to all external Oscillator modes (LP, XT, HS, EC, Timer1 Oscillator and RC).

FIGURE 6-9: FSCM BLOCK DIAGRAM



#### 6.5.1 FAIL-SAFE DETECTION

The FSCM module detects a failed oscillator by comparing the external oscillator to the FSCM sample clock. The sample clock is generated by dividing the LFINTOSC by 64. See Figure 6-9. Inside the fail detector block is a latch. The external clock sets the latch on each falling edge of the external clock. The sample clock clears the latch on each rising edge of the sample clock. A failure is detected when an entire half-cycle of the sample clock elapses before the external clock goes low.

#### 6.5.2 FAIL-SAFE OPERATION

When the external clock fails, the FSCM switches the device clock to an internal clock source and sets the bit flag OSFIF of the PIR2 register. Setting this flag will generate an interrupt if the OSFIE bit of the PIE2 register is also set. The device firmware can then take steps to mitigate the problems that may arise from a failed clock. The system clock will continue to be sourced from the internal clock source until the device firmware successfully restarts the external oscillator and switches back to external operation.

The internal clock source chosen by the FSCM is determined by the IRCF<3:0> bits of the OSCCON register. This allows the internal oscillator to be configured before a failure occurs.

#### 6.5.3 FAIL-SAFE CONDITION CLEARING

The Fail-Safe condition is cleared after a Reset, executing a SLEEP instruction or changing the SCS bits of the OSCCON register. When the SCS bits are changed, the OST is restarted. While the OST is running, the device continues to operate from the INTOSC selected in OSCCON. When the OST times out, the Fail-Safe condition is cleared after successfully switching to the external clock source. The OSFIF bit should be cleared prior to switching to the external clock source. If the Fail-Safe condition still exists, the OSFIF flag will again become set by hardware.

#### 6.5.4 RESET OR WAKE-UP FROM SLEEP

The FSCM is designed to detect an oscillator failure after the Oscillator Start-up Timer (OST) has expired. The OST is used after waking up from Sleep and after any type of Reset. The OST is not used with the EC or RC Clock modes so that the FSCM will be active as soon as the Reset or wake-up has completed. When the FSCM is enabled, the Two-Speed Start-up is also enabled. Therefore, the device will always be executing code while the OST is operating.

Note: Due to the wide range of oscillator start-up times, the Fail-Safe circuit is not active during oscillator start-up (i.e., after exiting Reset or Sleep). After an appropriate amount of time, the user should check the Status bits in the OSCSTAT register to verify the oscillator start-up and that the system clock switchover has successfully completed.

#### 21.3 Comparator Hysteresis

A selectable amount of separation voltage can be added to the input pins of each comparator to provide a hysteresis function to the overall operation. Hysteresis is enabled by setting the CxHYS bit of the CMxCON0 register.

See **Section 30.0 "Electrical Specifications"** for more information.

#### 21.4 Timer1 Gate Operation

The output resulting from a comparator operation can be used as a source for gate control of Timer1. See **Section 23.6 "Timer1 Gate"** for more information. This feature is useful for timing the duration or interval of an analog event.

It is recommended that the comparator output be synchronized to Timer1. This ensures that Timer1 does not increment while a change in the comparator is occurring.

#### 21.4.1 COMPARATOR OUTPUT SYNCHRONIZATION

The output from a comparator can be synchronized with Timer1 by setting the CxSYNC bit of the CMx-CON0 register.

Once enabled, the comparator output is latched on the falling edge of the Timer1 source clock. If a prescaler is used with Timer1, the comparator output is latched after the prescaling function. To prevent a race condition, the comparator output is latched on the falling edge of the Timer1 clock source and Timer1 increments on the rising edge of its clock source. See the Comparator Block Diagram (Figure 21-2) and the Timer1 Block Diagram (Figure 23-1) for more information.

#### 21.5 Comparator Interrupt

An interrupt can be generated upon a change in the output value of the comparator for each comparator, a rising edge detector and a falling edge detector are present.

When either edge detector is triggered and its associated enable bit is set (CxINTP and/or CxINTN bits of the CMxCON1 register), the Corresponding Interrupt Flag bit (CxIF bit of the PIR2 register) will be set.

To enable the interrupt, you must set the following bits:

- CxON, CxPOL and CxSP bits of the CMxCON0 register
- CxIE bit of the PIE2 register
- CxINTP bit of the CMxCON1 register (for a rising edge detection)
- CxINTN bit of the CMxCON1 register (for a falling edge detection)
- · PEIE and GIE bits of the INTCON register

The associated interrupt flag bit, CxIF bit of the PIR2 register, must be cleared in software. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence.

## 21.6 Comparator Positive Input Selection

Configuring the CxPCH<2:0> bits of the CMxCON1 register directs an internal voltage reference or an analog pin to the non-inverting input of the comparator:

- CxIN+ analog pin
- DAC output
- FVR (Fixed Voltage Reference)
- · Vss (Ground)

See Section 15.0 "Fixed Voltage Reference (FVR)" for more information on the Fixed Voltage Reference module.

See Section 19.0 "8-Bit Digital-to-Analog Converter (DAC) Module" for more information on the DAC input signal.

Any time the comparator is disabled (CxON = 0), all comparator inputs are disabled.

**Note:** Although a comparator is disabled, an interrupt can be generated by changing the output polarity with the CxPOL bit of the CMxCON0 register, or by switching the comparator on or off with the CxON bit of the CMxCON0 register.

#### 26.3.9 ECCP COMPATIBLE FULL-BRIDGE PWM

This mode of operation is designed to match the Full-Bridge mode from the ECCP module. It is called ECCP compatible as the term "full-bridge" alone has different connotations in regards to the output waveforms.

Full-Bridge Compatible mode uses the same waveform events as the single PWM mode to generate the output waveforms.

There are both Forward and Reverse modes available for this operation, again to match the ECCP implementation. Direction is selected with the mode control bits.

#### 26.3.9.1 Mode Features

- · Dead-band control available on direction switch
  - Changing from forward to reverse uses the falling edge dead-band counters.
  - Changing from reverse to forward uses the rising edge dead-band counters.
- · No steering control available
- PWM is output on the following four pins only:
  - PSMCxA
  - PSMCxB
  - PSMCxC
  - PSMCxD

#### 26.3.9.2 Waveform Generation - Forward

In this mode of operation, three of the four pins are static. PSMCxA is the only output that changes based on rising edge and falling edge events.

#### Static Signal Assignment

- · Outputs set to active state
  - PSMCxD
- · Outputs set to inactive state
  - PSMCxB
  - PSMCxC

#### Rising Edge Event

· PSMCxA is set active

Falling Edge Event

· PSMCxA is set inactive

#### 26.3.9.3 Waveform Generation – Reverse

In this mode of operation, three of the four pins are static. Only PSMCxB toggles based on rising edge and falling edge events.

Static Signal Assignment

- · Outputs set to active state
  - PSMCxC
- · Outputs set to inactive state
  - PSMCxA
- PSMCxD
- Rising Edge Event
- PSMCxB is set active

#### Falling Edge Event

· PSMCxB is set inactive

#### FIGURE 26-12: ECCP COMPATIBLE FULL-BRIDGE PWM WAVEFORM – PSMCXSTR0 = 0FH

| PWM Period Number  | 1 | 2        | 3      |                       | 5 | 6      | 7       | 8        | -9       | 10           | —11—        | -12 |
|--------------------|---|----------|--------|-----------------------|---|--------|---------|----------|----------|--------------|-------------|-----|
|                    | • | Forward  | mode o | peration <sup>.</sup> |   |        | Reverse | e mode c | peration |              |             |     |
| Period Event       | ┃ | <u> </u> |        | <u></u>               |   |        | ]       | ]        | ]        | [            |             |     |
| Falling Edge Event |   |          |        |                       |   |        |         |          |          |              |             |     |
| PSMCxA             |   |          |        |                       |   |        |         |          |          |              |             | -   |
| PSMCxB             |   |          |        |                       |   |        |         |          |          |              | 1<br>1<br>1 | _   |
| PSMCxC             |   |          |        |                       |   |        |         |          |          |              | 1           |     |
|                    |   |          |        |                       | _ |        |         |          | Rising   | Edge De<br>→ | ad Band     | 3   |
| PSMCxD             |   |          |        |                       |   | Tallir | iy ⊏age |          |          |              |             |     |

#### 26.6 **PSMC Modulation (Burst Mode)**

PSMC modulation is a method to stop/start PWM operation of the PSMC without having to disable the module. It also allows other modules to control the operational period of the PSMC. This is also referred to as Burst mode.

This is a method to implement PWM dimming.

#### 26.6.1 MODULATION ENABLE

The modulation function is enabled by setting the PxMDLEN bit of PSMC Modulation Control (PSMCxMDL) register (Register 26-2).

When modulation is enabled, the modulation source controls when the PWM signals are active and inactive.

When modulation is disabled, the PWM signals operate continuously, regardless of the selected modulation source.

#### 26.6.2 MODULATION SOURCES

There are multiple sources that can be used for modulating the PSMC. However, unlike the PSMC input sources, only one modulation source can be selected at a time. Modulation sources include:

- PSMCxIN pin
- Any CCP output
- · Any Comparator output
- PxMDLBIT of the PSMCxMDL register

#### 26.6.2.1 PxMDLBIT Bit

The PxMDLBIT bit of the PSMC Modulation Control (PSMCxMDL) register (Register 26-2) allows for software modulation control without having to enable/disable other module functions.

### 26.6.3 MODULATION EFFECT ON PWM SIGNALS

When modulation starts, the PSMC begins operation on a new period, just as if it had rolled over from one period to another during continuous operation.

When modulation stops, its operation depends on the type of waveform being generated.

In operation modes other than Fixed Duty Cycle, the PSMC completes its current PWM period and then freezes the module. The PSMC output pins are forced into the default inactive state ready for use when modulation starts.

In Fixed Duty Cycle mode operation, the PSMC continues to operate until the period event changes the PWM to its inactive state, at which point the PSMC module is frozen. The PSMC output pins are forced into the default inactive state ready for use when modulation starts.



#### FIGURE 26-19: PSMC MODULATION WAVEFORM

| R/W-0/0          | U-0                                                              | U-0              | R/W-0/0         | R/W-0/0                            | R/W-0/0              | R/W-0/0          | U-0         |  |  |  |  |
|------------------|------------------------------------------------------------------|------------------|-----------------|------------------------------------|----------------------|------------------|-------------|--|--|--|--|
| PxASDSIN         | —                                                                | —                | PxASDSC4        | PxASDSC3                           | PxASDSC2             | PxASDSC1         | —           |  |  |  |  |
| bit 7            |                                                                  |                  |                 |                                    |                      |                  | bit 0       |  |  |  |  |
|                  |                                                                  |                  |                 |                                    |                      |                  |             |  |  |  |  |
| Legend:          |                                                                  |                  |                 |                                    |                      |                  |             |  |  |  |  |
| R = Readable I   | bit                                                              | W = Writable     | bit             | U = Unimplemented 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            | PxASDSIN: A                                                      | uto-shutdown     | occurs on PSI   | MCxIN pin                          |                      |                  |             |  |  |  |  |
|                  | 1 = Auto-shutdown will occur when PSMCxIN pin goes true          |                  |                 |                                    |                      |                  |             |  |  |  |  |
|                  | 0 = PSMCXIN pin will not cause auto-shutdown                     |                  |                 |                                    |                      |                  |             |  |  |  |  |
| bit 6-5          | Unimplemen                                                       | ted: Read as '   | 0'              |                                    |                      |                  |             |  |  |  |  |
| bit 4            | PxASDSC4:                                                        | Auto-shutdown    | occurs on syr   | nc_C4OUT out                       | put                  |                  |             |  |  |  |  |
|                  | 1 = Auto-shu                                                     | utdown will occ  | ur when sync    | _C4OUT outpu                       | it goes true         |                  |             |  |  |  |  |
|                  | $0 = sync_{-}C4$                                                 |                  | ause auto-shu   | Itdown                             |                      |                  |             |  |  |  |  |
| bit 3            | PxASDSC3:                                                        | Auto-shutdown    | occurs on syr   | nc_C3OUT out                       | iput                 |                  |             |  |  |  |  |
|                  | 1 = Auto-shu                                                     | utdown will occ  | our when sync   | _C3OUT outpu                       | it goes true         |                  |             |  |  |  |  |
| hit 0            | D = Sync_CC                                                      |                  |                 |                                    |                      |                  |             |  |  |  |  |
| DIL Z            |                                                                  | utdown will occ  | i occurs on syr |                                    | ipui<br>it goos truo |                  |             |  |  |  |  |
|                  | 0 = sync  C2                                                     | 20UT will not a  | ause auto-shu   | _c2001 outpe                       | it goes tide         |                  |             |  |  |  |  |
| bit 1            | it 1 <b>PxASDSC1:</b> Auto-shutdown occurs on sync. C10UT output |                  |                 |                                    |                      |                  |             |  |  |  |  |
|                  | 1 = Auto-shi                                                     | utdown will occ  | ur when sync    | C1OU output                        | goes true            |                  |             |  |  |  |  |
|                  | 0 = sync_C1                                                      | OU will not ca   | use auto-shut   | down                               | -                    |                  |             |  |  |  |  |
| bit 0            | Unimplemen                                                       | ted: Read as '   | 0'              |                                    |                      |                  |             |  |  |  |  |

#### REGISTER 26-18: PSMCxASDS: PSMC AUTO-SHUTDOWN SOURCE REGISTER

#### 27.2 SPI Mode Overview

The Serial Peripheral Interface (SPI) bus is a synchronous serial data communication bus that operates in Full-Duplex mode. Devices communicate in a master/slave environment where the master device initiates the communication. A slave device is controlled through a Chip Select known as Slave Select.

The SPI bus specifies four signal connections:

- Serial Clock (SCK)
- Serial Data Out (SDO)
- Serial Data In (SDI)
- Slave Select (SS)

Figure 27-1 shows the block diagram of the MSSP module when operating in SPI mode.

The SPI bus operates with a single master device and one or more slave devices. When multiple slave devices are used, an independent Slave Select connection is required from the master device to each slave device.

Figure 27-4 shows a typical connection between a master device and multiple slave devices.

The master selects only one slave at a time. Most slave devices have tri-state outputs so their output signal appears disconnected from the bus when they are not selected.

Transmissions involve two shift registers, eight bits in size, one in the master and one in the slave. With either the master or the slave device, data is always shifted out one bit at a time, with the Most Significant bit (MSb) shifted out first. At the same time, a new Least Significant bit (LSb) is shifted into the same register.

Figure 27-5 shows a typical connection between two processors configured as master and slave devices.

Data is shifted out of both shift registers on the programmed clock edge and latched on the opposite edge of the clock.

The master device transmits information out on its SDO output pin which is connected to, and received by, the slave's SDI input pin. The slave device transmits information out on its SDO output pin, which is connected to, and received by, the master's SDI input pin.

To begin communication, the master device first sends out the clock signal. Both the master and the slave devices should be configured for the same clock polarity.

The master device starts a transmission by sending out the MSb from its shift register. The slave device reads this bit from that same line and saves it into the LSb position of its shift register. During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the master device is sending out the MSb from its shift register (on its SDO pin) and the slave device is reading this bit and saving it as the LSb of its shift register, that the slave device is also sending out the MSb from its shift register (on its SDO pin) and the master device is reading this bit and saving it as the LSb of its shift register.

After eight bits have been shifted out, the master and slave have exchanged register values.

If there is more data to exchange, the shift registers are loaded with new data and the process repeats itself.

Whether the data is meaningful or not (dummy data), depends on the application software. This leads to three scenarios for data transmission:

- Master sends useful data and slave sends dummy data.
- Master sends useful data and slave sends useful data.
- Master sends dummy data and slave sends useful data.

Transmissions may involve any number of clock cycles. When there is no more data to be transmitted, the master stops sending the clock signal and it deselects the slave.

Every slave device connected to the bus that has not been selected through its slave select line must disregard the clock and transmission signals and must not transmit out any data of its own.

### 27.6.13.2 Bus Collision During a Repeated Start Condition

During a Repeated Start condition, a bus collision occurs if:

- a) A low level is sampled on SDA when SCL goes from low level to high level.
- SCL goes low before SDA is asserted low, indicating that another master is attempting to transmit a data '1'.

When the user releases SDA and the pin is allowed to float high, the BRG is loaded with SSPADD and counts down to zero. The SCL pin is then deasserted and when sampled high, the SDA pin is sampled. If SDA is low, a bus collision has occurred (i.e., another master is attempting to transmit a data '0', Figure 27-35). If SDA is sampled high, the BRG is reloaded and begins counting. If SDA goes from high-to-low before the BRG times out, no bus collision occurs because no two masters can assert SDA at exactly the same time.

If SCL goes from high-to-low before the BRG times out and SDA has not already been asserted, a bus collision occurs. In this case, another master is attempting to transmit a data '1' during the Repeated Start condition, see Figure 27-36.

If, at the end of the BRG time-out, both SCL and SDA are still high, the SDA pin is driven low and the BRG is reloaded and begins counting. At the end of the count, regardless of the status of the SCL pin, the SCL pin is driven low and the Repeated Start condition is complete.

FIGURE 27-36: BUS COLLISION DURING A REPEATED START CONDITION (CASE 1)







#### REGISTER 27-2: SSPCON1: SSP CONTROL REGISTER 1

| R/C/HS_0/C                                  | P/C/HS_0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/M/_0/0                                                                                                                                                                                                                                                                                                                                   | R/M-0/0                                                                                                                                                                                                               | R/M/-0/0                                                                                                                                              | R/W_0/0                                                                                          | P/M/_0/0                                                                                         | R/W/_0/0                                                                              |  |  |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|
| WCOI                                        | SSPOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SSPEN                                                                                                                                                                                                                                                                                                                                      | CKP                                                                                                                                                                                                                   | 10/00-0/0                                                                                                                                             | SSPM<                                                                                            | (3.0>                                                                                            | 14/07-0/0                                                                             |  |  |
| hit 7                                       | 001 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                            | ÖN                                                                                                                                                                                                                    |                                                                                                                                                       | 001 M                                                                                            | .0.02                                                                                            | bit 0                                                                                 |  |  |
|                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                       |                                                                                                                                                       |                                                                                                  |                                                                                                  | 5.10                                                                                  |  |  |
| Legend:                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                       |                                                                                                                                                       |                                                                                                  |                                                                                                  |                                                                                       |  |  |
| R = Readable                                | bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | W = Writable bit                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                       | U = Unimplemen                                                                                                                                        | ted bit, read as '0'                                                                             |                                                                                                  |                                                                                       |  |  |
| u = Bit is uncha                            | anged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | x = Bit is unknowr                                                                                                                                                                                                                                                                                                                         | n                                                                                                                                                                                                                     | -n/n = Value at P                                                                                                                                     | OR and BOR/Value a                                                                               | t all other Resets                                                                               |                                                                                       |  |  |
| '1' = Bit is set                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | '0' = Bit is cleared                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                       | HS = Bit is set by                                                                                                                                    | hardware                                                                                         | C = User cleared                                                                                 |                                                                                       |  |  |
|                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                       |                                                                                                                                                       |                                                                                                  |                                                                                                  |                                                                                       |  |  |
| bit 7                                       | WCOL: Write Co<br><u>Master mode:</u><br>1 = A write to th<br>0 = No collision<br><u>Slave mode:</u><br>1 = The SSPBL<br>0 = No collision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Ilision Detect bit<br>ne SSPBUF register<br>IF register is written v                                                                                                                                                                                                                                                                       | r was attempted v<br>vhile it is still transr                                                                                                                                                                         | while the I <sup>2</sup> C condit<br>nitting the previous v                                                                                           | ions were not valid fo<br>vord (must be cleared i                                                | r a transmission to<br>in software)                                                              | b be started                                                                          |  |  |
| bit 6                                       | SSPOV: Receive           In SPI mode:           1 =         A new byte           Overflow cas           setting over           SSPBUF re           0 =         No overflow           In I <sup>2</sup> C mode:           1 =         A byte is re           (must be cl           0 =         No overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Overflow Indicator<br>is received while the<br>in only occur in Slave<br>flow. In Master mode<br>gister (must be clear<br>v<br>ecceived while the Si<br>eared in software).<br>v                                                                                                                                                           | bit <sup>(1)</sup><br>· SSPBUF register<br>e mode. In Slave r<br>., the overflow bit is<br>red in software).<br>SPBUF register i                                                                                      | is still holding the p<br>node, the user must<br>s not set since each<br>s still holding the p                                                        | revious data. In case c<br>read the SSPBUF, ev<br>new reception (and tran<br>revious byte. SSPOV | of overflow, the data<br>ren if only transmitti<br>nsmission) is initiate<br>/ is a "don't care" | a in SSPSR is lost.<br>ing data, to avoid<br>ed by writing to the<br>in Transmit mode |  |  |
| bit 5                                       | <ul> <li>SSPEN: Synchronous Serial Port Enable bit</li> <li>In both modes, when enabled, these pins must be properly configured as input or output</li> <li>In <u>SPI mode</u>:</li> <li>1 = Enables serial port and configures SCK, SDO, SDI and SS as the source of the serial port pins<sup>(2)</sup></li> <li>0 = Disables serial port and configures these pins as I/O port pins</li> <li><u>In <sup>2</sup>C mode</u>:</li> <li>1 = Enables the serial port and configures the SDA and SCL pins as the source of the serial port pins<sup>(3)</sup></li> <li>0 = Disables serial port and configures these pins as I/O port pins</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                       |                                                                                                                                                       |                                                                                                  |                                                                                                  |                                                                                       |  |  |
| bit 4                                       | <ul> <li>0 = Disables serial port and configures these pins as I/O port pins</li> <li>CKP: Clock Polarity Select bit <ul> <li>In SPI mode:</li> <li>1 = Idle state for clock is a high level</li> <li>0 = Idle state for clock is a low level</li> <li>In I<sup>2</sup>C Slave mode:</li> <li>SCL release control</li> <li>1 = Enable clock</li> <li>0 = Holds clock low (clock stretch). (Used to ensure data setup time.)</li> <li>In I<sup>2</sup>C Master mode:</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                       |                                                                                                                                                       |                                                                                                  |                                                                                                  |                                                                                       |  |  |
| bit 3-0                                     | $\begin{array}{l} \textbf{SSPM<3:0>:} \ \text{Syr}\\ 0000 = \text{SPI Mast}\\ 0001 = \text{SPI Mast}\\ 0010 = \text{SPI Mast}\\ 0010 = \text{SPI Mast}\\ 0101 = \text{SPI Mast}\\ 0100 = \text{SPI Slave}\\ 0101 = \text{SPI Slave}\\ 0101 = \text{SPI Slave}\\ 0101 = \text{I}^2\text{C Slave}\\ 1000 = \text{I}^2\text{C Mast}\\ 1001 = \text{Reservee}\\ 1001 = \text{Reservee}\\ 1011 = \text{I}^2\text{C firmw}\\ 1000 = \text{Reservee}\\ 1101 = \text{Reservee}\\ 1111 = \text{I}^2\text{C Slave}\\ 1111 = \text$ | achronous Serial Po<br>er mode, clock = Fo<br>er mode, clock = Fo<br>er mode, clock = Fo<br>er mode, clock = Fo<br>er mode, clock = SC<br>e mode, clock = SC<br>e mode, 7-bit addres<br>er mode, 10-bit addres<br>er mode, clock = Fo<br>der mode, clock = Fo<br>for are controlled Mast<br>der mode, 7-bit addres<br>e mode, 7-bit addres | nt Mode Select b<br>DSC/4<br>DSC/16<br>DSC/64<br>WR2 output/2<br>K pin, <u>SS</u> pin cor<br>K pin, <u>SS</u> pin cor<br>SS<br>DSC / (4 * (SSPADI<br>er mode (Slave id<br>SS with Start and :<br>SSS with Start and : | trol enabled<br>trol disabled, <u>SS</u> ci<br>(D+1)) <sup>(4)</sup><br>(D+1)) <sup>(5)</sup><br>dle)<br>Stop bit interrupts e<br>Stop bit interrupts | an be used as I/O pin<br>nabled<br>enabled                                                       |                                                                                                  |                                                                                       |  |  |
| Note 1:  <br>2: \<br>3: \<br>4: \$<br>5: \$ | n Master mode, the own<br>When enabled, these p<br>When enabled, the SDA<br>SSPADD values of 0, 1<br>SSPADD value of '0' is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | erflow bit is not set a<br>ins must be properly<br>and SCL pins must<br>or 2 are not suppor<br>not supported. Use                                                                                                                                                                                                                          | since each new r<br>y configured as ir<br>st be configured a<br>ted for I <sup>2</sup> C mode<br>SSPM = 0000 ir                                                                                                       | eception (and trans<br>iput or output.<br>is inputs.<br>istead.                                                                                       | mission) is initiated b                                                                          | y writing to the SS                                                                              | PBUF register.                                                                        |  |  |

#### 28.4.4 BREAK CHARACTER SEQUENCE

The EUSART module has the capability of sending the special Break character sequences that are required by the LIN bus standard. A Break character consists of a Start bit, followed by 12 '0' bits and a Stop bit.

To send a Break character, set the SENDB and TXEN bits of the TXSTA register. The Break character transmission is then initiated by a write to the TXREG. The value of data written to TXREG will be ignored and all '0's will be transmitted.

The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN specification).

The TRMT bit of the TXSTA register indicates when the transmit operation is active or idle, just as it does during normal transmission. See Figure 28-9 for the timing of the Break character sequence.

#### 28.4.4.1 Break and Sync Transmit Sequence

The following sequence will start a message frame header made up of a Break, followed by an auto-baud Sync byte. This sequence is typical of a LIN bus master.

- 1. Configure the EUSART for the desired mode.
- 2. Set the TXEN and SENDB bits to enable the Break sequence.
- 3. Load the TXREG with a dummy character to initiate transmission (the value is ignored).
- 4. Write '55h' to TXREG to load the Sync character into the transmit FIFO buffer.
- 5. After the Break has been sent, the SENDB bit is reset by hardware and the Sync character is then transmitted.

When the TXREG becomes empty, as indicated by the TXIF, the next data byte can be written to TXREG.

#### Write to TXREG Dummy Write **BRG** Output (Shift Clock) TX (pin) Start bit bit 0 bit 1 Stop bit Break TXIF bit (Transmit Interrupt Flag) TRMT bit (Transmit Shift Empty Flag) SENDB Sampled Here Auto Cleared SENDB (send Break control bit)

### FIGURE 28-9: SEND BREAK CHARACTER SEQUENCE

### 28.4.5 RECEIVING A BREAK CHARACTER

The Enhanced EUSART module can receive a Break character in two ways.

The first method to detect a Break character uses the FERR bit of the RCSTA register and the received data as indicated by RCREG. The Baud Rate Generator is assumed to have been initialized to the expected baud rate.

A Break character has been received when;

- RCIF bit is set
- FERR bit is set
- RCREG = 00h

The second method uses the Auto-Wake-up feature described in **Section 28.4.3** "**Auto-Wake-up on Break**". By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCIF interrupt, and receive the next data byte followed by another interrupt.

Note that following a Break character, the user will typically want to enable the Auto-Baud Detect feature. For both methods, the user can set the ABDEN bit of the BAUDCON register before placing the EUSART in Sleep mode.





#### FIGURE 29-3: TYPICAL CONNECTION FOR ICSP™ PROGRAMMING



### **30.0 INSTRUCTION SET SUMMARY**

Each instruction is a 14-bit word containing the operation code (opcode) and all required operands. The opcodes are broken into three broad categories.

- · Byte Oriented
- · Bit Oriented
- Literal and Control

The literal and control category contains the most varied instruction word format.

Table 30-3 lists the instructions recognized by the MPASM  $^{\rm TM}$  assembler.

All instructions are executed within a single instruction cycle, with the following exceptions, which may take two or three cycles:

- Subroutine takes two cycles (CALL, CALLW)
- Returns from interrupts or subroutines take two cycles (RETURN, RETLW, RETFIE)
- Program branching takes two cycles (GOTO, BRA, BRW, BTFSS, BTFSC, DECFSZ, INCSFZ)

#### TABLE 30-1: OPCODE FIELD DESCRIPTIONS

| Field | Description                                                                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f     | Register file address (0x00 to 0x7F)                                                                                                                                            |
| W     | Working register (accumulator)                                                                                                                                                  |
| b     | Bit address within an 8-bit file register                                                                                                                                       |
| k     | Literal field, constant data or label                                                                                                                                           |
| x     | Don't care location (= 0 or 1).<br>The assembler will generate code with $x = 0$ .<br>It is the recommended form of use for<br>compatibility with all Microchip software tools. |
| d     | Destination select; d = 0: store result in W,<br>d = 1: store result in file register f.<br>Default is d = 1.                                                                   |
| n     | FSR or INDF number. (0-1)                                                                                                                                                       |
| mm    | Pre-post increment-decrement mode selection                                                                                                                                     |

| TABLE 30-2: ABBREVIATION DE | SCRIPTIONS |
|-----------------------------|------------|
|-----------------------------|------------|

| Field | Description     |  |  |  |  |  |  |
|-------|-----------------|--|--|--|--|--|--|
| PC    | Program Counter |  |  |  |  |  |  |
| TO    | Time-Out bit    |  |  |  |  |  |  |
| С     | Carry bit       |  |  |  |  |  |  |
| DC    | Digit Carry bit |  |  |  |  |  |  |
| Z     | Zero bit        |  |  |  |  |  |  |
| PD    | Power-Down bit  |  |  |  |  |  |  |

 One additional instruction cycle will be used when any instruction references an indirect file register and the file select register is pointing to program memory.

One instruction cycle consists of 4 oscillator cycles; for an oscillator frequency of 4 MHz, this gives a nominal instruction execution rate of 1 MHz.

All instruction examples use the format '0xhh' to represent a hexadecimal number, where 'h' signifies a hexadecimal digit.

#### 30.1 Read-Modify-Write Operations

Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (R-M-W) operation. The register is read, the data is modified, and the result is stored according to either the instruction, or the destination designator 'd'. A read operation is performed on a register even if the instruction writes to that register.

|               |               |                               |         |       | 11_Bi+ ( | Jacode |      |                    |       |
|---------------|---------------|-------------------------------|---------|-------|----------|--------|------|--------------------|-------|
| Mnem<br>Opera | onic,<br>Inds | Description                   | Cycles  |       |          | Jhrone | , 01 | Status<br>Affected | Notes |
| • • • • •     |               |                               |         | INISD |          |        | LSD  |                    |       |
|               |               | BYTE-ORIENTED FILE RE         | GISTER  | OPERA | TIONS    |        |      |                    |       |
| ADDWF         | f, d          | Add W and £                   | 1       | 00    | 0111     | dfff   | ffff | C, DC, Z           | 2     |
| ADDWFC        | f, d          | Add with Carry W and £        | 1       | 11    | 1101     | dfff   | ffff | C, DC, Z           | 2     |
| ANDWF         | f, d          | AND W with £                  | 1       | 00    | 0101     | dfff   | ffff | Z                  | 2     |
| ASRF          | f, d          | Arithmetic Right Shift        | 1       | 11    | 0111     | dfff   | ffff | C, Z               | 2     |
| LSLF          | f, d          | Logical Left Shift            | 1       | 11    | 0101     | dfff   | ffff | C, Z               | 2     |
| LSRF          | f, d          | Logical Right Shift           | 1       | 11    | 0110     | dfff   | ffff | C, Z               | 2     |
| CLRF          | f             | Clear f                       | 1       | 00    | 0001     | lfff   | ffff | Z                  | 2     |
| CLRW          | _             | Clear W                       | 1       | 00    | 0001     | 0000   | 00xx | Z                  |       |
| COMF          | f, d          | Complement f                  | 1       | 00    | 1001     | dfff   | ffff | Z                  | 2     |
| DECF          | f, d          | Decrement f                   | 1       | 00    | 0011     | dfff   | ffff | Z                  | 2     |
| INCF          | f, d          | Increment f                   | 1       | 00    | 1010     | dfff   | ffff | Z                  | 2     |
| IORWF         | f, d          | Inclusive OR W with f         | 1       | 00    | 0100     | dfff   | ffff | Z                  | 2     |
| MOVF          | f, d          | Move f                        | 1       | 00    | 1000     | dfff   | ffff | Z                  | 2     |
| MOVWF         | f             | Move W to f                   | 1       | 00    | 0000     | 1fff   | ffff |                    | 2     |
| RLF           | f. d          | Rotate Left f through Carry   | 1       | 00    | 1101     | dfff   | ffff | С                  | 2     |
| RRF           | f. d          | Rotate Right f through Carry  | 1       | 00    | 1100     | dfff   | ffff | С                  | 2     |
| SUBWF         | f. d          | Subtract W from £             | 1       | 00    | 0010     | dfff   | ffff | C. DC. Z           | 2     |
| SUBWFB        | f. d          | Subtract with Borrow W from f | 1       | 11    | 1011     | dfff   | ffff | C. DC. Z           | 2     |
| SWAPF         | f. d          | Swap nibbles in f             | 1       | 0.0   | 1110     | dfff   | ffff | 0, 20, 2           | 2     |
| XORWE         | f, d          | Exclusive OR W with f         | 1       | 00    | 0110     | dfff   | ffff | 7                  | 2     |
| _             | , -           | BYTE ORIENTED SK              |         | ΔΤΙΟΝ | S        | -      |      |                    |       |
|               | fd            | Deprement & Skip if 0         | 1(2)    | 0.0   | 1011     | 2555   |      |                    | 1 2   |
| DECESZ        | f d           | Incroment f. Skip if 0        | 1(2)    | 00    | 1011     | dill   | LLLL |                    | 1, 2  |
| INCFSZ        | 1, U          |                               | 1(2)    | 00    |          | alli   | LLLL |                    | 1, 2  |
|               |               | BIT-ORIENTED FILE REG         | ISTER O | PERAT | IONS     |        |      |                    |       |
| BCF           | f, b          | Bit Clear £                   | 1       | 01    | 00bb     | bfff   | ffff |                    | 2     |
| BSF           | f, b          | Bit Set £                     | 1       | 01    | 01bb     | bfff   | ffff |                    | 2     |
|               |               | BIT-ORIENTED SKI              | P OPERA | TIONS |          |        |      |                    | •     |
| BTFSC         | f, b          | Bit Test £, Skip if Clear     | 1 (2)   | 01    | 10bb     | bfff   | ffff |                    | 1, 2  |
| BTFSS         | f, b          | Bit Test £, Skip if Set       | 1 (2)   | 01    | 11bb     | bfff   | ffff |                    | 1, 2  |
|               |               | LITERAL OPE                   | RATIONS | 3     |          |        |      |                    |       |
| ADDLW         | k             | Add literal and W             | 1       | 11    | 1110     | kkkk   | kkkk | C, DC, Z           |       |
| ANDLW         | k             | AND literal with W            | 1       | 11    | 1001     | kkkk   | kkkk | Z                  |       |
| IORLW         | k             | Inclusive OR literal with W   | 1       | 11    | 1000     | kkkk   | kkkk | Z                  |       |
| MOVLB         | k             | Move literal to BSR           | 1       | 00    | 0000     | 001k   | kkkk |                    |       |
| MOVLP         | k             | Move literal to PCLATH        | 1       | 11    | 0001     | 1kkk   | kkkk |                    |       |
| MOVLW         | k             | Move literal to W             | 1       | 11    | 0000     | kkkk   | kkkk |                    |       |
| SUBLW         | k             | Subtract W from literal       | 1       | 11    | 1100     | kkkk   | kkkk | C, DC, Z           |       |
| XORLW         | k             | Exclusive OR literal with W   | 1       | 11    | 1010     | kkkk   | kkkk | Z                  |       |

#### TABLE 30-3: ENHANCED MID-RANGE INSTRUCTION SET

**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.









#### **TABLE 31-7: OSCILLATOR PARAMETERS**

| Stanual      | Standard Operating Conditions (unless otherwise stated) |                                                                                              |                    |      |                      |         |                   |                                                                                                                                                     |  |  |  |  |
|--------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------|------|----------------------|---------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Param<br>No. | Sym.                                                    | Characteristic                                                                               | Freq.<br>Tolerance | Min. | Тур†                 | Max.    | Units             | Conditions                                                                                                                                          |  |  |  |  |
| OS08         | HFosc                                                   | Internal Calibrated HFINTOSC<br>Frequency <sup>(2)</sup>                                     | ±2%<br>±3%<br>±5%  |      | 16.0<br>16.0<br>16.0 |         | MHz<br>MHz<br>MHz | $0^{\circ}C \le TA \le +60^{\circ}C, VDD \ge 2.5V$<br>$60^{\circ}C \le TA \le 85^{\circ}C, VDD \ge 2.5V$<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ |  |  |  |  |
| OS08A        | MFosc                                                   | Internal Calibrated MFINTOSC<br>Frequency <sup>(2)</sup>                                     | ±2%<br>±3%<br>+5%  |      | 500<br>500<br>500    |         | kHz<br>kHz<br>kHz | $0^{\circ}C \le TA \le +60^{\circ}C, VDD \ge 2.5V$<br>$60^{\circ}C \le TA \le 85^{\circ}C, VDD \ge 2.5V$<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ |  |  |  |  |
| OS09         | LFosc                                                   | Internal LFINTOSC Frequency                                                                  |                    | _    | 31                   | _       | kHz               | $-40^{\circ}C \le TA \le +125^{\circ}C$                                                                                                             |  |  |  |  |
| OS10*        | Twarm                                                   | HFINTOSC<br>Wake-up from Sleep Start-up Time<br>MFINTOSC<br>Wake-up from Sleep Start-up Time |                    | _    | 3.2<br>24            | 8<br>35 | μs<br>μs          | VREGPM = 0<br>VREGPM = 0                                                                                                                            |  |  |  |  |
| *            | These                                                   | eveneters are characterized but not                                                          | a a ta al          |      |                      |         |                   |                                                                                                                                                     |  |  |  |  |

Standard Operating Conditions (unless otherwise stated)

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: Instruction cycle period (TCY) equals four times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min" values with an external clock applied to the OSC1 pin. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices.

2: To ensure these oscillator frequency tolerances, VDD and Vss must be capacitively decoupled as close to the device as possible. 0.1  $\mu$ F and 0.01  $\mu$ F values in parallel are recommended.

3: By design.

#### **FIGURE 31-6:** HFINTOSC FREQUENCY ACCURACY OVER DEVICE VDD AND TEMPERATURE



\*

#### TABLE 31-17: 5-BIT DIGITAL-TO-ANALOG CONVERTER (DAC) SPECIFICATIONS

| Operating Conditions: | $\sqrt{DD} = 3\sqrt{2}$ | Temperature = 25°C                    | (unloss | otherwise stated)   |
|-----------------------|-------------------------|---------------------------------------|---------|---------------------|
| Operating Conditions. | VUU - 3V.               | 1000000000000000000000000000000000000 | luniess | ollielwise stateu). |

| Param<br>No. | Sym.  | Characteristics              | Min. | Тур.   | Max.  | Units | Comments |
|--------------|-------|------------------------------|------|--------|-------|-------|----------|
| DAC01*       | CLSB5 | Step Size                    | _    | VDD/32 | _     | V     |          |
| DAC02*       | CACC5 | Absolute Accuracy            | _    | _      | ± 1/2 | LSb   |          |
| DAC03*       | CR5   | Unit Resistor Value (R)      | _    | 5K     | -     | Ω     |          |
| DAC04*       | CST5  | Settling Time <sup>(2)</sup> | _    | _      | 10    | μS    |          |

These parameters are characterized but not tested.

Note 1: See Section 32.0 "DC and AC Characteristics Graphs and Charts" for operating characterization.

2: Settling time measured while DACR<7:0> transitions from '00000' to '01111'.

#### TABLE 31-18: 8-BIT DIGITAL-TO-ANALOG CONVERTER (DAC) SPECIFICATIONS

| <b>Operating Conditions:</b> VDD = 3V, Temperature = 25°C (unless otherwise stated). |       |                              |      |         |       |       |          |
|--------------------------------------------------------------------------------------|-------|------------------------------|------|---------|-------|-------|----------|
| Param<br>No.                                                                         | Sym.  | Characteristics              | Min. | Тур.    | Max.  | Units | Comments |
| DAC05*                                                                               | CLSB8 | Step Size                    | _    | VDD/256 |       | V     |          |
| DAC06*                                                                               | CACC8 | Absolute Accuracy            | —    | —       | ± 1.5 | LSb   |          |
| DAC07*                                                                               | CR8   | Unit Resistor Value (R)      | —    | 600     | _     | Ω     |          |
| DAC08*                                                                               | CST8  | Settling Time <sup>(1)</sup> | —    | —       | 10    | μS    |          |
| * These peremeters are observatorized but not tested                                 |       |                              |      |         |       |       |          |

These parameters are characterized but not tested.

Note 1: Settling time measured while DACR<7:0> transitions from ' $0 \times 00$ ' to ' $0 \times FF$ '.

#### FIGURE 31-14: EUSART SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING



#### TABLE 31-19: EUSART SYNCHRONOUS TRANSMISSION REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |                |                                                              |          |    |      |       |            |  |
|---------------------------------------------------------|----------------|--------------------------------------------------------------|----------|----|------|-------|------------|--|
| Param.<br>No.                                           | Symbol         | Characteristic                                               |          |    | Max. | Units | Conditions |  |
| US120                                                   | US120 TCKH2DTV | SYNC XMIT (Master and Slave)<br>Clock high to data-out valid | 3.0-5.5V | —  | 80   | ns    |            |  |
|                                                         |                |                                                              | 1.8-5.5V | _  | 100  | ns    |            |  |
| US121                                                   | US121 TCKRF    | Clock out rise time and fall time                            | 3.0-5.5V |    | 45   | ns    |            |  |
|                                                         | (Master mode)  | 1.8-5.5V                                                     | _        | 50 | ns   |       |            |  |
| US122                                                   | US122 TDTRF    | Data-out rise time and fall time                             | 3.0-5.5V | _  | 45   | ns    |            |  |
|                                                         |                | 1.8-5.5V                                                     |          | 50 | ns   |       |            |  |

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





100 Max: Typical + 3σ (-40°C to +125°C) Typical; statistical mean @ 25°C Min: Typical - 3σ (-40°C to +125°C) 90 Max 80 Time (mS) Typical 70 Min. 60 50 40 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 2.0 VDD (V)

FIGURE 32-69: PWRT Period, PIC16F1788/9 Only.



FIGURE 32-70: PWRT Period, PIC16LF1788/9 Only.



FIGURE 32-72: POR Rearm Voltage, NP Mode (VREGPM = 0), PIC16F1788/9 Only.





140