



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

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

Email: info@E-XFL.COM

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

| TABLE 1-5: | PIC18F4XK80 PINOUT I/O DESCRIPTIONS (CONTINUED) |
|------------|-------------------------------------------------|
|------------|-------------------------------------------------|

|                                                                                | Pin N | umber        | Pin         | Buffer        |                                                                                 |
|--------------------------------------------------------------------------------|-------|--------------|-------------|---------------|---------------------------------------------------------------------------------|
| Pin Name                                                                       | PDIP  | QFN/<br>TQFP | Ріп<br>Туре | Витег<br>Туре | Description                                                                     |
|                                                                                |       |              |             |               | PORTB is a bidirectional I/O port.                                              |
| RB0/AN10/FLT0/INT0                                                             | 33    | 8            |             |               |                                                                                 |
| RB0                                                                            |       |              | I/O         | ST/           | Digital I/O.                                                                    |
|                                                                                |       |              |             | CMOS          |                                                                                 |
| AN10                                                                           |       |              | I           | Analog        | Analog Input 10.                                                                |
| FLT0                                                                           |       |              | I           | ST            | Enhanced PWM Fault input for ECCP1.                                             |
| INT0                                                                           |       |              |             | ST            | External Interrupt 0.                                                           |
| RB1/AN8/CTDIN/INT1                                                             | 34    | 9            |             |               |                                                                                 |
| RB1                                                                            |       |              | I/O         | ST/<br>CMOS   | Digital I/O.                                                                    |
| AN8                                                                            |       |              | I           | Analog        | Analog Input 8.                                                                 |
| CTDIN                                                                          |       |              | I           | ST            | CTMU pulse delay input.                                                         |
| INT1                                                                           |       |              | I           | ST            | External Interrupt 1.                                                           |
| RB2/CANTX/CTED1/<br>INT2                                                       | 35    | 10           |             |               |                                                                                 |
| RB2                                                                            |       |              | I/O         | ST/<br>CMOS   | Digital I/O.                                                                    |
| CANTX                                                                          |       |              | 0           | CMOS          | CAN bus TX.                                                                     |
| CTED1                                                                          |       |              | I           | ST            | CTMU Edge 1 input.                                                              |
| INT2                                                                           |       |              | I           | ST            | External Interrupt 2.                                                           |
| RB3/CANRX/CTED2/<br>INT3                                                       | 36    | 11           |             |               |                                                                                 |
| RB3                                                                            |       |              | I/O         | ST/<br>CMOS   | Digital I/O.                                                                    |
| CANRX                                                                          |       |              | I           | ST            | CAN bus RX.                                                                     |
| CTED2                                                                          |       |              | I           | ST            | CTMU Edge 2 input.                                                              |
| INT3                                                                           |       |              | I           | ST            | External Interrupt 3.                                                           |
| RB4/AN9/CTPLS/KBI0                                                             | 37    | 14           |             |               |                                                                                 |
| RB4                                                                            |       |              | I/O         | ST/<br>CMOS   | Digital I/O.                                                                    |
| AN9                                                                            |       |              | I           | Analog        | Analog Input 9.                                                                 |
| CTPLS                                                                          |       |              | 0           | ST            | CTMU pulse generator output.                                                    |
| KBI0                                                                           |       |              | I           | ST            | Interrupt-on-change pin.                                                        |
| RB5/T0CKI/T3CKI/CCP5/<br>KBI1                                                  | 38    | 15           |             |               |                                                                                 |
| RB5                                                                            |       |              | I/O         | ST/<br>CMOS   | Digital I/O.                                                                    |
| TOCKI                                                                          |       |              | I           | ST            | Timer0 external clock input.                                                    |
| ТЗСКІ                                                                          |       |              | I           | ST            | Timer3 external clock input.                                                    |
| CCP5                                                                           |       |              | I/O         | ST            | Capture 5 input/Compare 5 output/PWM5 output.                                   |
| KBI1                                                                           |       |              | I           | ST            | Interrupt-on-change pin.                                                        |
| <b>Legend:</b> $I^2C^{TM} = I^2C/SM$<br>ST = Schmitt<br>I = Input<br>P = Power |       |              |             | 1OS level     | CMOS = CMOS compatible input or output<br>s Analog = Analog input<br>O = Output |

| Pin Name                                                                                  | Pin<br>Num | Pin<br>Type | Buffer<br>Type | Description                                   |
|-------------------------------------------------------------------------------------------|------------|-------------|----------------|-----------------------------------------------|
|                                                                                           |            |             |                | PORTB is a bidirectional I/O port.            |
| RB0/AN10/FLT0/INT0                                                                        | 13         |             |                |                                               |
| RB0                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| AN10                                                                                      |            | Ι           | Analog         | Analog Input 10.                              |
| FLT0                                                                                      |            | Ι           | ST             | Enhanced PWM Fault input for ECCP1.           |
| INT0                                                                                      |            | Ι           | ST             | External Interrupt 0.                         |
| RB1/AN8/CTDIN/INT1                                                                        | 14         |             |                |                                               |
| RB1                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| AN8                                                                                       |            | Ι           | Analog         | Analog Input 8.                               |
| CTDIN                                                                                     |            | Ι           | ST             | CTMU pulse delay input.                       |
| INT1                                                                                      |            | Ι           | ST             | External Interrupt 1.                         |
| RB2/CANTX/CTED1/<br>INT2                                                                  | 15         |             |                |                                               |
| RB2                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| CANTX                                                                                     |            | 0           | CMOS           | CAN bus TX.                                   |
| CTED1                                                                                     |            | Ι           | ST             | CTMU Edge 1 input.                            |
| INT2                                                                                      |            | Ι           | ST             | External Interrupt 2.                         |
| RB3/CANRX/CTED2/<br>INT3                                                                  | 16         |             |                |                                               |
| RB3                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| CANRX                                                                                     |            | Ι           | ST             | CAN bus RX.                                   |
| CTED2                                                                                     |            | Ι           | ST             | CTMU Edge 2 input.                            |
| INT3                                                                                      |            | Ι           | ST             | External Interrupt 3.                         |
| RB4/AN9/CTPLS/KBI0                                                                        | 20         |             |                |                                               |
| RB4                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| AN9                                                                                       |            | Ι           | Analog         | Analog Input 9.                               |
| CTPLS                                                                                     |            | 0           | ST             | CTMU pulse generator output.                  |
| KBI0                                                                                      |            | Ι           | ST             | Interrupt-on-change pin.                      |
| RB5/T0CKI/T3CKI/CCP5/<br>KBI1                                                             | 21         |             |                |                                               |
| RB5                                                                                       |            | I/O         | ST/<br>CMOS    | Digital I/O.                                  |
| TOCKI                                                                                     |            | I           | ST             | Timer0 external clock input.                  |
| ТЗСКІ                                                                                     |            | I           | ST             | Timer3 external clock input.                  |
| CCP5                                                                                      |            | I/O         | ST/<br>CMOS    | Capture 5 input/Compare 5 output/PWM5 output. |
| KBI1                                                                                      |            | I           | ST             | Interrupt-on-change pin.                      |
| Legend: I <sup>2</sup> C™ = I <sup>2</sup> C/SI<br>ST = Schmitt<br>I = Input<br>P = Power |            |             | er             | CMOS = CMOS compatible input or output        |

| TABLE 1-6: | PIC18F6XK80 PINOUT I/O DESCRIPTIONS (CONTINUED) |
|------------|-------------------------------------------------|
|------------|-------------------------------------------------|

## 4.0 POWER-MANAGED MODES

The PIC18F66K80 family of devices offers a total of seven operating modes for more efficient power management. These modes provide a variety of options for selective power conservation in applications where resources may be limited (such as battery-powered devices).

There are three categories of power-managed mode:

- Run modes
- Idle modes
- · Sleep mode

There is an Ultra Low-Power Wake-up (ULPWU) for waking from Sleep mode.

These categories define which portions of the device are clocked, and sometimes, at what speed. The Run and Idle modes may use any of the three available clock sources (primary, secondary or internal oscillator block). The Sleep mode does not use a clock source.

The ULPWU mode, on the RA0 pin, enables a slow falling voltage to generate a wake-up, even from Sleep, without excess current consumption. (See **Section 4.7 "Ultra Low-Power Wake-up"**.)

The power-managed modes include several powersaving features offered on previous PIC<sup>®</sup> devices. One is the clock switching feature, offered in other PIC18 devices. This feature allows the controller to use the SOSC oscillator instead of the primary one. Another power-saving feature is Sleep mode, offered by all PIC devices, where all device clocks are stopped.

### 4.1 Selecting Power-Managed Modes

Selecting a power-managed mode requires two decisions:

- · Will the CPU be clocked or not
- What will be the clock source

The IDLEN bit (OSCCON<7>) controls CPU clocking, while the SCS<1:0> bits (OSCCON<1:0>) select the clock source. The individual modes, bit settings, clock sources and affected modules are summarized in Table 4-1.

#### 4.1.1 CLOCK SOURCES

The SCS<1:0> bits select one of three clock sources for power-managed modes. Those sources are:

- The primary clock as defined by the FOSC<3:0> Configuration bits
- The Secondary Clock (the SOSC oscillator)
- The Internal Oscillator block (for LF-INTOSC modes)

#### 4.1.2 ENTERING POWER-MANAGED MODES

Switching from one power-managed mode to another begins by loading the OSCCON register. The SCS<1:0> bits select the clock source and determine which Run or Idle mode is used. Changing these bits causes an immediate switch to the new clock source, assuming that it is running. The switch may also be subject to clock transition delays. These considerations are discussed in **Section 4.1.3 "Clock Transitions and Status Indicators"** and subsequent sections.

Entering the power-managed Idle or Sleep modes is triggered by the execution of a SLEEP instruction. The actual mode that results depends on the status of the IDLEN bit.

Depending on the current and impending mode, a change to a power-managed mode does not always require setting all of the previously discussed bits. Many transitions can be done by changing the oscillator select bits, or changing the IDLEN bit, prior to issuing a SLEEP instruction. If the IDLEN bit is already configured as desired, it may only be necessary to perform a SLEEP instruction to switch to the desired mode.

| Mada     | oscco                   | ON Bits                       | Module  | Clocking                                |                                          |  |  |
|----------|-------------------------|-------------------------------|---------|-----------------------------------------|------------------------------------------|--|--|
| Mode     | IDLEN<7> <sup>(1)</sup> | EN<7> <sup>(1)</sup> SCS<1:0> |         | Peripherals                             | Available Clock and Oscillator Source    |  |  |
| Sleep    | 0                       | N/A                           | Off     | Off                                     | None – All clocks are disabled           |  |  |
| PRI_RUN  | N/A                     | 00                            | Clocked | This is the normal, full-power executio |                                          |  |  |
| SEC_RUN  | N/A                     | 01                            | Clocked | Clocked                                 | Secondary – SOSC Oscillator              |  |  |
| RC_RUN   | N/A                     | 1x                            | Clocked | Clocked                                 | Internal oscillator block <sup>(2)</sup> |  |  |
| PRI_IDLE | 1                       | 00                            | Off     | Clocked                                 | Primary – LP, XT, HS, RC, EC             |  |  |
| SEC_IDLE | 1                       | 01                            | Off     | Clocked                                 | Secondary – SOSC oscillator              |  |  |
| RC_IDLE  | 1                       | 1x                            | Off     | Clocked                                 | Internal oscillator block <sup>(2)</sup> |  |  |

#### TABLE 4-1: POWER-MANAGED MODES

**Note 1:** IDLEN reflects its value when the **SLEEP** instruction is executed.

2: Includes INTOSC (HF-INTOSC and MG-INTOSC) and INTOSC postscaler, as well as the LF-INTOSC source.

### TABLE 6-2: PIC18F66K80 FAMILY REGISTER FILE SUMMARY (CONTINUED)

| Addr. | File Name      | Bit 7       | Bit 6       | Bit 5            | Bit 4   | Bit 3    | Bit 2    | Bit 1    | Bit 0    | Value on<br>POR, BOR<br>on page |
|-------|----------------|-------------|-------------|------------------|---------|----------|----------|----------|----------|---------------------------------|
| F6Dh  | RXB0D7         | RXB0D77     | RXB0D76     | RXB0D75          | RXB0D74 | RXB0D73  | RXB0D72  | RXB0D71  | RXB0D70  | 91                              |
| F6Ch  | RXB0D6         | RXB0D67     | RXB0D66     | RXB0D65          | RXB0D64 | RXB0D63  | RXB0D62  | RXB0D61  | RXB0D60  | 91                              |
| F6Bh  | RXB0D5         | RXB0D57     | RXB0D56     | RXB0D55          | RXB0D54 | RXB0D53  | RXB0D52  | RXB0D51  | RXB0D50  | 91                              |
| F6Ah  | RXB0D4         | RXB0D47     | RXB0D46     | RXB0D45          | RXB0D44 | RXB0D43  | RXB0D42  | RXB0D41  | RXB0D40  | 91                              |
| F69h  | RXB0D3         | RXB0D37     | RXB0D36     | RXB0D35          | RXB0D34 | RXB0D33  | RXB0D32  | RXB0D31  | RXB0D30  | 91                              |
| F68h  | RXB0D2         | RXB0D27     | RXB0D26     | RXB0D25          | RXB0D24 | RXB0D23  | RXB0D22  | RXB0D21  | RXB0D20  | 91                              |
| F67h  | RXB0D1         | RXB0D17     | RXB0D16     | RXB0D15          | RXB0D14 | RXB0D13  | RXB0D12  | RXB0D11  | RXB0D10  | 91                              |
| F66h  | RXB0D0         | RXB0D07     | RXB0D06     | RXB0D05          | RXB0D04 | RXB0D03  | RXB0D02  | RXB0D01  | RXB0D00  | 91                              |
| F65h  | RXB0DLC        | _           | RXRTR       | RB1              | RB0     | DLC3     | DLC2     | DLC1     | DLC0     | 91                              |
| F64h  | RXB0EIDL       | EID7        | EID6        | EID5             | EID4    | EID3     | EID2     | EID1     | EID0     | 91                              |
| F63h  | RXB0EIDH       | EID15       | EID14       | EID13            | EID12   | EID11    | EID10    | EID9     | EID8     | 91                              |
| F62h  | RXB0SIDL       | SID2        | SID1        | SID0             | SRR     | EXID     | _        | EID17    | EID16    | 91                              |
| F61h  | RXB0SIDH       | SID10       | SID9        | SID8             | SID7    | SID6     | SID5     | SID4     | SID3     | 91                              |
| F60h  | RXB0CON        | RXFUL       | RXM1        | RXM0             | _       | RXRTRRO  | RXB0DBEN | JTOFF    | FILHIT0  | 91                              |
| F60h  | RXB0CON        | RXFUL       | RXM1        | RTRRO            | FILHIT4 | FILHIT3  | FILHIT2  | FILHIT1  | FILHIT0  | 91                              |
| F5Fh  | CM1CON         | CON         | COE         | CPOL             | EVPOL1  | EVPOL0   | CREF     | CCH1     | CCH0     | 91                              |
| F5Eh  | CM2CON         | CON         | COE         | CPOL             | EVPOL1  | EVPOL0   | CREF     | CCH1     | CCH0     | 91                              |
| F5Dh  | ANCON0         | ANSEL7      | ANSEL6      | ANSEL5           | ANSEL4  | ANSEL3   | ANSEL2   | ANSEL1   | ANSEL0   | 91                              |
| F5Ch  | ANCON1         | _           | ANSEL14     | ANSEL13          | ANSEL12 | ANSEL11  | ANSEL10  | ANSEL9   | ANSEL8   | 91                              |
| F5Bh  | WPUB           | WPUB7       | WPUB6       | WPUB5            | WPUB4   | WPUB3    | WPUB2    | WPUB1    | WPUB0    | 91                              |
| F5Ah  | IOCB           | IOCB7       | IOCB6       | IOCB5            | IOCB4   | _        | _        | _        | _        | 91                              |
| F59h  | PMD0           | CCP5MD      | CCP4MD      | CCP3MD           | CCP2MD  | CCP1MD   | UART2MD  | UART1MD  | SSPMD    | 91                              |
| F58h  | PMD1           | PSPMD       | CTMUMD      | ADCMD            | TMR4MD  | TMR3MD   | TMR2MD   | TMR1MD   | TMR0MD   | 93                              |
| F57h  | PMD2           | _           | _           | _                | _       | MODMD    | ECANMD   | CMP2MD   | CMP1MD   | 93                              |
| F56h  | PADCFG1        | RDPU        | REPU        | RFPU             | RGPU    | _        | _        | _        | CTMUDS   | 93                              |
| F55h  | CTMUCONH       | CTMUEN      | _           | CTMUSIDL         | TGEN    | EDGEN    | EDGSEQEN | IDISSEN  | CTTRIG   | 93                              |
| F54h  | CTMUCONL       | EDG2POL     | EDG2SEL1    | EDG2SEL0         | EDG1POL | EDG1SEL1 | EDG1SEL0 | EDG2STAT | EDG1STAT | 93                              |
| F53h  | CTMUICON       | ITRIM5      | ITRIM4      | ITRIM3           | ITRIM2  | ITRIM1   | ITRIM0   | IRNG1    | IRNG0    | 93                              |
| F52h  | CCPR2H         |             |             | egister 2 High E |         |          |          |          |          | 93                              |
| F51h  | CCPR2L         |             |             | gister 2 Low B   | -       |          |          |          |          | 93                              |
| F50h  | CCP2CON        | _           | _           | DC2B1            | DC2B0   | CCP2M3   | CCP2M2   | CCP2M1   | CCP2M0   | 93                              |
| F4Fh  | CCPR3H         | Capture/Com | pare/PWM Re | egister 3 High E |         |          |          |          |          | 93                              |
| F4Eh  | CCPR3L         |             |             | gister 3 Low B   |         |          |          |          |          | 93                              |
| F4Dh  | CCP3CON        | _           | _           | DC3B1            | D32B0   | CCP3M3   | CCP3M2   | CCP3M1   | CCP3M0   | 93                              |
| F4Ch  | CCPR4H         | Capture/Com | pare/PWM Re | gister 4 High E  |         |          |          |          |          | 93                              |
| F4Bh  | CCPR4L         |             |             | gister 4 Low B   |         |          |          |          |          | 93                              |
| F4Ah  | CCP4CON        |             | _           | DC4B1            | DC4B0   | CCP4M3   | CCP4M2   | CCP4M1   | CCP4M0   | 93                              |
| F49H  | CCPR5H         | Capture/Com | pare/PWM Re | aister 5 High E  |         |          |          |          |          | 93                              |
| F48h  | CCPR5L         |             |             | gister 5 Low B   | ,       |          |          |          |          | 93                              |
| F47h  | CCP5CON        | _           | _           | DC5B1            | DC5B0   | CCP5M3   | CCP5M2   | CCP5M1   | CCP5M0   | 93                              |
| F46h  | PSPCON         | IBF         | OBF         | IBOV             | PSPMODE | _        | _        | _        | _        | 93                              |
| F45h  | MDCON          | MDEN        | MDOE        | MDSLR            | MDOPOL  | MDO      | _        |          | MDBIT    | 93                              |
| F44h  | MDSRC          | MDSODIS     | _           |                  | -       | MDSRC3   | MDSRC2   | MDSRC1   | MDSRC0   | 93                              |
| F43h  | MDCARH         | MDCHODIS    | MDCHPOL     | MDCHSYNC         |         | MDCH3    | MDCH2    | MDCH1    | MDCH0    | 93                              |
| F42h  | MDCARL         | MDCLODIS    | MDCLPOL     | MDCLSYNC         |         | MDCL3    | MDCL2    | MDCL1    | MDCL0    | 93                              |
| F41h  | Unimplemented  |             |             |                  |         |          |          |          |          | -                               |
| F40h  | Unimplemented  |             |             |                  |         |          |          |          |          | _                               |
| F3Fh  | CANCON_RO0     | CANCON_R    | 20          |                  |         |          |          |          |          | 93                              |
| F3Eh  | CANSTAT_RO0    | CANSTAT_R   |             |                  |         |          |          |          |          | 93                              |
|       | 0, 10, 171 100 |             |             |                  |         |          |          | -        | 1        |                                 |
| F3Dh  | RXB1D7         | RXB1D77     | RXB1D76     | RXB1D75          | RXB1D74 | RXB1D73  | RXB1D72  | RXB1D71  | RXB1D70  | 93                              |

### TABLE 6-2: PIC18F66K80 FAMILY REGISTER FILE SUMMARY (CONTINUED)

| Addr.         | E 6-2: P             | Bit 7              | Bit 6         | Bit 5   | Bit 4         | Bit 3         | Bit 2              | Bit 1              | Bit 0         | Value on<br>POR, BOR<br>on page |
|---------------|----------------------|--------------------|---------------|---------|---------------|---------------|--------------------|--------------------|---------------|---------------------------------|
| F09h          | TXB2D3               | TXB2D37            | TXB2D36       | TXB2D35 | TXB2D34       | TXB2D33       | TXB2D32            | TXB2D31            | TXB2D30       | 95                              |
| F08h          | TXB2D2               | TXB2D27            | TXB2D26       | TXB2D25 | TXB2D24       | TXB2D23       | TXB2D22            | TXB2D21            | TXB2D20       | 95                              |
| F07h          | TXB2D2               | TXB2D27            | TXB2D20       | TXB2D25 | TXB2D24       | TXB2D23       | TXB2D22<br>TXB2D12 | TXB2D21<br>TXB2D11 | TXB2D10       | 95                              |
| F06h          | TXB2D1<br>TXB2D0     | TXB2D17<br>TXB2D07 | TXB2D10       | TXB2D15 | TXB2D14       | TXB2D13       | TXB2D12            | TXB2D11<br>TXB2D01 | TXB2D10       | 95                              |
| F05h          | TXB2D0               | TXB2D07            | TXRTR         |         | TAB2D04       | DLC3          | DLC2               | DLC1               | DLC0          | 95                              |
| F04h          | TXB2DLC              | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| F0411<br>F03h | TXB2EIDL<br>TXB2EIDH | EID7<br>EID15      | EID0<br>EID14 | EID3    | EID4<br>EID12 | EID3<br>EID11 | EID2<br>EID10      | EID1<br>EID9       | EID0<br>EID8  | 95<br>95                        |
| F02h          | TXB2EIDH             | SID2               | SID14         | SIDO    | SRR           | EXID          | EIDIU              | EID9<br>EID17      | EID8<br>EID16 | 95<br>95                        |
| F0211         | TXB2SIDL<br>TXB2SIDH | SID2<br>SID10      | SID1          | SID0    | SID7          | SID6          | SID5               | SID4               | SID3          | 95<br>95                        |
|               | 1                    | TXBIF              |               |         |               |               | 3105               | TXPRI1             |               |                                 |
| F00h          | TXB2CON              |                    | TXABT         | TXLARB  | TXERR         | TXREQ         |                    |                    | TXPRI0        | 95                              |
| EFFh          | RXM1EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EFEh          | RXM1EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EFDh          | RXM1SIDL             | SID2               | SID1          | SID0    | -             | EXIDEN        | -                  | EID17              | EID16         | 95                              |
| EFCh          | RXM1SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EFBh          | RXM0EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EFAh          | RXM0EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EF9h          | RXM0SIDL             | SID2               | SID1          | SID0    | —             | EXIDEN        | —                  | EID17              | EID16         | 95                              |
| EF8h          | RXM0SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EF7h          | RXF5EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EF6h          | RXF5EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EF5h          | RXF5SIDL             | SID2               | SID1          | SID0    | —             | EXIDEN        | —                  | EID17              | EID16         | 95                              |
| EF4h          | RXF5SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EF3h          | RXF4EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EF2h          | RXF4EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EF1h          | RXF4SIDL             | SID2               | SID1          | SID0    | —             | EXIDEN        | —                  | EID17              | EID16         | 95                              |
| EF0h          | RXF4SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EEFh          | RXF3EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EEEh          | RXF3EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EEDh          | RXF3SIDL             | SID2               | SID1          | SID0    | —             | EXIDEN        | —                  | EID17              | EID16         | 95                              |
| EECh          | RXF3SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EEBh          | RXF2EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EEAh          | RXF2EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EE9h          | RXF2SIDL             | SID2               | SID1          | SID0    | _             | EXIDEN        | _                  | EID17              | EID16         | 95                              |
| EE8h          | RXF2SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EE7h          | RXF1EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EE6h          | RXF1EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EE5h          | RXF1SIDL             | SID2               | SID1          | SID0    | _             | EXIDEN        | _                  | EID17              | EID16         | 95                              |
| EE4h          | RXF1SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EE3h          | RXF0EIDL             | EID7               | EID6          | EID5    | EID4          | EID3          | EID2               | EID1               | EID0          | 95                              |
| EE2h          | RXF0EIDH             | EID15              | EID14         | EID13   | EID12         | EID11         | EID10              | EID9               | EID8          | 95                              |
| EE1h          | RXF0SIDL             | SID2               | SID1          | SID0    | _             | EXIDEN        | _                  | EID17              | EID16         | 95                              |
| EE0h          | RXF0SIDH             | SID10              | SID9          | SID8    | SID7          | SID6          | SID5               | SID4               | SID3          | 95                              |
| EDFh          | CANCON RO4           | CANCON_R           |               | 5.20    | 5.51          | 5.20          | 5.20               | 5.5 1              | 0.20          | 95                              |
| EDEh          | CANSTAT RO4          | CANSTAT R          |               |         |               |               |                    |                    |               | 95                              |
| EDDh          | B5D7                 | B5D77              | B5D76         | B5D75   | B5D74         | B5D73         | B5D72              | B5D71              | B5D70         | 95<br>95                        |
| EDCh          | B5D6                 | B5D67              | B5D66         | B5D65   | B5D64         | B5D63         | B5D62              | B5D61              | B5D60         | 95<br>95                        |
| EDBh          | B5D6<br>B5D5         |                    |               |         |               |               |                    |                    |               | 95<br>95                        |
|               | ł                    | B5D57              | B5D56         | B5D55   | B5D54         | B5D53         | B5D52              | B5D51              | B5D50         |                                 |
| EDAh          | B5D4                 | B5D47              | B5D46         | B5D45   | B5D44         | B5D43         | B5D42              | B5D41              | B5D40         | 95                              |
| ED9h          | B5D3                 | B5D37              | B5D36         | B5D35   | B5D34         | B5D33         | B5D32              | B5D31              | B5D30         | 95                              |
| ED8h          | B5D2                 | B5D27              | B5D26         | B5D25   | B5D24         | B5D23         | B5D22              | B5D21              | B5D20         | 95                              |
| ED7h          | B5D1                 | B5D17              | B5D16         | B5D15   | B5D14         | B5D13         | B5D12              | B5D11              | B5D10         | 95                              |

# 6.6 Data Memory and the Extended Instruction Set

Enabling the PIC18 extended instruction set (XINST Configuration bit = 1) significantly changes certain aspects of data memory and its addressing. Using the Access Bank for many of the core PIC18 instructions introduces a new addressing mode for the data memory space. This mode also alters the behavior of Indirect Addressing using FSR2 and its associated operands.

What does not change is just as important. The size of the data memory space is unchanged, as well as its linear addressing. The SFR map remains the same. Core PIC18 instructions can still operate in both Direct and Indirect Addressing mode. Inherent and literal instructions do not change at all. Indirect Addressing with FSR0 and FSR1 also remains unchanged.

#### 6.6.1 INDEXED ADDRESSING WITH LITERAL OFFSET

Enabling the PIC18 extended instruction set changes the behavior of Indirect Addressing using the FSR2 register pair and its associated file operands. Under the proper conditions, instructions that use the Access Bank – that is, most bit-oriented and byte-oriented instructions – can invoke a form of Indexed Addressing using an offset specified in the instruction. This special addressing mode is known as Indexed Addressing with Literal Offset or the Indexed Literal Offset mode.

When using the extended instruction set, this addressing mode requires the following:

- Use of the Access Bank ('a' = 0)
- A file address argument that is less than or equal to 5Fh

Under these conditions, the file address of the instruction is not interpreted as the lower byte of an address (used with the BSR in Direct Addressing) or as an 8-bit address in the Access Bank. Instead, the value is interpreted as an offset value to an Address Pointer specified by FSR2. The offset and the contents of FSR2 are added to obtain the target address of the operation.

#### 6.6.2 INSTRUCTIONS AFFECTED BY INDEXED LITERAL OFFSET MODE

Any of the core PIC18 instructions that can use Direct Addressing are potentially affected by the Indexed Literal Offset Addressing mode. This includes all byte-oriented and bit-oriented instructions, or almost one-half of the standard PIC18 instruction set. Instructions that only use Inherent or Literal Addressing modes are unaffected.

Additionally, byte-oriented and bit-oriented instructions are not affected if they do not use the Access Bank (Access RAM bit = 1), or include a file address of 60h or above. Instructions meeting these criteria will continue to execute as before. A comparison of the different possible addressing modes when the extended instruction set is enabled is shown in Figure 6-9.

Those who desire to use byte-oriented or bit-oriented instructions in the Indexed Literal Offset mode should note the changes to assembler syntax for this mode. This is described in more detail in **Section 29.2.1** "Extended Instruction Syntax".

| R/W-1         | R/W-1                                                                           | R/W-1                                                                        | R/W-1             | R/W-1            | R/W-1            | R/W-1          | R/W-1              |  |  |  |  |  |  |
|---------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------|------------------|------------------|----------------|--------------------|--|--|--|--|--|--|
| IRXIP         | WAKIP                                                                           | ERRIP                                                                        | TXB2IP            | TXB1IP           | TXB0IP           | RXB1IP         | RXB0IP/<br>FIFOFIE |  |  |  |  |  |  |
| bit 7         |                                                                                 |                                                                              |                   |                  |                  |                | bit                |  |  |  |  |  |  |
| Legend:       |                                                                                 |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
| R = Readabl   | e bit                                                                           | W = Writable                                                                 | bit               | U = Unimpler     | mented bit, read | d as '0'       |                    |  |  |  |  |  |  |
| -n = Value at | POR                                                                             | '1' = Bit is set                                                             | t                 | '0' = Bit is cle |                  | x = Bit is unk | nown               |  |  |  |  |  |  |
|               |                                                                                 |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 7         |                                                                                 | IRXIP: Invalid Message Received Interrupt Priority bits<br>1 = High priority |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High phi<br>0 = Low price                                                   | •                                                                            |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 6         | -                                                                               | Wake-up Activ                                                                | ity Interrupt Pr  | riority bit      |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High pri                                                                    | 1 = High priority                                                            |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | 0 = Low price                                                                   |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 5         |                                                                                 | N Bus Error Inte                                                             | errupt Priority I | oit              |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High priority<br>0 = Low priority                                           |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 4         | •                                                                               | insmit Buffer 2 I                                                            |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High pri                                                                    |                                                                              |                   | ,                |                  |                |                    |  |  |  |  |  |  |
|               | 0 = Low price                                                                   | -                                                                            |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 3         | <b>TXB1IP:</b> Transmit Buffer 1 Interrupt Priority bit<br>1 = High priority    |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               |                                                                                 | = High priority<br>= Low priority                                            |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 2         | -                                                                               | insmit Buffer 0 I                                                            | nterrupt Priori   | tv bit           |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High pri                                                                    |                                                                              |                   | .,               |                  |                |                    |  |  |  |  |  |  |
|               | 0 = Low price                                                                   | ority                                                                        |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 1         |                                                                                 | ceive Buffer 1 I                                                             | nterrupt Priorit  | y bit            |                  |                |                    |  |  |  |  |  |  |
|               | <u>Mode 0:</u><br>1 = High priority for Receive Buffer 1                        |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High priority for Receive Buffer 1<br>0 = Low priority for Receive Buffer 1 |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | Modes 1 and                                                                     |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               |                                                                                 | ority for receive<br>ority for received                                      |                   |                  |                  |                |                    |  |  |  |  |  |  |
| bit 0         | -                                                                               | OFIP: Receive                                                                | -                 | unt Priority hit |                  |                |                    |  |  |  |  |  |  |
| Sit 0         | Mode 0:                                                                         |                                                                              | Daner o Intern    | apt i nonty bit  |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High priority for Receive Buffer 0                                          |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               | -                                                                               | ority for Receive                                                            | e Buffer 0        |                  |                  |                |                    |  |  |  |  |  |  |
|               | <u>Mode 1:</u><br>Unimpleme                                                     | nted: Read as '                                                              | 0'                |                  |                  |                |                    |  |  |  |  |  |  |
|               | Mode 2:                                                                         |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               |                                                                                 | FO Full Interrup                                                             | t Flag bit        |                  |                  |                |                    |  |  |  |  |  |  |
|               | 1 = High pri<br>0 = Low pric                                                    |                                                                              |                   |                  |                  |                |                    |  |  |  |  |  |  |
|               |                                                                                 | Jing                                                                         |                   |                  |                  |                |                    |  |  |  |  |  |  |

#### REGISTER 10-18: IPR5: PERIPHERAL INTERRUPT PRIORITY REGISTER 5

#### REGISTER 18-2: CTMUCONL: CTMU CONTROL LOW REGISTER

| R/W-0         | R/W-0         | R/W-0                               | R/W-0           | R/W-0             | R/W-0           | R/W-0           | R/W-0    |
|---------------|---------------|-------------------------------------|-----------------|-------------------|-----------------|-----------------|----------|
| EDG2POL       | EDG2SEL1      | EDG2SEL0                            | EDG1POL         | EDG1SEL1          | EDG1SEL0        | EDG2STAT        | EDG1STAT |
| bit 7         |               |                                     |                 |                   |                 |                 | bit 0    |
|               |               |                                     |                 |                   |                 |                 |          |
| Legend:       |               |                                     |                 |                   |                 |                 |          |
| R = Readabl   | e bit         | W = Writable b                      | bit             | U = Unimplem      | ented bit, read | 1 as '0'        |          |
| -n = Value at | POR           | '1' = Bit is set                    |                 | '0' = Bit is clea | ared            | x = Bit is unkr | nown     |
|               |               |                                     |                 |                   |                 |                 |          |
| bit 7         | EDG2POL: E    | dge 2 Polarity S                    | Select bit      |                   |                 |                 |          |
|               |               | programmed f                        |                 |                   |                 |                 |          |
|               | 0 = Edge 2 is | programmed for                      | or a negative e | edge response     |                 |                 |          |
| bit 6-5       |               | :0>: Edge 2 Sou                     | urce Select bit | S                 |                 |                 |          |
|               | 11 = CTED1    |                                     |                 |                   |                 |                 |          |
|               | 10 = CTED2    | pin<br>Special Event T              | rigger          |                   |                 |                 |          |
|               |               | pecial Event Tri                    |                 |                   |                 |                 |          |
| bit 4         | EDG1POL: E    | dge 1 Polarity S                    | Select bit      |                   |                 |                 |          |
|               | 1 = Edge 1 is | programmed f                        | or a positive e | dge response      |                 |                 |          |
|               | 0 = Edge 1 is | s programmed f                      | or a negative e | edge response     |                 |                 |          |
| bit 3-2       | EDG1SEL<1:    | :0>: Edge 1 Sou                     | urce Select bit | s                 |                 |                 |          |
|               | 11 = CTED1    |                                     |                 |                   |                 |                 |          |
|               | 10 = CTED2    |                                     |                 |                   |                 |                 |          |
|               |               | Special Event T<br>pecial Event Tri | 00              |                   |                 |                 |          |
| bit 1         |               | Edge 2 Status b                     |                 |                   |                 |                 |          |
|               |               | vent has occurr                     |                 |                   |                 |                 |          |
|               | Ų             | vent has not oc                     |                 |                   |                 |                 |          |
| bit 0         | •             | Edge 1 Status b                     |                 |                   |                 |                 |          |
|               |               | vent has occurr                     |                 |                   |                 |                 |          |
|               | 0 = Edge 1 e  |                                     |                 |                   |                 |                 |          |

### REGISTER 21-2: SSPCON1: MSSP CONTROL REGISTER 1 (SPI MODE)

| R/W-0      | R/W-0                                              | R/W-0                                | R/W-0           | R/W-0                           | R/W-0                  | R/W-0                | R/W-0                |  |
|------------|----------------------------------------------------|--------------------------------------|-----------------|---------------------------------|------------------------|----------------------|----------------------|--|
| WCOL       | SSPOV <sup>(1)</sup>                               | SSPEN <sup>(2)</sup>                 | CKP             | SSPM3 <sup>(3)</sup>            | SSPM2 <sup>(3)</sup>   | SSPM1 <sup>(3)</sup> | SSPM0 <sup>(3)</sup> |  |
| bit 7      |                                                    |                                      |                 |                                 | •                      | •<br>•               | bit (                |  |
|            |                                                    |                                      |                 |                                 |                        |                      |                      |  |
| Legend:    |                                                    |                                      |                 |                                 |                        |                      |                      |  |
| R = Reada  |                                                    | W = Writable b                       | bit             | -                               | nented bit, rea        |                      |                      |  |
| -n = Value | at POR                                             | '1' = Bit is set                     |                 | '0' = Bit is cleared            |                        | x = Bit is unknown   |                      |  |
| bit 7      | WCOL: Write                                        | Collision Detec                      | t bit           |                                 |                        |                      |                      |  |
|            | software)                                          |                                      | written while   | it is still transm              | itting the previ       | ious word (mus       | t be cleared ir      |  |
|            | 0 = No collisi                                     |                                      |                 |                                 |                        |                      |                      |  |
| bit 6      |                                                    | eive Overflow In                     | dicator bit     |                                 |                        |                      |                      |  |
|            | $\frac{\text{SPI Slave mo}}{1 = A \text{ new by}}$ |                                      | hila tha SSPF   | BUF register is s               | till holding the       | previous data li     | n case of over       |  |
|            |                                                    |                                      |                 | flow can only oc                |                        |                      |                      |  |
|            |                                                    |                                      |                 | ta, to avoid settir             |                        |                      |                      |  |
|            | 0 = No overfl                                      | ow                                   | c               |                                 | •                      |                      |                      |  |
| bit 5      | SSPEN: Mas                                         | ter Synchronous                      | s Serial Port I | Enable bit <sup>(2)</sup>       |                        |                      |                      |  |
|            |                                                    |                                      |                 | SCK, SDO, SD<br>these pins as I |                        | erial port pins      |                      |  |
| bit 4      | CKP: Clock F                                       | olarity Select bi                    | t               |                                 |                        |                      |                      |  |
|            |                                                    | for clock is a high                  |                 |                                 |                        |                      |                      |  |
|            | 0 = Idle state                                     | for clock is a lov                   | w level         |                                 |                        |                      |                      |  |
| bit 3-0    | SSPM<3:0>:                                         | Master Synchro                       | nous Serial I   | Port Mode Selec                 | ct bits <sup>(3)</sup> |                      |                      |  |
|            |                                                    | laster mode: clo                     |                 |                                 |                        |                      |                      |  |
|            |                                                    |                                      |                 | <u>SS</u> pin control           |                        | an be used as l      | I/O pin              |  |
|            |                                                    |                                      |                 | SS pin control                  | enabled                |                      |                      |  |
|            |                                                    | laster mode: clo<br>laster mode: clo |                 | •                               |                        |                      |                      |  |
|            |                                                    | laster mode: clo                     |                 |                                 |                        |                      |                      |  |
|            |                                                    | laster mode: clo                     |                 |                                 |                        |                      |                      |  |
|            | n Master mode, t<br>writing to the SSF             |                                      | is not set sind | ce each new rec                 | eption (and tra        | ansmission) is i     | nitiated by          |  |
|            | When enabled th                                    | 0                                    | n nronerly c    | onfigured as inn                | ute or outpute         |                      |                      |  |

- 2: When enabled, these pins must be properly configured as inputs or outputs.
- **3:** Bit combinations not specifically listed here are either reserved or implemented in I<sup>2</sup>C mode only.

#### 21.4.3.4 7-Bit Address Masking Mode

Unlike 5-bit masking, 7-Bit Address Masking mode uses a mask of up to 8 bits (in 10-bit addressing) to define a range of addresses that can be Acknowledged, using the lowest bits of the incoming address. This allows the module to Acknowledge up to 127 different addresses with 7-bit addressing, or 255 with 10-bit addressing (see Example 21-3). This mode is the default configuration of the module, which is selected when MSSPMSK is unprogrammed ('1').

The address mask for 7-Bit Address Masking mode is stored in the SSPMSK register, instead of the SSPCON2 register. SSPMSK is a separate hardware register within the module, but it is not directly addressable. Instead, it shares an address in the SFR space with the SSPADD register. To access the SSPMSK register, it is necessary to select MSSP mode, '1001' (SSPCON1<3:0> = 1001) and then read or write to the location of SSPADD.

To use 7-Bit Address Masking mode, it is necessary to initialize SSPMSK with a value before selecting the  $I^2C$  Slave Addressing mode. Thus, the required sequence of events is:

- 1. Select SSPMSK Access mode (SSPCON2<3:0> = 1001).
- 2. Write the mask value to the appropriate SSPADD register address (FC8h).
- 3. Set the appropriate I<sup>2</sup>C Slave mode (SSPCON2<3:0> = 0111 for 10-bit addressing, 0110 for 7-bit addressing).

Setting or clearing mask bits in SSPMSK behaves in the opposite manner of the ADMSKx bits in 5-Bit Address Masking mode. That is, clearing a bit in SSPMSK causes the corresponding address bit to be masked; setting the bit requires a match in that position. SSPMSK resets to all '1's upon any Reset condition and, therefore, has no effect on the standard MSSP operation until written with a mask value.

With 7-bit addressing, SSPMSK<7:1> bits mask the corresponding address bits in the SSPADD register. For any SSPMSK bits that are active (SSPMSK<n> = 0), the corresponding SSPADD address bit is ignored (SSPADD<n> = x). For the module to issue an address Acknowledge, it is sufficient to match only on addresses that do not have an active address mask.

With 10-bit addressing, SSPMSK<7:0> bits mask the corresponding address bits in the SSPADD register. For any SSPMSK bits that are active (= 0), the corresponding SSPADD address bit is ignored (SSPADD<n> = x).

Note: The two Most Significant bits of the address are not affected by address masking.

### EXAMPLE 21-3: ADDRESS MASKING EXAMPLES IN 7-BIT MASKING MODE

### 7-Bit Addressing:

SSPADD<7:1> = 1010 000

SSPMSK<7:1> = 1111 001

Addresses Acknowledged = ACh, A8h, A4h, A0h

#### 10-Bit Addressing:

SSPADD<7:0> = 1010 0000 (The two MSb are ignored in this example since they are not affected)

```
SSPMSK<5:1> = 1111 0011
```

Addresses Acknowledged = ACh, A8h, A4h, A0h



## 22.3.4.2 Special Considerations Using the WUE Bit

The timing of WUE and RCxIF events may cause some confusion when it comes to determining the validity of received data. As noted, setting the WUE bit places the EUSARTx in an Idle mode. The wake-up event causes a receive interrupt by setting the RCxIF bit. The WUE bit is cleared after this when a rising edge is seen on RXx/DTx. The interrupt condition is then cleared by reading the RCREGx register. Ordinarily, the data in RCREGx will be dummy data and should be discarded.

The fact that the WUE bit has been cleared (or is still set) and the RCxIF flag is set should not be used as an indicator of the integrity of the data in RCREGx. Users should consider implementing a parallel method in firmware to verify received data integrity.

To assure that no actual data is lost, check the RCIDL bit to verify that a receive operation is not in process. If a receive operation is not occurring, the WUE bit may then be set just prior to entering the Sleep mode.

#### FIGURE 22-8: AUTO-WAKE-UP BIT (WUE) TIMINGS DURING NORMAL OPERATION

| OSC1                  | 승규는 다 다 다             | 을 있는 것을 있을 것을 했다. | pununun.                              | (N. S. M. S. M<br>San sa | 지나 다른 다른다.     | 지나 다른다 다                                                                                                        | 김 지가 지갑 지갑 지 | 그 다른다는 다 3    | તો સાથે સાથે                          | 지나 다 다 다                                                                                                       | 지 않으니?    |
|-----------------------|-----------------------|-------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------|--------------|---------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------|
|                       | ) – 33 sei 6 <u>8</u> | year              | ;                                     |                                                                                                                                                              | · · · ·        |                                                                                                                 | ÷            |               |                                       | - Januar (n. 1937)                                                                                             | Kinaned - |
| 9603 B8 <sup>93</sup> | ş                     | ******            | 2                                     |                                                                                                                                                              |                |                                                                                                                 |              |               |                                       | ç                                                                                                              | •         |
|                       | 5                     | 2                 | ,                                     |                                                                                                                                                              | : 2<br>: 5     | 3                                                                                                               |              |               | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | · · ·                                                                                                          |           |
| ex/CEX Ener           | 3                     | ,                 | · · · · · · · · · · · · · · · · · · · | - 41111                                                                                                                                                      | THATTAR:::::   | iina an taona an taon |              |               | MAA                                   | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~                                                                        |           |
| 1000 100              | 2                     |                   | ,<br>,                                | ( )<br>( +                                                                                                                                                   | 1 - S<br>1 - S |                                                                                                                 | د<br>        |               | ) (<br>                               | )<br>چند <b>و</b> در                                                             |           |
| 900d9                 |                       | ;                 | ;                                     |                                                                                                                                                              | •••••••••      |                                                                                                                 | Alexand      | and allows    | and ditte                             | konsen{                                                                                                        | ·         |
|                       | 1                     |                   | *                                     | :                                                                                                                                                            |                | 1                                                                                                               | a Maria      | and configure |                                       | Er and the second s |           |

#### FIGURE 22-9: AUTO-WAKE-UP BIT (WUE) TIMINGS DURING SLEEP

| 0803 (        | www.ia          | puhuhuh.         | puhihuny                              |            | ····· | nhhạnh                                    | hhh            | · · · · · · · · · · · · · · · · · · ·      | 2 |
|---------------|-----------------|------------------|---------------------------------------|------------|-------|-------------------------------------------|----------------|--------------------------------------------|---|
| - vvus 5894 j | 945 848 848<br> | 40.00 mmm.<br>24 |                                       |            |       |                                           | <u>.</u>       | , process 283<br>Servey X.<br>Comments 200 |   |
| XXXII CASA Ş  |                 | ;<br>;<br>-      | ;<br>;<br>;                           |            |       | ,<br>;                                    |                |                                            |   |
| eddir (       |                 |                  | , , , , , , , , , , , , , , , , , , , |            |       | ·<br>···································· | : to used tand | · · · · · · · · · · · · · · · · · · ·      |   |
|               | 82.8            | 89 Conton        | d Especielaci 🗍                       | Stange Sou | 36 1  | 0336070 693                               | 1.49-0966-1986 | 01740293333                                |   |

2. The SEBARG concers in the while the WEB to is set.

#### REGISTER 27-14: RXB1CON: RECEIVE BUFFER 1 CONTROL REGISTER (CONTINUED)

#### bit 2-0 <u>Mode 0:</u>

FILHIT<2:0>: Filter Hit bits

These bits indicate which acceptance filter enabled the last message reception into Receive Buffer 1.

- 111 = Reserved
- 110 = Reserved
- 101 = Acceptance Filter 5 (RXF5)
- 100 = Acceptance Filter 4 (RXF4)
- 011 = Acceptance Filter 3 (RXF3)
- 010 = Acceptance Filter 2 (RXF2)
- 001 = Acceptance Filter 1 (RXF1), only possible when RXB0DBEN bit is set

000 = Acceptance Filter 0 (RXF0), only possible when RXB0DBEN bit is set

#### Mode 1, 2:

**FILHIT<4:0>:** Filter Hit bits<2:0> These bits, in combination with FILHIT<4:3>, indicate which acceptance filter enabled the message reception into this receive buffer.

01111 = Acceptance Filter 15 (RXF15) 01110 = Acceptance Filter 14 (RXF14)

00000 = Acceptance Filter 0 (RXF0)

**Note 1:** This bit is set by the CAN module upon receiving a message and must be cleared by software after the buffer is read. As long as RXFUL is set, no new message will be loaded and the buffer will be considered full.

## REGISTER 27-15: RXBnSIDH: RECEIVE BUFFER 'n' STANDARD IDENTIFIER REGISTERS, HIGH BYTE [0 $\leq$ n $\leq$ 1]

| R-x   | R-x  | R-x  | R-x  | R-x  | R-x  | R-x  | R-x   |
|-------|------|------|------|------|------|------|-------|
| SID10 | SID9 | SID8 | SID7 | SID6 | SID5 | SID4 | SID3  |
| bit 7 |      |      |      |      |      |      | bit 0 |

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | , read as '0'      |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

bit 7-0 **SID<10:3>:** Standard Identifier bits (if EXID (RXBnSIDL<3>) = 0) Extended Identifier bits, EID<28:21> (if EXID = 1). The PIC18F66K80 family devices are error-active if both error counters are below the error-passive limit of 128. They are error-passive if at least one of the error counters equals or exceeds 128. They go to bus-off if the transmit error counter equals or exceeds the busoff limit of 256. The devices remain in this state until the bus-off recovery sequence is finished. The bus-off recovery sequence consists of 128 occurrences of 11 consecutive recessive bits (see Figure 27-8). Note that the CAN module, after going bus-off, will recover back to error-active without any intervention by the MCU if the bus remains Idle for 128 x 11 bit times. If this is not desired, the error Interrupt Service Routine should address this. The current Error mode of the CAN module can be read by the MCU via the COMSTAT register.

Additionally, there is an Error State Warning flag bit, EWARN, which is set if at least one of the error counters equals or exceeds the error warning limit of 96. EWARN is reset if both error counters are less than the error warning limit.

#### FIGURE 27-8: ERROR MODES STATE DIAGRAM



### 27.15 CAN Interrupts

The module has several sources of interrupts. Each of these interrupts can be individually enabled or disabled. The PIR5 register contains interrupt flags. The PIE5 register contains the enables for the 8 main interrupts. A special set of read-only bits in the CANSTAT register, the ICODE bits, can be used in combination with a jump table for efficient handling of interrupts.

All interrupts have one source, with the exception of the error interrupt and buffer interrupts in Mode 1 and 2. Any of the error interrupt sources can set the error interrupt flag. The source of the error interrupt can be determined by reading the Communication Status register, COMSTAT. In Mode 1 and 2, there are two interrupt enable/disable and flag bits – one for all transmit buffers and the other for all receive buffers.

The interrupts can be broken up into two categories: receive and transmit interrupts.

The receive related interrupts are:

- Receive Interrupts
- Wake-up Interrupt
- Receiver Overrun Interrupt
- Receiver Warning Interrupt
- Receiver Error-Passive Interrupt

The transmit related interrupts are:

- Transmit Interrupts
- Transmitter Warning Interrupt
- Transmitter Error-Passive Interrupt
- Bus-Off Interrupt

# 28.6 Program Verification and Code Protection

The user program memory is divided into four blocks. One of these is a boot block of 1 or 2 Kbytes. The remainder of the memory is divided into blocks on binary boundaries. Each of the blocks has three code protection bits associated with them. They are:

- Code-Protect bit (CPx)
- Write-Protect bit (WRTx)
- External Block Table Read bit (EBTRx)

Figure 28-6 shows the program memory organization for 48, 64, 96 and 128 Kbyte devices and the specific code protection bit associated with each block. The actual locations of the bits are summarized in Table 28-4.





| BTFSC                                                                  | Bit Test File                                                               | , Skip if Clea                                                                                                                |                                                                    | BTFSS                                                                  | Bit Test File                                                                 | e, Skip if Set                                                                                                                  |                                                                 |
|------------------------------------------------------------------------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| Syntax:                                                                | BTFSC f, b                                                                  | {,a}                                                                                                                          |                                                                    | Syntax:                                                                | BTFSS f, b {                                                                  | ,a}                                                                                                                             |                                                                 |
| Operands:                                                              | $\begin{array}{l} 0\leq f\leq 255\\ 0\leq b\leq 7\\ a\in [0,1] \end{array}$ |                                                                                                                               |                                                                    | Operands:                                                              | 0 ≤ f ≤ 255<br>0 ≤ b < 7<br>a ∈ [0,1]                                         |                                                                                                                                 |                                                                 |
| Operation:                                                             | skip if (f <b>)</b>                                                         | = 0                                                                                                                           |                                                                    | Operation:                                                             | skip if (f <b>)</b>                                                           | = 1                                                                                                                             |                                                                 |
| Status Affected:                                                       | None                                                                        |                                                                                                                               |                                                                    | Status Affected:                                                       | None                                                                          |                                                                                                                                 |                                                                 |
| Encoding:                                                              | 1011                                                                        | bbba ff                                                                                                                       | ff ffff                                                            | Encoding:                                                              | 1010                                                                          | bbba ff                                                                                                                         | ff ffff                                                         |
| Description:                                                           | instruction is<br>the next inst<br>current instru<br>and a NOP is           | gister 'f' is '0',<br>s skipped. If bit<br>ruction fetchec<br>uction executic<br>s executed inst<br>rcle instruction          | 'b' is '0', then<br>I during the<br>on is discarded<br>ead, making | Description:                                                           | instruction is<br>the next inst<br>current instru<br>and a NOP is             | gister 'f' is '1', f<br>s skipped. If bit<br>ruction fetched<br>uction executio<br>s executed inst-<br>rcle instruction.        | 'b' is '1', then<br>during the<br>n is discarded<br>ead, making |
|                                                                        |                                                                             | e Access Banl<br>BSR is used to                                                                                               | k is selected. If<br>a select the                                  |                                                                        |                                                                               | e Access Bank<br>BSR is used to                                                                                                 | is selected. If select the                                      |
|                                                                        | is enabled, t<br>Indexed Lite<br>whenever f<br>Section 29.3<br>Bit-Oriented | d the extended<br>his instruction<br>ral Offset Addr<br>≤ 95 (5Fh). See<br>2.3 "Byte-Orie<br>d Instructions<br>et Mode" for d | essing mode<br>ented and<br>in Indexed                             |                                                                        | set is enable<br>Indexed Lite<br>whenever f ≤<br>Section 29.3<br>Bit-Oriented | d the extended<br>d, this instructi<br>ral Offset Addr<br>≤ 95 (5Fh). See<br>2.3 "Byte-Orie<br>d Instructions<br>et Mode" for d | on operates in<br>essing mode<br>e<br>inted and<br>in Indexed   |
| Words:                                                                 | 1                                                                           |                                                                                                                               |                                                                    | Words:                                                                 | 1                                                                             |                                                                                                                                 |                                                                 |
| Cycles:                                                                |                                                                             | cles if skip and<br>2-word instrue                                                                                            |                                                                    | Cycles:                                                                |                                                                               | ycles if skip an<br>a 2-word instru                                                                                             |                                                                 |
| Q Cycle Activity:                                                      |                                                                             |                                                                                                                               |                                                                    | Q Cycle Activity:                                                      |                                                                               |                                                                                                                                 |                                                                 |
| Q1                                                                     | Q2                                                                          | Q3                                                                                                                            | Q4                                                                 | Q1                                                                     | Q2                                                                            | Q3                                                                                                                              | Q4                                                              |
| Decode                                                                 | Read                                                                        | Process                                                                                                                       | No                                                                 | Decode                                                                 | Read                                                                          | Process                                                                                                                         | No                                                              |
| If akin:                                                               | register 'f'                                                                | Data                                                                                                                          | operation                                                          | If skip:                                                               | register 'f'                                                                  | Data                                                                                                                            | operation                                                       |
| lf skip:<br>Q1                                                         | Q2                                                                          | Q3                                                                                                                            | Q4                                                                 | п sкip.<br>Q1                                                          | Q2                                                                            | Q3                                                                                                                              | Q4                                                              |
| No                                                                     | No                                                                          | No                                                                                                                            | No                                                                 | No                                                                     | No                                                                            | No                                                                                                                              | No                                                              |
| operation                                                              | operation                                                                   | operation                                                                                                                     | operation                                                          | operation                                                              | operation                                                                     | operation                                                                                                                       | operation                                                       |
| If skip and follow                                                     | ed by 2-word ins                                                            | truction:                                                                                                                     |                                                                    | If skip and follow                                                     | ed by 2-word ins                                                              | truction:                                                                                                                       |                                                                 |
| Q1                                                                     | Q2                                                                          | Q3                                                                                                                            | Q4                                                                 | Q1                                                                     | Q2                                                                            | Q3                                                                                                                              | Q4                                                              |
| No<br>operation                                                        | No                                                                          | No                                                                                                                            | No                                                                 | No<br>operation                                                        | No<br>operation                                                               | No                                                                                                                              | No<br>operation                                                 |
| No                                                                     | operation<br>No                                                             | operation<br>No                                                                                                               | operation<br>No                                                    | No                                                                     | No                                                                            | operation<br>No                                                                                                                 | No                                                              |
| operation                                                              | operation                                                                   | operation                                                                                                                     | operation                                                          | operation                                                              | operation                                                                     | operation                                                                                                                       | operation                                                       |
| Example:                                                               | HERE B<br>FALSE :<br>TRUE :                                                 | IFSC FLAG                                                                                                                     | 3, 1, 0                                                            | Example:                                                               | HERE B'<br>FALSE :<br>TRUE :                                                  | IFSS FLAG                                                                                                                       | , 1, O                                                          |
| Before Instru<br>PC<br>After Instruc<br>If FLAG<br>P(<br>If FLAG<br>PC | = add<br>tion<br>G<1> = 0;<br>C = add<br>G<1> = 1;                          | ress (HERE)<br>ress (TRUE)<br>ress (FALSE                                                                                     | )                                                                  | Before Instru<br>PC<br>After Instruc<br>If FLAG<br>P(<br>If FLAG<br>PC | = add<br>tion<br>5<1> = 0;<br>C = add<br>5<1> = 1;                            | ress (HERE)<br>ress (FALSE<br>ress (TRUE)                                                                                       | )                                                               |

#### 29.2.3 BYTE-ORIENTED AND BIT-ORIENTED INSTRUCTIONS IN INDEXED LITERAL OFFSET MODE

| Note: | Enabling the PIC18 instruction set exten- |
|-------|-------------------------------------------|
|       | sion may cause legacy applications to     |
|       | behave erratically or fail entirely.      |

In addition to eight new commands in the extended set, enabling the extended instruction set also enables Indexed Literal Offset Addressing (Section 6.6.1 "Indexed Addressing with Literal Offset"). This has a significant impact on the way that many commands of the standard PIC18 instruction set are interpreted.

When the extended set is disabled, addresses embedded in opcodes are treated as literal memory locations: either as a location in the Access Bank (a = 0) or in a GPR bank designated by the BSR (a = 1). When the extended instruction set is enabled and a = 0, however, a file register argument of 5Fh or less is interpreted as an offset from the pointer value in FSR2 and not as a literal address. For practical purposes, this means that all instructions that use the Access RAM bit as an argument – that is, all byte-oriented and bit-oriented instructions, or almost half of the core PIC18 instructions – may behave differently when the extended instruction set is enabled.

When the content of FSR2 is 00h, the boundaries of the Access RAM are essentially remapped to their original values. This may be useful in creating backward-compatible code. If this technique is used, it may be necessary to save the value of FSR2 and restore it when moving back and forth between C and assembly routines in order to preserve the Stack Pointer. Users must also keep in mind the syntax requirements of the extended instruction set (see Section 29.2.3.1 "Extended Instruction Syntax with Standard PIC18 Commands").

Although the Indexed Literal Offset mode can be very useful for dynamic stack and pointer manipulation, it can also be very annoying if a simple arithmetic operation is carried out on the wrong register. Users who are accustomed to the PIC18 programming must keep in mind that, when the extended instruction set is enabled, register addresses of 5Fh or less are used for Indexed Literal Offset Addressing.

Representative examples of typical byte-oriented and bit-oriented instructions in the Indexed Literal Offset mode are provided on the following page to show how execution is affected. The operand conditions shown in the examples are applicable to all instructions of these types.

# 29.2.3.1 Extended Instruction Syntax with Standard PIC18 Commands

When the extended instruction set is enabled, the file register argument 'f' in the standard byte-oriented and bit-oriented commands is replaced with the literal offset value 'k'. As already noted, this occurs only when 'f' is less than or equal to 5Fh. When an offset value is used, it must be indicated by square brackets ("[]"). As with the extended instructions, the use of brackets indicates to the compiler that the value is to be interpreted as an index or an offset. Omitting the brackets, or using a value greater than 5Fh within the brackets, will generate an error in the MPASM<sup>™</sup> Assembler.

If the index argument is properly bracketed for Indexed Literal Offset Addressing, the Access RAM argument is never specified; it will automatically be assumed to be '0'. This is in contrast to standard operation (extended instruction set disabled), when 'a' is set on the basis of the target address. Declaring the Access RAM bit in this mode will also generate an error in the MPASM Assembler.

The destination argument 'd' functions as before.

In the latest versions of the MPASM Assembler, language support for the extended instruction set must be explicitly invoked. This is done with either the command line option,  $/_{Y}$ , or the PE directive in the source listing.

#### 29.2.4 CONSIDERATIONS WHEN ENABLING THE EXTENDED INSTRUCTION SET

It is important to note that the extensions to the instruction set may not be beneficial to all users. In particular, users who are not writing code that uses a software stack may not benefit from using the extensions to the instruction set.

Additionally, the Indexed Literal Offset Addressing mode may create issues with legacy applications written to the PIC18 assembler. This is because instructions in the legacy code may attempt to address registers in the Access Bank below 5Fh. Since these addresses are interpreted as literal offsets to FSR2 when the instruction set extension is enabled, the application may read or write to the wrong data addresses.

When porting an application to the PIC18F66K80 family, it is very important to consider the type of code. A large, re-entrant application that is written in C and would benefit from efficient compilation will do well when using the instruction set extensions. Legacy applications that heavily use the Access Bank will most likely not benefit from using the extended instruction set.

#### 31.2 DC Characteristics: Power-Down and Supply Current PIC18F66K80 Family (Industrial/Extended) (Continued)

|              | 6K80 Family<br>strial/Extended) | Standard<br>Operating  |      |       | -40°C ≤ TA ≤ | otherwise stated)<br>+85°C for industrial<br>+125°C for extended |                                        |
|--------------|---------------------------------|------------------------|------|-------|--------------|------------------------------------------------------------------|----------------------------------------|
| Param<br>No. | Device                          | Тур                    | Max  | Units |              | Conditions                                                       | 3                                      |
|              | Supply Current (IDD)            | Cont. <sup>(2,3)</sup> |      |       |              |                                                                  |                                        |
|              | PIC18LFXXK80                    | 330                    | 480  | μA    | -40°C        |                                                                  |                                        |
|              |                                 | 330                    | 480  | μA    | +25°C        |                                                                  |                                        |
|              |                                 | 330                    | 480  | μA    | +60°C        | V <sub>DD</sub> = 1.8V <sup>(4)</sup><br>Regulator Disabled      |                                        |
|              |                                 | 340                    | 500  | μA    | +85°C        |                                                                  |                                        |
|              |                                 | 350                    | 540  | μA    | +125°C       |                                                                  |                                        |
|              | PIC18LFXXK80                    | 522                    | 720  | μA    | -40°C        |                                                                  |                                        |
|              |                                 | 522                    | 720  | μA    | +25°C        | $V_{DD} = 3.3V^{(4)}$<br>Regulator Disabled                      |                                        |
|              |                                 | 522                    | 720  | μA    | +60°C        |                                                                  |                                        |
|              |                                 | 540                    | 740  | μA    | +85°C        |                                                                  |                                        |
|              |                                 | 550                    | 780  | μA    | +125°C       |                                                                  | Fosc = 4 MHz<br>( <b>RC IDLE</b> mode, |
|              | PIC18FXXK80                     | 540                    | 760  | μΑ    | -40°C        |                                                                  | Internal HF-INTOSC)                    |
|              |                                 | 540                    | 760  | μA    | +25°C        | (5)                                                              | ,                                      |
|              |                                 | 540                    | 760  | μΑ    | +60°C        | $V_{DD} = 3.3 V^{(5)}$<br>Regulator Enabled                      |                                        |
|              |                                 | 560                    | 780  | μΑ    | +85°C        |                                                                  |                                        |
|              |                                 | 580                    | 810  | μA    | +125°C       |                                                                  |                                        |
|              | PIC18FXXK80                     | 600                    | 1250 | μA    | -40°C        |                                                                  |                                        |
|              |                                 | 600                    | 1250 | μA    | +25°C        |                                                                  |                                        |
|              |                                 | 600                    | 1250 | μA    | +60°C        | $V_{DD} = 5V^{(5)}$<br>Regulator Enabled                         |                                        |
|              |                                 | 610                    | 1300 | μΑ    | +85°C        |                                                                  |                                        |
|              |                                 | 620                    | 1340 | μA    | +125°C       |                                                                  |                                        |

Legend: Shading of rows is to assist in readability of the table.

**Note 1:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in a high-impedance state and tied to VDD or VSS, and all features that add delta current are disabled (such as WDT, SOSC oscillator, BOR, etc.).

2: The supply current is mainly a function of operating voltage, frequency and mode. Other factors, such as I/O pin loading and switching rate, oscillator type and circuit, internal code execution pattern and temperature, also have an impact on the current consumption.

The test conditions for all IDD measurements in active operation mode are:

OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD;

MCLR = VDD; WDT enabled/disabled as specified.

3: Standard, low-cost 32 kHz crystals have an operating temperature range of -10°C to +70°C. Extended temperature crystals are available at a much higher cost.

- 4: For LF devices, RETEN (CONFIG1L<0>) = 1.
- 5: For F devices, SRETEN (WDTCON<4>) = 1 and RETEN (CONFIG1L<0>) = 0.

| 31.3 | DC Characteristics: | PIC18F66K80 Famil | y (Industrial) (Continued) |
|------|---------------------|-------------------|----------------------------|
|------|---------------------|-------------------|----------------------------|

|                     |        |                                            | $\begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for industrial} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for extended} \end{array}$ |     |       |                                                         |  |
|---------------------|--------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|---------------------------------------------------------|--|
| Param<br>No.        | Symbol | Characteristic                             | Min                                                                                                                                                                                                                                                             | Max | Units | Conditions                                              |  |
|                     | Vон    | Output High Voltage <sup>(1)</sup>         |                                                                                                                                                                                                                                                                 |     |       |                                                         |  |
| D090                |        | I/O Ports:                                 |                                                                                                                                                                                                                                                                 |     | V     |                                                         |  |
|                     |        | PORTA, PORTB, PORTC                        | VDD - 0.7                                                                                                                                                                                                                                                       | —   | V     | lон = -3 mA, VDD = 5.5V,<br>-40°С to +125°С             |  |
|                     |        | PORTD, PORTE, PORTF,<br>PORTG              | VDD - 0.7                                                                                                                                                                                                                                                       | —   | V     | lон = -2 mA, VDD = 5.5V,<br>-40°С to +125°С             |  |
| D092                |        | OSC2/CLKO<br>(INTOSC, EC modes)            | Vdd - 0.7                                                                                                                                                                                                                                                       | —   | V     | lон = -1 mA, VDD = 5.5V,<br>-40°С to +125°С             |  |
|                     |        | Capacitive Loading Specs<br>on Output Pins |                                                                                                                                                                                                                                                                 |     |       |                                                         |  |
| D100 <sup>(4)</sup> | COSC2  | OSC2 Pin                                   | —                                                                                                                                                                                                                                                               | 20  | pF    | In HS mode when external<br>clock is used to drive OSC1 |  |
| D101                | Сю     | All I/O Pins and OSC2                      | _                                                                                                                                                                                                                                                               | 50  | pF    | To meet the AC Timing<br>Specifications                 |  |
| D102                | Св     | SCL, SDA                                   | —                                                                                                                                                                                                                                                               | 400 | pF    | I <sup>2</sup> C <sup>™</sup> Specification             |  |

**Note 1:** Negative current is defined as current sourced by the pin.

|                                                                                                                                                                            | . 174                                                                                                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| SLRCON (Slew Rate Control)<br>SSPCON1 (MSSP Control 1, I <sup>2</sup> C Mode)                                                                                              | .298                                                                                                                                         |
| SSPCON1 (MSSP Control 1, SPI Mode)                                                                                                                                         |                                                                                                                                              |
| SSPCON2 (MSSP Control 2, I <sup>2</sup> C Master Mode)                                                                                                                     | . 299                                                                                                                                        |
| SSPCON2 (MSSP Control 2, I <sup>2</sup> C Slave Mode)                                                                                                                      | . 300                                                                                                                                        |
| SSPMSK (I <sup>2</sup> C Slave Address Mask)                                                                                                                               | . 300                                                                                                                                        |
| SSPSTAT (MSSP Status, I <sup>2</sup> C Mode)                                                                                                                               |                                                                                                                                              |
| SSPSTAT (MSSP Status, SPI Mode)                                                                                                                                            |                                                                                                                                              |
| STATUS                                                                                                                                                                     | . 122                                                                                                                                        |
| STKPTR (Stack Pointer)                                                                                                                                                     |                                                                                                                                              |
| T0CON (Timer0 Control)                                                                                                                                                     | . 205                                                                                                                                        |
| T1CON (Timer1 Control)                                                                                                                                                     |                                                                                                                                              |
| T1GCON (Timer1 Gate Control)                                                                                                                                               |                                                                                                                                              |
| T2CON (Timer2 Control)                                                                                                                                                     |                                                                                                                                              |
| T3CON (Timer3 Control)                                                                                                                                                     | . 223                                                                                                                                        |
| T3GCON (Timer3 Gate Control)                                                                                                                                               |                                                                                                                                              |
| T4CON (Timer4 Control)                                                                                                                                                     | . 233                                                                                                                                        |
| TXBIE (Transmit Buffers Interrupt Enable)                                                                                                                                  |                                                                                                                                              |
| TXBnCON (Transmit Buffer n Control)                                                                                                                                        |                                                                                                                                              |
| TXBnDLC (Transmit Buffer n Data Length Code)                                                                                                                               |                                                                                                                                              |
| TXBnDm (Transmit Buffer n Data Field Byte m)                                                                                                                               |                                                                                                                                              |
| TXBnEIDH (Transmit Buffer n Extended Identifier,                                                                                                                           |                                                                                                                                              |
| Byte)<br>TXBnEIDL (Transmit Buffer n Extended Identifier,                                                                                                                  |                                                                                                                                              |
| Byte)                                                                                                                                                                      |                                                                                                                                              |
| TXBnSIDH (Transmit Buffer n Standard Identifier,                                                                                                                           |                                                                                                                                              |
| Byte)                                                                                                                                                                      |                                                                                                                                              |
| TXBnSIDL (Transmit Buffer n Standard Identifier,                                                                                                                           |                                                                                                                                              |
|                                                                                                                                                                            | LOW                                                                                                                                          |
| Byte)                                                                                                                                                                      |                                                                                                                                              |
|                                                                                                                                                                            | .401                                                                                                                                         |
| Byte)                                                                                                                                                                      | .401<br>.403                                                                                                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)                                                        | .401<br>.403<br>.334<br>.473                                                                                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)                    | .401<br>.403<br>.334<br>.473<br>.172                                                                                                         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET           | .401<br>.403<br>.334<br>.473<br>.172<br>.513                                                                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457                                                                                         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457<br>.457                                                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457<br>.457<br>.457                                                                         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457<br>.457<br>.457<br>.457                                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457                                                         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.514                                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.514<br>.515                                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.514<br>.515<br>.103                         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>,457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.514<br>.515<br>.103<br>.104                 |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.514<br>.515<br>.103<br>.104<br>.601         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.515<br>.103<br>.104<br>.601<br>.515         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.514<br>.515<br>.103<br>.104<br>.601<br>.515<br>.516         |
| Byte)<br>TXERRCNT (Transmit Error Count)<br>TXSTAx (Transmit Status and Control)<br>WDTCON (Watchdog Timer Control)<br>WPUB (Weak Pull-up PORTB Enable)<br>RESET<br>Resets | .401<br>.403<br>.334<br>.473<br>.172<br>.513<br>.457<br>.457<br>.457<br>.457<br>.457<br>.514<br>.515<br>.103<br>.104<br>.515<br>.516<br>.516 |

## S

| SCK                                        |     |
|--------------------------------------------|-----|
| SDI                                        |     |
| SDO                                        |     |
| SEC_IDLE Mode                              | 71  |
| SEC_RUN Mode                               | 66  |
| Selective Peripheral Module Control        |     |
| Serial Clock, SCK                          |     |
| Serial Data In (SDI)                       |     |
| Serial Data Out (SDO)                      |     |
| Serial Peripheral Interface. See SPI Mode. |     |
| SETF                                       | 517 |
| Shoot-Through Current                      |     |
| Slave Select (SS)                          |     |
| SLEEP                                      | 518 |
| Sleep Mode                                 | 70  |
|                                            |     |

| Software Simulator (MPLAB SIM)                                                        | 535                              |
|---------------------------------------------------------------------------------------|----------------------------------|
| Special Event Trigger. See Compare (CCP Module).                                      |                                  |
| Special Event Trigger. See Compare (ECCP Mode).                                       |                                  |
| SPI Mode (MSSP)                                                                       |                                  |
| Associated Registers                                                                  |                                  |
| Bus Mode Compatibility                                                                |                                  |
| Effects of a Reset                                                                    |                                  |
| Enabling SPI I/O                                                                      |                                  |
| Master Mode<br>Master/Slave Connection                                                |                                  |
|                                                                                       |                                  |
| Operation<br>Operation in Power-Managed Modes                                         | 290                              |
| Serial Clock                                                                          |                                  |
| Serial Data In                                                                        |                                  |
| Serial Data Out                                                                       |                                  |
| Slave Mode                                                                            |                                  |
| Slave Node                                                                            |                                  |
| Slave Select Synchronization                                                          |                                  |
| SPI Clock                                                                             |                                  |
| SSPBUF Register                                                                       |                                  |
| SSPSR Register                                                                        |                                  |
| Typical Connection                                                                    |                                  |
| <u>SS</u>                                                                             |                                  |
| SSPOV                                                                                 |                                  |
| SSPOV Status Flag                                                                     |                                  |
| SSPSTAT Register                                                                      |                                  |
| R/W Bit                                                                               | 304                              |
| Stack Full/Underflow Resets                                                           |                                  |
| SUBFSR                                                                                |                                  |
| SUBFWB                                                                                | 518                              |
| SUBLW                                                                                 |                                  |
| SUBULNK                                                                               | 529                              |
| SUBWF                                                                                 |                                  |
| SUBWFB                                                                                | 520                              |
| SWAPF                                                                                 | 520                              |
| т                                                                                     |                                  |
| -                                                                                     | 400                              |
| Table Pointer Operations (table)<br>Table Reads/Table Writes                          |                                  |
| Table Reads/Table Writes                                                              |                                  |
| TBLRD                                                                                 |                                  |
|                                                                                       |                                  |
|                                                                                       |                                  |
| Time-out in Various Situations (table)                                                | . 84                             |
| Time-out in Various Situations (table)<br>Timer0                                      | . 84<br>205                      |
| Time-out in Various Situations (table)<br>Timer0<br>Associated Registers              | . 84<br>205<br>207               |
| Time-out in Various Situations (table)<br>Timer0<br>Associated Registers<br>Operation | . 84<br>205<br>207<br>206        |
| Time-out in Various Situations (table)<br>Timer0<br>Associated Registers              | . 84<br>205<br>207<br>206<br>207 |

| Table Pointer Operations (table)                | . 132 |
|-------------------------------------------------|-------|
| Table Reads/Table Writes                        | . 105 |
| TBLRD                                           | . 521 |
| TBLWT                                           | . 522 |
| Time-out in Various Situations (table)          | 84    |
| Timer0                                          | . 205 |
| Associated Registers                            | . 207 |
| Operation                                       | . 206 |
| Overflow Interrupt                              | . 207 |
| Prescaler                                       | . 207 |
| Switching Assignment                            | . 207 |
| Prescaler Assignment (PSA Bit)                  | . 207 |
| Prescaler Select (T0PS2:T0PS0 Bits)             | . 207 |
| Reads and Writes in 16-Bit Mode                 | . 206 |
| Source Edge Select (T0SE Bit)                   | . 206 |
| Source Select (T0CS Bit)                        | . 206 |
| Timer1                                          | . 209 |
| 16-Bit Read/Write Mode                          | . 214 |
| Associated Registers                            | . 220 |
| Clock Source Selection                          | . 212 |
| Gate                                            | . 216 |
| Interrupt                                       | . 215 |
| Operation                                       | . 212 |
| Oscillator                                      | . 209 |
| Oscillator, as Secondary Clock                  | 56    |
| Resetting, Using the ECCP Special Event Trigger | . 216 |
| SOSC Oscillator                                 | . 214 |
| Layout Considerations                           | . 215 |
| Use as a Clock Source                           | . 215 |