



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                      |
|----------------------------|-----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 64MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                  |
| Number of I/O              | 25                                                                          |
| Program Memory Size        | 32KB (16K x 16)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 256 x 8                                                                     |
| RAM Size                   | 2K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 35x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-UFQFN Exposed Pad                                                        |
| Supplier Device Package    | 28-UQFN (4x4)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf25k40-e-mv |
|                            |                                                                             |

Email: info@E-XFL.COM

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

# 1.0 DEVICE OVERVIEW

This document contains device specific information for the following devices:

- PIC18F24K40 PIC18LF24K40
- PIC18F25K40 PIC18LF25K40

This family offers the advantages of all PIC18 microcontrollers – namely, high computational performance at an economical price – with the addition of high-endurance, Program Flash Memory. In addition to these features, the PIC18(L)F2x/4xK40 family introduces design enhancements that make these microcontrollers a logical choice for many high-performance, power sensitive applications.

### 1.1 New Core Features

#### 1.1.1 XLP TECHNOLOGY

All of the devices in the PIC18(L)F2x/4xK40 family incorporate a range of features that can significantly reduce power consumption during operation. Key items include:

- Alternate Run Modes: By clocking the controller from the secondary oscillator or the internal oscillator block, power consumption during code execution can be reduced by as much as 90%.
- Multiple Idle Modes: The controller can also run with its CPU core disabled but the peripherals still active. In these states, power consumption can be reduced even further, to as little as 4% of normal operation requirements.
- **On-the-fly Mode Switching:** The powermanaged modes are invoked by user code during operation, allowing the user to incorporate power-saving ideas into their application's software design.
- **Peripheral Module Disable:** Modules that are not being used in the code can be selectively disabled using the PMD module. This further reduces the power consumption.

### 1.1.2 MULTIPLE OSCILLATOR OPTIONS AND FEATURES

All of the devices in the PIC18(L)F2x/4xK40 family offer several different oscillator options. The PIC18(L)F2x/4xK40 family can be clocked from several different sources:

- HFINTOSC
  - 1-64 MHz precision digitally controlled internal oscillator
- LFINTOSC
- 31 kHz internal oscillator
- EXTOSC
  - External clock (EC)
  - Low-power oscillator (LP)
  - Medium power oscillator (XT)
  - High-power oscillator (HS)
- SOSC
  - Secondary oscillator circuit operating at 31 kHz
- A Phase Lock Loop (PLL) frequency multiplier (4x) is available to the External Oscillator modes enabling clock speeds of up to 64 MHz
- Fail-Safe Clock Monitor: This option constantly monitors the main clock source against a reference signal provided by the LFINTOSC. If a clock failure occurs, the controller is switched to the internal oscillator block, allowing for continued operation or a safe application shutdown.

| REGISIE    | toning                            | uration word                                                                                                                                                               |                | siij. Superv               | 1501            |                 |               |  |  |  |
|------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------|-----------------|-----------------|---------------|--|--|--|
| R/W-1      | U-1                               | R/W-1                                                                                                                                                                      | R/W-1          | R/W-1                      | R/W-1           | R/W-1           | R/W-1         |  |  |  |
| XINST      | _                                 | DEBUG                                                                                                                                                                      | STVREN         | PPS1WAY                    | ZCD             | BORV            | /<1:0>        |  |  |  |
| bit 7      |                                   |                                                                                                                                                                            |                |                            |                 |                 | bit (         |  |  |  |
|            |                                   |                                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
| Legend:    |                                   |                                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
| R = Reada  |                                   | W = Writable                                                                                                                                                               |                | -                          | mented bit, rea |                 |               |  |  |  |
| -n = value | for blank device                  | '1' = Bit is set                                                                                                                                                           | [              | '0' = Bit is cle           | eared           | x = Bit is unkı | nown          |  |  |  |
| bit 7      | XINST: Exten                      | ded Instruction                                                                                                                                                            | Set Enable bi  | it                         |                 |                 |               |  |  |  |
|            |                                   | ed Instruction Se                                                                                                                                                          |                |                            |                 | (Legacy mode)   |               |  |  |  |
|            |                                   | ed Instruction Se                                                                                                                                                          |                | d Addressing r             | node enabled    |                 |               |  |  |  |
| bit 6      |                                   | ted: Read as '1                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
| bit 5      |                                   | ugger Enable b<br>ound debugger                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
|            | •                                 | ound debugger                                                                                                                                                              |                |                            |                 |                 |               |  |  |  |
| bit 4      | •                                 | ck Overflow/Ur                                                                                                                                                             |                | t Enable bit               |                 |                 |               |  |  |  |
|            |                                   | verflow or Unde                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
|            |                                   | verflow or Unde                                                                                                                                                            |                |                            | t               |                 |               |  |  |  |
| bit 3      |                                   | <ul> <li><b>PPS1WAY:</b> PPSLOCKED bit One-Way Set Enable bit</li> <li>1 = The PPSLOCKED bit can only be set once after an unlocking sequence is executed; once</li> </ul> |                |                            |                 |                 |               |  |  |  |
|            |                                   | CK is set, all fut                                                                                                                                                         |                |                            |                 |                 |               |  |  |  |
|            | 0 = The PPS                       | SLOCKED bit o                                                                                                                                                              |                |                            |                 |                 | g sequence is |  |  |  |
|            | execute                           | ,                                                                                                                                                                          |                |                            |                 |                 |               |  |  |  |
| bit 2      | <b>ZCD:</b> ZCD Di<br>1 = ZCD dis | sable bit<br>abled. ZCD car                                                                                                                                                | n ha anahlad l | hy setting the 3           | 7CDSEN bit of   |                 |               |  |  |  |
|            |                                   | ays enabled, Z                                                                                                                                                             |                |                            |                 | ZODCON          |               |  |  |  |
| bit 1-0    | BORV<1:0>:                        | Brown-out Res                                                                                                                                                              | et Voltage Se  | lection bit <sup>(1)</sup> |                 |                 |               |  |  |  |
|            | PIC18F2xK40                       |                                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset \<br>wn-out Reset \                                                                                                                                           | • •            | ,                          |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset V                                                                                                                                                             |                |                            |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset V                                                                                                                                                             |                |                            |                 |                 |               |  |  |  |
|            | PIC18LF2xK4                       | 0 device:                                                                                                                                                                  |                |                            |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset V                                                                                                                                                             | • •            | ,                          |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset V                                                                                                                                                             |                |                            |                 |                 |               |  |  |  |
|            |                                   | wn-out Reset \<br>wn-out Reset \                                                                                                                                           |                |                            |                 |                 |               |  |  |  |
|            |                                   |                                                                                                                                                                            |                |                            |                 |                 |               |  |  |  |
| Note 1 Th  | he higher voltage si              | ettina is recomr                                                                                                                                                           | nended for on  | eration at or a            | hove 16 MHz     |                 |               |  |  |  |

#### REGISTER 3-4: Configuration Word 2H (30 0003h): Supervisor

**Note 1:** The higher voltage setting is recommended for operation at or above 16 MHz.

| U-0                                                                                  | U-0                 | R/W-0/0                                                                | R/W-0/0 | R/W-0/0      | R/W-0/0          | R/W-0/0       | R/W-0/0      |
|--------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------|---------|--------------|------------------|---------------|--------------|
| _                                                                                    | —                   |                                                                        |         | HFTU         | N<5:0>           |               |              |
| bit 7                                                                                |                     |                                                                        |         |              |                  |               | bit C        |
| Legend:                                                                              |                     |                                                                        |         |              |                  |               |              |
| R = Readab                                                                           | ole bit             | W = Writable                                                           | bit     | U = Unimplen | nented bit, read | d as '0'      |              |
| u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all oth |                     |                                                                        |         |              |                  |               | other Resets |
| '1' = Bit is se                                                                      | et                  | '0' = Bit is clea                                                      | ared    |              |                  |               |              |
| bit 5-0                                                                              | 01 1111 =<br>•<br>• | >: HFINTOSC F<br>Maximum freque<br>Center frequenc<br>(default value). | ency    | -            | g at the calibra | ted frequency |              |

| Name                 | Bit 7          | Bit 6                | Bit 5            | Bit 4             | Bit 3           | Bit 2     | Bit 1       | Bit 0    | Register on<br>Page |
|----------------------|----------------|----------------------|------------------|-------------------|-----------------|-----------|-------------|----------|---------------------|
| INTCON               | GIE            | PEIE                 | _                | _                 | —               | _         | _           | INTEDG   | 166                 |
| PIE0                 | —              | —                    | TMR0IE           | IOCIE             | —               | INT2IE    | INT1IE      | INTOIE   | 175                 |
| PIE1                 | OSCFIE         | CSWIE                | —                | _                 | —               | —         | ADTIE       | ADIE     | 176                 |
| PIE2                 | HLVDIE         | ZCDIE                | _                | _                 | _               | —         | C2IE        | C1IE     | 177                 |
| PIE3                 | —              | —                    | RC1IE            | TX1IE             | -               | -         | BCL1IE      | SSP1IE   | 178                 |
| PIE4                 | _              | _                    | TMR6IE           | TMR5IE            | TMR4IE          | TMR3IE    | TMR2IE      | TMR1IE   | 179                 |
| PIE5                 | _              | _                    | _                | _                 | —               | TMR5GIE   | TMR3GIE     | TMR1GIE  | 180                 |
| PIE6                 | —              | —                    | —                | _                 | —               | —         | CCP2IE      | CCP1IE   | 181                 |
| PIE7                 | SCANIE         | CRCIE                | NVMIE            | _                 | —               | —         | —           | CWG1IE   | 182                 |
| PIR0                 | —              | —                    | TMR0IF           | IOCIF             | —               | INT2IF    | INT1IF      | INTOIF   | 167                 |
| PIR1                 | OSCFIF         | CSWIF                | —                | _                 | —               | —         | ADTIF       | ADIF     | 168                 |
| PIR2                 | HLVDIF         | ZCDIF <sup>(1)</sup> | _                | —                 | —               | _         | C2IF        | C1IF     | 169                 |
| PIR3                 | _              | _                    | RC1IF            | TX1IF             | —               | -         | BCL1IF      | SSP1IF   | 170                 |
| PIR4                 | —              | —                    | TMR6IF           | TMR5IF            | TMR4IF          | TMR3IF    | TMR2IF      | TMR1IF   | 170                 |
| IOCAP                | _              | _                    | IOCAP5           | IOCAP4            | IOCAP3          | IOCAP2    | IOCAP1      | IOCAP0   | 206                 |
| IOCAN                | _              | _                    | IOCAN5           | IOCAN4            | IOCAN3          | IOCAN2    | IOCAN1      | IOCAN0   | 206                 |
| IOCAF                | —              | —                    | IOCAF5           | IOCAF4            | IOCAF3          | IOCAF2    | IOCAF1      | IOCAF0   | 206                 |
| IOCCP <sup>(1)</sup> | _              | _                    | IOCCP5           | IOCCP4            | IOCCP3          | IOCCP2    | IOCCP1      | IOCCP0   | 206                 |
| IOCCN <sup>(1)</sup> | _              | _                    | IOCCN5           | IOCCN4            | IOCCN3          | IOCCN2    | IOCCN1      | IOCCN0   | 206                 |
| IOCCF <sup>(1)</sup> | —              | _                    | IOCCF5           | IOCCF4            | IOCCF3          | IOCCF2    | IOCCF1      | IOCCF0   | 206                 |
| STATUS               | —              | —                    | —                | TO                | PD              | Z         | DC          | С        | 114                 |
| VREGCON              | —              | —                    | _                | —                 | —               | _         | VREGPM      | Reserved | 60                  |
| CPUDOZE              | IDLEN          | DOZEN                | ROI              | DOE               | —               |           | DOZE<2:0>   |          | 61                  |
| WDTCON0              | —              | —                    |                  |                   | WDTPS<4:0>      |           |             | SEN      | 81                  |
| WDTCON1              | —              |                      | WDTPS<2:0>       |                   | _               |           | WINDOW<2:0> | >        | 82                  |
| Note 1: -            | – = unimplemer | nted location, re    | ad as '0'. Shade | d cells are not ι | used in Power-D | own mode. |             |          | •                   |

### TABLE 6-1: SUMMARY OF REGISTERS ASSOCIATED WITH POWER-DOWN MODE

| U-0                      | U-0               | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                        | —                 | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PWM4MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PWM3MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CCP2MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | CCP1MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | bit 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| e bit                    | W = Writable      | bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | U = Unimplem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nented bit, read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | l as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| hanged                   | x = Bit is unkn   | own                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -n/n = Value a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | t POR and BO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/Value at all o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ther Resets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| t                        | '0' = Bit is clea | ared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | q = Value dep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ends on condit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Unimplement              | ed: Read as '0'   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   | th Modulator PV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | VM4 bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   | th Madulatar DV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1/1/2 hit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0 = PWM3 m               | odule enabled     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| CCP2MD: Disa             | able Pulse-Widt   | h Modulator CC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | P2 bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1 = CCP2 module disabled |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   | Madulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   | n Modulator CC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | P1 DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                          |                   | -       -         e bit       W = Writable I         hanged       x = Bit is unkn         t       '0' = Bit is cleat         Unimplemented:       Read as '0'         PWM4MD:       Disable Pulse-Widt         1 =       PWM4 module disabled         0 =       PWM4 module enabled         PWM3MD:       Disable Pulse-Widt         1 =       PWM3 module disabled         0 =       PWM3 module enabled         CCP2MD:       Disable Pulse-Widt         1 =       CCP2 module disabled         0 =       CCP2 module enabled         CCP1MD:       Disable Pulse-Widt | -       -         e bit       W = Writable bit         hanged       x = Bit is unknown         t       '0' = Bit is cleared         Unimplemented: Read as '0'         PWM4MD: Disable Pulse-Width Modulator PW         1 = PWM4 module disabled         0 = PWM4 module enabled         PWM3MD: Disable Pulse-Width Modulator PW         1 = PWM3 module disabled         0 = PWM3 module disabled         0 = PWM3 module enabled         CCP2MD: Disable Pulse-Width Modulator CC         1 = CCP2 module disabled         0 = CCP2 module disabled         0 = CCP2 module disabled         0 = CCP1 module disabled | —       —       —       PWM4MD         e bit       W = Writable bit       U = Unimplem         hanged       x = Bit is unknown       -n/n = Value a         t       '0' = Bit is cleared       q = Value dep         Unimplemented:       Read as '0'         PWM4MD:       Disable Pulse-Width Modulator PWM4 bit         1 = PWM4 module disabled       0 = PWM4 module enabled         PWM3MD:       Disable Pulse-Width Modulator PWM3 bit         1 = PWM3 module disabled       0 = PWM3 module enabled         CCP2MD:       Disable Pulse-Width Modulator CCP2 bit         1 = CCP2 module disabled       0 = CCP2 module enabled         CCP1MD:       Disable Pulse-Width Modulator CCP1 bit         1 = CCP1 module disabled       0 = CCP1 bit | -       -       PWM4MD       PWM3MD         e bit       W = Writable bit       U = Unimplemented bit, read         hanged       x = Bit is unknown       -n/n = Value at POR and BO         t       '0' = Bit is cleared       q = Value depends on condit         Unimplemented: Read as '0'       PWM4MD: Disable Pulse-Width Modulator PWM4 bit         1 = PWM4 module disabled       0 = PWM4 module enabled         PWM3MD: Disable Pulse-Width Modulator PWM3 bit         1 = PWM3 module disabled         0 = PWM3 module enabled         CCP2MD: Disable Pulse-Width Modulator CCP2 bit         1 = CCP2 module disabled         0 = CCP2 module enabled         CCP1MD: Disable Pulse-Width Modulator CCP1 bit         1 = CCP1 module disabled | -       -       PWM4MD       PWM3MD       CCP2MD         e bit       W = Writable bit       U = Unimplemented bit, read as '0'         hanged       x = Bit is unknown       -n/n = Value at POR and BOR/Value at all of         t       '0' = Bit is cleared       q = Value depends on condition         Unimplemented:       Read as '0'         PWM4MD:       Disable Pulse-Width Modulator PWM4 bit         1 = PWM4 module disabled       0 = PWM4 module enabled         PWM3MD:       Disable Pulse-Width Modulator PWM3 bit         1 = PWM3 module disabled       0 = PWM3 module disabled         0 = PWM3 module disabled       0 = PCP2MD:         0 = CCP2MD:       Disable Pulse-Width Modulator CCP2 bit         1 = CCP2 module disabled       0 = CCP2 module disabled         0 = CCP1MD:       Disable Pulse-Width Modulator CCP1 bit         1 = CCP1 module disabled       0 = CCP1 module disabled |

#### REGISTER 7-4: PMD3: PMD CONTROL REGISTER 3

# 9.1 Register Definitions: Windowed Watchdog Timer Control

| U-0            | U-0              | R/W <sup>(3)</sup> -q/q <sup>(2)</sup>                             | R/W <sup>(3)</sup> -q/q <sup>(2)</sup> | R/W <sup>(3)</sup> -q/q <sup>(2)</sup> | R/W <sup>(3)</sup> -q/q <sup>(2)</sup> | R/W <sup>(3)</sup> -q/q <sup>(2)</sup> | R/W-0/0    |  |
|----------------|------------------|--------------------------------------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|----------------------------------------|------------|--|
| _              | -                |                                                                    |                                        | WDTPS<4:0>                             |                                        |                                        | SEN        |  |
| oit 7          | ÷                |                                                                    |                                        |                                        |                                        |                                        | bit        |  |
| Legend:        |                  |                                                                    |                                        |                                        |                                        |                                        |            |  |
| R = Readat     | ole bit          | W = Writable b                                                     | oit                                    | U = Unimplem                           | nented bit, read                       | as '0'                                 |            |  |
| u = Bit is ur  |                  | x = Bit is unkno                                                   |                                        | •                                      |                                        | R/Value at all oth                     | ner Resets |  |
| '1' = Bit is s | 0                | '0' = Bit is clea                                                  |                                        |                                        | ends on condit                         |                                        |            |  |
|                |                  |                                                                    |                                        |                                        |                                        |                                        |            |  |
| bit 7-6        | Unimpleme        | ented: Read as '0                                                  | )'                                     |                                        |                                        |                                        |            |  |
| oit 5-1        | WDTPS<4:         | 0>: Watchdog Tin                                                   | ner Prescale S                         | elect bits <sup>(1)</sup>              |                                        |                                        |            |  |
|                | Bit Value =      | Prescale Rate                                                      |                                        |                                        |                                        |                                        |            |  |
|                | 11111 <b>= F</b> | Reserved. Results                                                  | in minimum in                          | terval (1:32)                          |                                        |                                        |            |  |
|                | •                |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | •                |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | 10011 = F        | Reserved. Results                                                  | in minimum in                          | terval (1:32)                          |                                        |                                        |            |  |
|                | 10010 <b>= 1</b> | :8388608 (2 <sup>23</sup> ) (II                                    | nterval 256s n                         | ominal)                                |                                        |                                        |            |  |
|                | 10001 = <b>1</b> | :4194304 (2 <sup>22</sup> ) (li                                    | nterval 128s no                        | ominal)                                |                                        |                                        |            |  |
|                | 10000 = 1        | :2097152 (2 <sup>21</sup> ) (lı<br>:1048576 (2 <sup>20</sup> ) (lı | nterval 64s noi                        | minal)                                 |                                        |                                        |            |  |
|                | 01111 = <b>1</b> | :1048576 (2 <sup>20</sup> ) (li                                    | nterval 32s noi                        | minal)                                 |                                        |                                        |            |  |
|                |                  | :524288 (2 <sup>19</sup> ) (Int                                    |                                        |                                        |                                        |                                        |            |  |
|                | 01101 = 1        | :262144 (2 <sup>18</sup> ) (Int                                    | terval 8s nomir                        | nal)                                   |                                        |                                        |            |  |
|                |                  | :131072 (2 <sup>17</sup> ) (Int                                    |                                        |                                        |                                        |                                        |            |  |
|                |                  | :65536 (Interval 2<br>:32768 (Interval 1                           |                                        | eset value)                            |                                        |                                        |            |  |
|                |                  | :16384 (Interval 5                                                 | ,                                      | D.                                     |                                        |                                        |            |  |
|                |                  | :8192 (Interval 25                                                 |                                        |                                        |                                        |                                        |            |  |
|                |                  | :4096 (Interval 12                                                 |                                        |                                        |                                        |                                        |            |  |
|                |                  | = 1:2048 (Interval 64 ms nominal)                                  |                                        |                                        |                                        |                                        |            |  |
|                |                  | :1024 (Interval 32                                                 |                                        |                                        |                                        |                                        |            |  |
|                |                  | :512 (Interval 16                                                  |                                        |                                        |                                        |                                        |            |  |
|                |                  | :256 (Interval 8 m                                                 |                                        |                                        |                                        |                                        |            |  |
|                |                  | :128 (Interval 4 m<br>:64 (Interval 2 ms                           |                                        |                                        |                                        |                                        |            |  |
|                |                  | :32 (Interval 1 ms                                                 |                                        |                                        |                                        |                                        |            |  |
| oit 0          |                  | are Enable/Disab                                                   |                                        | g Timer bit                            |                                        |                                        |            |  |
|                | If WDTE<1:       | 0>=1x:                                                             |                                        | -                                      |                                        |                                        |            |  |
|                | This bit is ig   |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | If WDTE<1:       | <b>0&gt; =</b> 01:                                                 |                                        |                                        |                                        |                                        |            |  |
|                | 1 = WDT is       |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | 0 = WDT is       |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | If WDTE<1:       |                                                                    |                                        |                                        |                                        |                                        |            |  |
|                | This bit is ig   | nored                                                              |                                        |                                        |                                        |                                        |            |  |

### REGISTER 9-1: WDTCON0: WATCHDOG TIMER CONTROL REGISTER 0

- 2: When WDTCPS <4:0> in CONFIG3L = 11111, the Reset value of WDTPS<4:0> is 01011. Otherwise, the Reset value of WDTPS<4:0> is equal to WDTCPS<4:0> in CONFIG3L.
- 3: When WDTCPS <4:0> in CONFIG3L  $\neq$  11111, these bits are read-only.

| Address            | Name    | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2       | Bit 1   | Bit 0   | <u>Value on</u><br>POR, BOR |
|--------------------|---------|---------|---------|---------|---------|---------|-------------|---------|---------|-----------------------------|
| F26h<br>to<br>F22h | _       |         |         |         | Unimpl  | emented |             |         |         | _                           |
| F21h               | ANSELC  | ANSELC7 | ANSELC6 | ANSELC5 | ANSELC4 | ANSELC3 | ANSELC2     | ANSELC1 | ANSELC0 | 11111111                    |
| F20h               | WPUC    | WPUC7   | WPUC6   | WPUC5   | WPUC4   | WPUC3   | WPUC2       | WPUC1   | WPUC0   | 00000000                    |
| F1Fh               | ODCONC  | ODCC7   | ODCC6   | ODCC5   | ODCC4   | ODCC3   | ODCC2       | ODCC1   | ODCC0   | 00000000                    |
| F1Eh               | SLRCONC | SLRC7   | SLRC6   | SLRC5   | SLRC4   | SLRC3   | SLRC2       | SLRC1   | SLRC0   | 11111111                    |
| F1Dh               | INLVLC  | INLVLC7 | INLVLC6 | INLVLC5 | INLVLC4 | INLVLC3 | INLVLC2     | INLVLC1 | INLVLC0 | 11111111                    |
| F1Ch               | IOCCP   | IOCCP7  | IOCCP6  | IOCCP5  | IOCCP4  | IOCCP3  | IOCCP2      | IOCCP1  | IOCCP0  | 00000000                    |
| F1Bh               | IOCCN   | IOCCN7  | IOCCN6  | IOCCN5  | IOCCN4  | IOCCN3  | IOCCN2      | IOCCN1  | IOCCN0  | 00000000                    |
| F1Ah               | IOCCF   | IOCCF7  | IOCCF6  | IOCCF5  | IOCCF4  | IOCCF3  | IOCCF2      | IOCCF1  | IOCCF0  | 00000000                    |
| F19h               | ANSELB  | ANSELB7 | ANSELB6 | ANSELB5 | ANSELB4 | ANSELB3 | ANSELB2     | ANSELB1 | ANSELB0 | 11111111                    |
| F18h               | WPUB    | WPUB7   | WPUB6   | WPUB5   | WPUB4   | WPUB3   | WPUB2       | WPUB1   | WPUB0   | 00000000                    |
| F17h               | ODCONB  | ODCB7   | ODCB6   | ODCB5   | ODCB4   | ODCB3   | ODCB2       | ODCB1   | ODCB0   | 00000000                    |
| F16h               | SLRCONB | SLRB7   | SLRB6   | SLRB5   | SLRB4   | SLRB3   | SLRB2       | SLRB1   | SLRB0   | 11111111                    |
| F15h               | INLVLB  | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | INLVLB3 | INLVLB2     | INLVLB1 | INLVLB0 | 11111111                    |
| F14h               | IOCBP   | IOCBP7  | IOCBP6  | IOCBP5  | IOCBP4  | IOCBP3  | IOCBP2      | IOCBP1  | IOCBP0  | 00000000                    |
| F13h               | IOCBN   | IOCBN7  | IOCBN6  | IOCBN5  | IOCBN4  | IOCBN3  | IOCBN2      | IOCBN1  | IOCBN0  | 00000000                    |
| F12h               | IOCBF   | IOCBF7  | IOCBF6  | IOCBF5  | IOCBF4  | IOCBF3  | IOCBF2      | IOCBF1  | IOCBF0  | 00000000                    |
| F11h               | ANSELA  | ANSELA7 | ANSELA6 | ANSELA5 | ANSELA4 | ANSELA3 | ANSELA2     | ANSELA1 | ANSELA0 | 11111111                    |
| F10h               | WPUA    | WPUA7   | WPUA6   | WPUA5   | WPUA4   | WPUA3   | WPUA2       | WPUA1   | WPUA0   | 00000000                    |
| F0Fh               | ODCONA  | ODCA7   | ODCA6   | ODCA5   | ODCA4   | ODCA3   | ODCA2       | ODCA1   | ODCA0   | 00000000                    |
| F0Eh               | SLRCONA | SLRA7   | SLRA6   | SLRA5   | SLRA4   | SLRA3   | SLRA2       | SLRA1   | SLRA0   | 11111111                    |
| F0Dh               | INLVLA  | INLVLA7 | INLVLA6 | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2     | INLVLA1 | INLVLA0 | 11111111                    |
| F0Ch               | IOCAP   | IOCAP7  | IOCAP6  | IOCAP5  | IOCAP4  | IOCAP3  | IOCAP2      | IOCAP1  | IOCAP0  | 00000000                    |
| F0Bh               | IOCAN   | IOCAN7  | IOCAN6  | IOCAN5  | IOCAN4  | IOCAN3  | IOCAN2      | IOCAN1  | IOCAN0  | 00000000                    |
| F0Ah               | IOCAF   | IOCAF7  | IOCAF6  | IOCAF5  | IOCAF4  | IOCAF3  | IOCAF2      | IOCAF1  | IOCAF0  | 00000000                    |
| F09h<br>to<br>EFFh | _       |         | 1       | 1       | Unimpl  | emented | L           | 1       | L       | _                           |
| EFEh               | RC7PPS  | _       | _       | _       |         |         | RC7PPS<4:0> |         |         | 00000                       |
| EFDh               | RC6PPS  | _       | _       | _       |         |         | RC6PPS<4:0> |         |         | 00000                       |
| EFCh               | RC5PPS  | _       | _       | _       |         |         | RC5PPS<4:0> |         |         | 00000                       |
| EFBh               | RC4PPS  | _       | _       | _       |         |         | RC4PPS<4:0> |         |         | 00000                       |
| EFAh               | RC3PPS  | _       | _       | _       |         |         | RC3PPS<4:0> |         |         | 00000                       |
| EF9h               | RC2PPS  | _       | _       | _       |         |         | RC2PPS<4:0> |         |         | 00000                       |
| EF8h               | RC1PPS  | _       | _       | _       |         |         | RC1PPS<4:0> |         |         | 00000                       |
| EF7h               | RC0PPS  | _       | _       | _       |         |         | RC0PPS<4:0> |         |         | 00000                       |
| EF6h               | RB7PPS  | _       | _       | _       |         |         | RB7PPS<4:0> |         |         | 00000                       |
| EF5h               | RB6PPS  | _       | _       | _       |         |         | RB6PPS<4:0> |         |         | 00000                       |
| EF4h               | RB5PPS  | _       |         | _       |         |         | RB5PPS<4:0> |         |         | 00000                       |
| EF3h               | RB4PPS  | _       | _       | _       |         |         | RB4PPS<4:0> |         |         | 00000                       |

| TABLE 10-5: | <b>REGISTER FILE</b> | SUMMARY FOR | PIC18(L)F | 24/25K40 DEVICES | (CONTINUED) |
|-------------|----------------------|-------------|-----------|------------------|-------------|
|             |                      |             |           |                  |             |

Legend: x = unknown, u = unchanged, — = unimplemented, q = value depends on condition

Note 1: Not available on LF devices.

#### FIGURE 10-7: COMPARING ADDRESSING OPTIONS FOR BIT-ORIENTED AND BYTE-ORIENTED INSTRUCTIONS (EXTENDED INSTRUCTION SET ENABLED)

**EXAMPLE INSTRUCTION:** ADDWF, f, d, a (Opcode: 0010 01da ffff ffff)

### When 'a' = 0 and $f \ge 60h$ :

The instruction executes in Direct Forced mode. 'f' is interpreted as a location in the Access RAM between 060h and 0FFh. This is the same as locations F60h to FFFh (Bank 15) of data memory.

Locations below 60h are not available in this addressing mode.



Note that in this mode, the correct syntax is now: ADDWF [k], d where 'k' is the same as 'f'.

#### When 'a' = 1 (all values of f):

The instruction executes in Direct mode (also known as Direct Long mode). 'f' is interpreted as a location in one of the 16 banks of the data memory space. The bank is designated by the Bank Select Register (BSR). The address can be in any implemented bank in the data memory space.



#### 11.1.5 ERASING PROGRAM FLASH MEMORY

The minimum erase block is 32 or 64 words (refer to Table 11-3). Only through the use of an external programmer, or through ICSP<sup>™</sup> control, can larger blocks of program memory be bulk erased. Word erase in the Flash array is not supported.

For example, when initiating an erase sequence from a microcontroller with erase row size of 32 words, a block of 32 words (64 bytes) of program memory is erased. The Most Significant 16 bits of the TBLPTR<21:6> point to the block being erased. The TBLPTR<5:0> bits are ignored.

The NVMCON1 register commands the erase operation. The NVMREG<1:0> bits must be set to point to the Program Flash Memory. The WREN bit must be set to enable write operations. The FREE bit is set to select an erase operation.

The NVM unlock sequence described in **Section 11.1.4 "NVM Unlock Sequence**" should be used to guard against accidental writes. This is sometimes referred to as a long write.

A long write is necessary for erasing the internal Flash. Instruction execution is halted during the long write cycle. The long write is terminated by the internal programming timer.

# 11.1.5.1 Program Flash Memory Erase Sequence

The sequence of events for erasing a block of internal program memory is:

- 1. NVMREG bits of the NVMCON1 register point to PFM
- 2. Set the FREE and WREN bits of the NVMCON1 register
- 3. Perform the unlock sequence as described in Section 11.1.4 "NVM Unlock Sequence"

If the PFM address is write-protected, the WR bit will be cleared and the erase operation will not take place, WRERR is signaled in this scenario.

The operation erases the memory row indicated by masking the LSBs of the current TBLPTR.

While erasing PFM, CPU operation is suspended and it resumes when the operation is complete. Upon completion the WR bit is cleared in hardware, the NVMIF is set and an interrupt will occur if the NVMIE bit is also set.

Write latch data is not affected by erase operations and WREN will remain unchanged.

Note 1: If a write or erase operation is terminated by an unexpected event, WRERR bit will be set which the user can check to decide whether a rewrite of the location(s) is needed.

- 2: WRERR is set if WR is written to '1' while TBLPTR points to a write-protected address.
- **3:** WRERR is set if WR is written to '1' while TBLPTR points to an invalid address location (Table 10-2 and Table 11-1).

# 14.0 INTERRUPTS

The PIC18(L)F2x/4xK40 devices have multiple interrupt sources and an interrupt priority feature that allows most interrupt sources to be assigned a high or low priority level. The high priority interrupt vector is at 0008h and the low priority interrupt vector is at 0018h. A high priority interrupt event will interrupt a low priority interrupt that may be in progress.

The registers for controlling interrupt operation are:

- INTCON
- PIR1, PIR2, PIR3, PIR4, PIR5, PIR6, PIR7
- PIE1, PIE2, PIE3, PIE4, PIE5, PIE6, PIE7
- IPR1, IPR2, IPR3, IPR4, IPR5, IPR6, IPR7

It is recommended that the Microchip header files supplied with MPLAB<sup>®</sup> IDE be used for the symbolic bit names in these registers. This allows the assembler/ compiler to automatically take care of the placement of these bits within the specified register.

In general, interrupt sources have three bits to control their operation. They are:

- Flag bit to indicate that an interrupt event occurred
- Enable bit that allows program execution to branch to the interrupt vector address when the flag bit is set
- Priority bit to select high priority or low priority

## 14.1 Mid-Range Compatibility

When the IPEN bit is cleared (default state), the interrupt priority feature is disabled and interrupts are compatible with PIC<sup>®</sup> microcontroller mid-range devices. In Compatibility mode, the interrupt priority bits of the IPRx registers have no effect. The PEIE/GIEL bit of the INTCON register is the global interrupt enable for the peripherals. The PEIE/GIEL bit disables only the peripheral interrupt sources and enables the peripheral interrupt sources when the GIE/GIEH bit is also set. The GIE/GIEH bit of the INTCON register is the global interrupt enable which enables all non-peripheral interrupt sources and disables all interrupt sources, including the peripherals. All interrupts branch to address 0008h in Compatibility mode.

### 14.2 Interrupt Priority

The interrupt priority feature is enabled by setting the IPEN bit of the INTCON register. When interrupt priority is enabled the GIE/GIEH and PEIE/GIEL Global Interrupt Enable bits of Compatibility mode are replaced by the GIEH high priority, and GIEL low priority, global interrupt enables. When the IPEN bit is set, the GEIH bit of the INTCON register enables all interrupts which have their associated bit in the IPRx register set. When the GEIH bit is cleared, then all interrupt sources including those selected as low priority in the IPRx register are disabled.

When both GIEH and GIEL bits are set, all interrupts selected as low priority sources are enabled.

A high priority interrupt will vector immediately to address 00 0008h and a low priority interrupt will vector to address 00 0018h.

### 14.3 Interrupt Response

When an interrupt is responded to, the Global Interrupt Enable bit is cleared to disable further interrupts. The GIE/GIEH bit is the Global Interrupt Enable when the IPEN bit is cleared. When the IPEN bit is set, enabling interrupt priority levels, the GIEH bit is the high priority Global Interrupt Enable and the GIEL bit is the low priority Global Interrupt Enable. High priority interrupt sources can interrupt a low priority interrupt. Low priority interrupts are not processed while high priority interrupts are in progress.

The return address is pushed onto the stack and the PC is loaded with the interrupt vector address (0008h or 0018h). Once in the Interrupt Service Routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits in the INTCONx and PIRx registers. The interrupt flag bits must be cleared by software before re-enabling interrupts to avoid repeating the same interrupt.

The "return from interrupt" instruction, RETFIE, exits the interrupt routine and sets the GIE/GIEH bit (GIEH or GIEL if priority levels are used), which re-enables interrupts.

For external interrupt events, such as the INT pins or the Interrupt-on-change pins, the interrupt latency will be three to four instruction cycles. The exact latency is the same for one-cycle or two-cycle instructions. Individual interrupt flag bits are set, regardless of the status of their corresponding enable bits or the Global Interrupt Enable bit.

Note: Do not use the MOVFF instruction to modify any of the interrupt control registers while **any** interrupt is enabled. Doing so may cause erratic microcontroller behavior.

# 14.8 Register Definitions: Interrupt Control

| R/W-0/0               | R/W-0/0                                                                                              | R/W-0/0                                                                                           | U-0                                                 | U-0                                      | R/W-1/1          | R/W-1/1           | R/W-1/1       |
|-----------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------|------------------|-------------------|---------------|
| GIE/GIEH              | PEIE/GIEL                                                                                            | IPEN                                                                                              | _                                                   | -                                        | INT2EDG          | INT1EDG           | INT0EDG       |
| bit 7                 |                                                                                                      |                                                                                                   |                                                     | <b>I</b>                                 |                  | I                 | bit (         |
|                       |                                                                                                      |                                                                                                   |                                                     |                                          |                  |                   |               |
| Legend:               |                                                                                                      |                                                                                                   |                                                     |                                          |                  |                   |               |
| R = Readable          | e bit                                                                                                | W = Writable                                                                                      | bit                                                 | U = Unimple                              | mented bit, read | 1 as '0'          |               |
| -n = Value at         | POR                                                                                                  | '1' = Bit is set                                                                                  |                                                     | '0' = Bit is cle                         | eared            | x = Bit is unki   | nown          |
| bit 7                 | <u>If IPEN = 1</u> :<br>1 = En<br>0 = Dis                                                            | lobal Interrupt I<br>ables all unma<br>sables all interr                                          | sked interrup                                       | ts and cleared                           | by hardware for  | high-priority in  | terrupts only |
|                       |                                                                                                      | ables all unmas<br>ables all interru                                                              |                                                     | ts and cleared                           | by hardware for  | all interrupts    |               |
| bit 6                 | <u>If IPEN = 1</u> :<br>1 = En<br>0 = Dis<br><u>If IPEN = 0</u> :<br>1 = En                          | Peripheral Intern<br>ables all low-pr<br>sables all low-p<br>ables all unmas<br>sables all peripl | iority interrup<br>riority interrup<br>sked periphe | ots and cleared<br>ots<br>ral interrupts | by hardware fo   | r low-priority in | terrupts only |
| bit 5                 | 1 = Enable                                                                                           | pt Priority Enab<br>priority levels o<br>priority levels o                                        | n interrupts                                        |                                          |                  |                   |               |
| bit 4-3               | Unimplemen                                                                                           | ted: Read as 'd                                                                                   | )'                                                  |                                          |                  |                   |               |
| bit 2                 | 1 = Interrup                                                                                         | tternal Interrupt<br>t on rising edge<br>t on falling edge                                        | e of INT2 pin                                       | ect bit                                  |                  |                   |               |
| bit 1                 | 1 = Interrup                                                                                         | tternal Interrupt<br>t on rising edge<br>t on falling edge                                        | e of INT1 pin                                       |                                          |                  |                   |               |
| bit 0                 | 1 = Interrup                                                                                         | tternal Interrup<br>t on rising edge<br>t on falling edge                                         | e of INT0 pin                                       |                                          |                  |                   |               |
| cc<br>its<br>er<br>th | terrupt flag bits a<br>ondition occurs, r<br>corresponding<br>nable bit. User s<br>e appropriate int | egardless of the<br>enable bit or the<br>software should<br>errupt flag bits                      | e state of<br>ne global<br>d ensure<br>are clear    |                                          |                  |                   |               |

prior to enabling an interrupt. This feature

allows for software polling.

### 21.3.3 SOFTWARE INTERRUPT MODE

When the Capture mode is changed, a false capture interrupt may be generated. The user should keep the CCPxIE Interrupt Priority bit of the PIE6 register clear to avoid false interrupts. Additionally, the user should clear the CCPxIF interrupt flag bit of the PIR6 register following any change in Operating mode.

Note: Clocking Timer1 from the system clock (Fosc) should not be used in Capture mode. In order for Capture mode to recognize the trigger event on the CCPx pin, Timer1 must be clocked from the instruction clock (Fosc/4) or from an external clock source.

### 21.3.4 CCP PRESCALER

There are four prescaler settings specified by the MODE<3:0> bits of the CCPxCON register. Whenever the CCP module is turned off, or the CCP module is not in Capture mode, the prescaler counter is cleared. Any Reset will clear the prescaler counter.

Switching from one capture prescaler to another does not clear the prescaler and may generate a false interrupt. To avoid this unexpected operation, turn the module off by clearing the CCPxCON register before changing the prescaler. Example 21-1 demonstrates the code to perform this function.

#### EXAMPLE 21-1: CHANGING BETWEEN CAPTURE PRESCALERS

| BANKSEI | L CCPxCON   | ;Set Bank bits to point |
|---------|-------------|-------------------------|
|         |             | ;to CCPxCON             |
| CLRF    | CCPxCON     | ;Turn CCP module off    |
| MOVLW   | NEW_CAPT_PS | ;Load the W reg with    |
|         |             | ;the new prescaler      |
|         |             | ;move value and CCP ON  |
| MOVWF   | CCPxCON     | ;Load CCPxCON with this |
|         |             | ;value                  |
|         |             |                         |

## 21.3.5 CAPTURE DURING SLEEP

Capture mode depends upon the Timer1 module for proper operation. There are two options for driving the Timer1 module in Capture mode. It can be driven by the instruction clock (Fosc/4), or by an external clock source.

When Timer1 is clocked by Fosc/4, Timer1 will not increment during Sleep. When the device wakes from Sleep, Timer1 will continue from its previous state.

Capture mode will operate during Sleep when Timer1 is clocked by an external clock source.

### 21.4 Compare Mode

The Compare mode function described in this section is available and identical for all CCP modules.

Compare mode makes use of the 16-bit Timer1 resource. The 16-bit value of the CCPRxH:CCPRxL register pair is constantly compared against the 16-bit value of the TMRxH:TMRxL register pair. When a match occurs, one of the following events can occur:

- Toggle the CCPx output, clear TMRx
- · Toggle the CCPx output
- · Set the CCPx output
- · Clear the CCPx output
- Pulse output
- Pulse output, clear TMRx

The action on the pin is based on the value of the MODE<3:0> control bits of the CCPxCON register. At the same time, the interrupt flag CCPxIF bit is set, and an ADC conversion can be triggered, if selected.

All Compare modes can generate an interrupt and trigger an ADC conversion. When MODE =  $4 \cdot b0001$  or  $4 \cdot b1011$ , the CCP resets the TMR register pair.

Figure 21-2 shows a simplified diagram of the compare operation.

# FIGURE 21-2:

#### COMPARE MODE OPERATION BLOCK DIAGRAM



| U-0              | U-0        | U-0               | U-0  | U-0                                | R/W-0/0                 | R/W-0/0          | R/W-0/0     |  |  |
|------------------|------------|-------------------|------|------------------------------------|-------------------------|------------------|-------------|--|--|
| _                | —          | —                 | —    | —                                  | CHS<2:0> <sup>(1)</sup> |                  |             |  |  |
| bit 7 bi         |            |                   |      |                                    |                         |                  |             |  |  |
|                  |            |                   |      |                                    |                         |                  |             |  |  |
| Legend:          |            |                   |      |                                    |                         |                  |             |  |  |
| R = Readable I   | oit        | W = Writable      | bit  | U = Unimplemented bit, read as '0' |                         |                  |             |  |  |
| u = Bit is uncha | anged      | x = Bit is unkn   | iown | -n/n = Value a                     | at POR and BO           | R/Value at all o | ther Resets |  |  |
| '1' = Bit is set |            | '0' = Bit is clea | ared |                                    |                         |                  |             |  |  |
|                  |            |                   |      |                                    |                         |                  |             |  |  |
| bit 7-3          | Unimplemen | nted: Read as 'o  | י)   |                                    |                         |                  |             |  |  |

| DIT 7-3 | Unimplemented: Read as 10"                      |
|---------|-------------------------------------------------|
| bit 2-0 | CHS<2:0>: Modulator Carrier High Selection bits |
|         | See Table 25-2 for signal list                  |

#### REGISTER 25-4: MDCARL: MODULATION LOW CARRIER CONTROL REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-0/0                 | R/W-0/0 | R/W-0/0 |  |  |
|-------|-----|-----|-----|-----|-------------------------|---------|---------|--|--|
| —     | —   |     | _   | —   | CLS<2:0> <sup>(1)</sup> |         |         |  |  |
| bit 7 |     |     |     |     |                         |         | bit 0   |  |  |

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

bit 7-3 Unimplemented: Read as '0'

bit 2-0 CLS<2:0>: Modulator Carrier Low Input Selection bits See Table 25-2 for signal list

#### TABLE 25-2: MDCARH/MDCARL SELECTION MUX CONNECTIONS

|         | MDCARH |                           |                     |   | MDCARL                    |
|---------|--------|---------------------------|---------------------|---|---------------------------|
| CHS<2:0 | )>     | Connection                | CLS<2:0> Connection |   | Connection                |
| 111     | 7      | PWM4 OUT                  | 111                 | 7 | PWM4 OUT                  |
| 110     | 6      | PWM3 OUT                  | 110                 | 6 | PWM3 OUT                  |
| 101     | 5      | CCP2 OUT                  | 101                 | 5 | CCP2 OUT                  |
| 100     | 4      | CCP1 OUT                  | 100                 | 4 | CCP1 OUT                  |
| 011     | 3      | CLKREF output             | 011                 | 3 | CLKREF output             |
| 010     | 2      | HFINTOSC                  | 010                 | 2 | HFINTOSC                  |
| 001     | 1      | FOSC (system clock)       | 001                 | 1 | FOSC (system clock)       |
| 000     | 0      | Pin selected by MDCARHPPS | 000                 | 0 | Pin selected by MDCARLPPS |

© 2016-2017 Microchip Technology Inc.

### 27.5.1.5 Synchronous Master Reception

Data is received at the RXx/DTx pin. The RXx/DTx pin output driver is automatically disabled when the EUSART is configured for synchronous master receive operation.

In Synchronous mode, reception is enabled by setting either the Single Receive Enable bit (SREN of the RCxSTA register) or the Continuous Receive Enable bit (CREN of the RCxSTA register).

When SREN is set and CREN is clear, only as many clock cycles are generated as there are data bits in a single character. The SREN bit is automatically cleared at the completion of one character. When CREN is set, clocks are continuously generated until CREN is cleared. If CREN is cleared in the middle of a character the CK clock stops immediately and the partial character is discarded. If SREN and CREN are both set, then SREN is cleared at the completion of the first character and CREN takes precedence.

To initiate reception, set either SREN or CREN. Data is sampled at the RXx/DTx pin on the trailing edge of the TX/CK clock pin and is shifted into the Receive Shift Register (RSR). When a complete character is received into the RSR, the RCxIF bit is set and the character is automatically transferred to the two character receive FIFO. The Least Significant eight bits of the top character in the receive FIFO are available in RCxREG. The RCxIF bit remains set as long as there are unread characters in the receive FIFO.

| Note: | If the RX/DT function is on an analog pin, |
|-------|--------------------------------------------|
|       | the corresponding ANSEL bit must be        |
|       | cleared for the receiver to function.      |

### 27.5.1.6 Slave Clock

Synchronous data transfers use a separate clock line, which is synchronous with the data. A device configured as a slave receives the clock on the TX/CK line. The TXx/CKx pin output driver is automatically disabled when the device is configured for synchronous slave transmit or receive operation. Serial data bits change on the leading edge to ensure they are valid at the trailing edge of each clock. One data bit is transferred for each clock cycle. Only as many clock cycles should be received as there are data bits.

**Note:** If the device is configured as a slave and the TX/CK function is on an analog pin, the corresponding ANSEL bit must be cleared.

### 27.5.1.7 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before RCxREG is read to access the FIFO. When this happens the OERR bit of the RCxSTA register is set. Previous data in the FIFO will not be overwritten. The two characters in the FIFO buffer can be read, however, no additional characters will be received until the error is cleared. The OERR bit can only be cleared by clearing the overrun condition. If the overrun error occurred when the SREN bit is set and CREN is clear then the error is cleared by reading RCxREG. If the overrun occurred when the CREN bit is set then the error condition is cleared by either clearing the CREN bit of the RCxSTA register or by clearing the SPEN bit which resets the EUSART.

#### 27.5.1.8 Receiving 9-Bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCxSTA register is set the EUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCxSTA register is the ninth, and Most Significant, data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCxREG.

# 27.5.1.9 Synchronous Master Reception Setup:

- Initialize the SPxBRGH:SPxBRGL register pair for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Clear the ANSEL bit for the RXx pin (if applicable).
- 3. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 4. Ensure bits CREN and SREN are clear.
- 5. If interrupts are desired, set the RCxIE bit of the PIE3 register and the GIE and PEIE bits of the INTCON register.
- 6. If 9-bit reception is desired, set bit RX9.
- 7. Start reception by setting the SREN bit or for continuous reception, set the CREN bit.
- Interrupt flag bit RCxIF will be set when reception of a character is complete. An interrupt will be generated if the enable bit RCxIE was set.
- 9. Read the RCxSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 10. Read the 8-bit received data by reading the RCxREG register.
- 11. If an overrun error occurs, clear the error by either clearing the CREN bit of the RCxSTA register or by clearing the SPEN bit which resets the EUSART.

| Field           | Description                                                                                                                                                     |  |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| a               | RAM access bit<br>a = 0: RAM location in Access RAM (BSR register is ignored)<br>a = 1: RAM bank is specified by BSR register                                   |  |  |  |  |  |  |  |
| bbb             | Bit address within an 8-bit file register (0 to 7).                                                                                                             |  |  |  |  |  |  |  |
| BSR             | Bank Select Register. Used to select the current RAM bank.                                                                                                      |  |  |  |  |  |  |  |
| C, DC, Z, OV, N | ALU Status bits: Carry, Digit Carry, Zero, Overflow, Negative.                                                                                                  |  |  |  |  |  |  |  |
| d               | Destination select bit<br>d = 0: store result in WREG<br>d = 1: store result in file register f                                                                 |  |  |  |  |  |  |  |
| dest            | Destination: either the WREG register or the specified register file location.                                                                                  |  |  |  |  |  |  |  |
| f               | 8-bit Register file address (00h to FFh) or 2-bit FSR designator (0h to 3h).                                                                                    |  |  |  |  |  |  |  |
| fs              | 12-bit Register file address (000h to FFFh). This is the source address.                                                                                        |  |  |  |  |  |  |  |
| fd              | 12-bit Register file address (000h to FFFh). This is the destination address.                                                                                   |  |  |  |  |  |  |  |
| GIE             | Global Interrupt Enable bit.                                                                                                                                    |  |  |  |  |  |  |  |
| k               | Literal field, constant data or label (may be either an 8-bit, 12-bit or a 20-bit value).                                                                       |  |  |  |  |  |  |  |
| label           | Label name.                                                                                                                                                     |  |  |  |  |  |  |  |
| mm              | The mode of the TBLPTR register for the table read and table write instructions.<br>Only used with table read and table write instructions:                     |  |  |  |  |  |  |  |
| *               | No change to register (such as TBLPTR with table reads and writes)                                                                                              |  |  |  |  |  |  |  |
| *+              | Post-Increment register (such as TBLPTR with table reads and writes)                                                                                            |  |  |  |  |  |  |  |
| *_              | Post-Decrement register (such as TBLPTR with table reads and writes)                                                                                            |  |  |  |  |  |  |  |
| +*              | Pre-Increment register (such as TBLPTR with table reads and writes)                                                                                             |  |  |  |  |  |  |  |
| n               | The relative address (2's complement number) for relative branch instructions or the direct address for CALL/BRANCH and RETURN instructions.                    |  |  |  |  |  |  |  |
| PC              | Program Counter.                                                                                                                                                |  |  |  |  |  |  |  |
| PCL             | Program Counter Low Byte.                                                                                                                                       |  |  |  |  |  |  |  |
| PCH             | Program Counter High Byte.                                                                                                                                      |  |  |  |  |  |  |  |
| PCLATH          | Program Counter High Byte Latch.                                                                                                                                |  |  |  |  |  |  |  |
| PCLATU          | Program Counter Upper Byte Latch.                                                                                                                               |  |  |  |  |  |  |  |
| PD              | Power-down bit.                                                                                                                                                 |  |  |  |  |  |  |  |
| PRODH           | Product of Multiply High Byte.                                                                                                                                  |  |  |  |  |  |  |  |
| PRODL           | Product of Multiply Low Byte.                                                                                                                                   |  |  |  |  |  |  |  |
| S               | Fast Call/Return mode select bit<br>s = 0: do not update into/from shadow registers<br>s = 1: certain registers loaded into/from shadow registers (Fast mode)   |  |  |  |  |  |  |  |
| TBLPTR          | 21-bit Table Pointer (points to a Program Memory location).                                                                                                     |  |  |  |  |  |  |  |
| TABLAT          | 8-bit Table Latch.                                                                                                                                              |  |  |  |  |  |  |  |
| TO              | Time-out bit.                                                                                                                                                   |  |  |  |  |  |  |  |
| TOS             | Top-of-Stack.                                                                                                                                                   |  |  |  |  |  |  |  |
| u               | Unused or unchanged.                                                                                                                                            |  |  |  |  |  |  |  |
| WDT             | Watchdog Timer.                                                                                                                                                 |  |  |  |  |  |  |  |
| WREG            | Working register (accumulator).                                                                                                                                 |  |  |  |  |  |  |  |
| x               | Don't care ('0' or '1'). The assembler will generate code with $x = 0$ . It is the recommended form of use for compatibility with all Microchip software tools. |  |  |  |  |  |  |  |
| zs              | 7-bit offset value for indirect addressing of register files (source).                                                                                          |  |  |  |  |  |  |  |
| z <sub>d</sub>  | 7-bit offset value for indirect addressing of register files (destination).                                                                                     |  |  |  |  |  |  |  |
| { }             | Optional argument.                                                                                                                                              |  |  |  |  |  |  |  |
| [text]          | Indicates an indexed address.                                                                                                                                   |  |  |  |  |  |  |  |
| (text)          | The contents of text.                                                                                                                                           |  |  |  |  |  |  |  |
| [expr] <n></n>  | Specifies bit n of the register indicated by the pointer expr.                                                                                                  |  |  |  |  |  |  |  |
| →               | Assigned to.                                                                                                                                                    |  |  |  |  |  |  |  |
| < >             | Register bit field.                                                                                                                                             |  |  |  |  |  |  |  |
| E               | In the set of.                                                                                                                                                  |  |  |  |  |  |  |  |
| italics         | User defined term (font is Courier).                                                                                                                            |  |  |  |  |  |  |  |

TABLE 35-1: OPCODE FIELD DESCRIPTIONS

| BNC         |                                                                  | Branch if Not Carry                                                        |                                                                                         |                                       | BNN                                                                          | Branch if                                                                                                                                                                                                                                                                  | Branch if Not Negative                    |                 |  |  |
|-------------|------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|--|--|
| Syntax:     |                                                                  | BNC n                                                                      |                                                                                         |                                       | Syntax:                                                                      | BNN n                                                                                                                                                                                                                                                                      | BNN n                                     |                 |  |  |
| Operands    | :                                                                | -128 ≤ n ≤ 1                                                               | 27                                                                                      |                                       | Operands:                                                                    | -128 ≤ n ≤                                                                                                                                                                                                                                                                 | 127                                       |                 |  |  |
| Operation   | :                                                                | if CARRY b<br>(PC) + 2 + 2                                                 |                                                                                         |                                       | Operation:                                                                   | if NEGATI\<br>(PC) + 2 +                                                                                                                                                                                                                                                   |                                           |                 |  |  |
| Status Affe | ected:                                                           | None                                                                       |                                                                                         |                                       | Status Affected:                                                             | None                                                                                                                                                                                                                                                                       |                                           |                 |  |  |
| Encoding:   |                                                                  | 1110                                                                       | 0011 nni                                                                                | nn nnnn                               | Encoding:                                                                    | 1110                                                                                                                                                                                                                                                                       | 0111 nr                                   | inn nnnn        |  |  |
| Descriptio  | n:                                                               | will branch.<br>The 2's con<br>added to the<br>incremented<br>instruction, | nplement num<br>e PC. Since th<br>d to fetch the r<br>the new addre<br>n. This instruct | e PC will have<br>next<br>ess will be | Description:                                                                 | cription:<br>If the NEGATIVE bit is '0', then program will branch.<br>The 2's complement number '2r<br>added to the PC. Since the PC v<br>incremented to fetch the next<br>instruction, the new address will<br>PC + 2 + 2n. This instruction is 1<br>2-cycle instruction. |                                           |                 |  |  |
| Words:      |                                                                  | 1                                                                          |                                                                                         |                                       | Words:                                                                       | 1                                                                                                                                                                                                                                                                          |                                           |                 |  |  |
| Cycles:     |                                                                  | 1(2)                                                                       |                                                                                         |                                       | Cycles:                                                                      | 1(2)                                                                                                                                                                                                                                                                       |                                           |                 |  |  |
| Q Cycle A   | Activity:                                                        |                                                                            |                                                                                         |                                       | Q Cycle Activity:<br>If Jump:                                                |                                                                                                                                                                                                                                                                            |                                           |                 |  |  |
|             | Q1                                                               | Q2                                                                         | Q3                                                                                      | Q4                                    | Q1                                                                           | Q2                                                                                                                                                                                                                                                                         | Q3                                        | Q4              |  |  |
| De          | ecode                                                            | Read literal<br>'n'                                                        | Process<br>Data                                                                         | Write to PC                           | Decode                                                                       | Read literal<br>'n'                                                                                                                                                                                                                                                        | Process<br>Data                           | Write to PC     |  |  |
| ор          | No<br>eration                                                    | No<br>operation                                                            | No<br>operation                                                                         | No<br>operation                       | No<br>operation                                                              | No<br>operation                                                                                                                                                                                                                                                            | No<br>operation                           | No<br>operation |  |  |
| If No Jum   | ıp:                                                              |                                                                            |                                                                                         |                                       | If No Jump:                                                                  |                                                                                                                                                                                                                                                                            |                                           |                 |  |  |
|             | Q1                                                               | Q2                                                                         | Q3                                                                                      | Q4                                    | Q1                                                                           | Q2                                                                                                                                                                                                                                                                         | Q3                                        | Q4              |  |  |
| De          | ecode                                                            | Read literal<br>'n'                                                        | Process<br>Data                                                                         | No<br>operation                       | Decode                                                                       | Read literal<br>'n'                                                                                                                                                                                                                                                        | Process<br>Data                           | No<br>operation |  |  |
| Example:    |                                                                  | HERE                                                                       | BNC Jump                                                                                |                                       | Example:                                                                     | HERE                                                                                                                                                                                                                                                                       | BNN Jum                                   | ò               |  |  |
| After       | re Instruc<br>PC<br>Instructio<br>If CARR<br>PC<br>If CARR<br>PC | = ade<br>on<br>f = 0;<br>= ade<br>f = 1;                                   | dress (HERE<br>dress (Jump)<br>dress (HERE                                              |                                       | Before Instru<br>PC<br>After Instruc<br>If NEG,<br>P(<br>If NEG,<br>P(<br>P) | = ac<br>tion<br>ATIVE = 0;<br>C = ac<br>ATIVE = 1;                                                                                                                                                                                                                         | dress (HERE<br>dress (Jumg<br>dress (HERE | 5)              |  |  |

| BTG                                         | Bit Toggle f                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | BOV                                                                | Branch if Overflow                                                      |                                                                                      |                                                        |  |  |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------|--|--|
| Syntax:                                     | BTG f, b {,a}                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Syntax:                                                            | BOV n                                                                   | n                                                                                    |                                                        |  |  |
| Operands:                                   | $0 \leq f \leq 255$                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Operands:                                                          | -128 ≤ n ≤ ′                                                            | 127                                                                                  |                                                        |  |  |
|                                             | 0 ≤ b < 7<br>a ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Operation:                                                         | if OVERFL0<br>(PC) + 2 + 2                                              | OW bit is '1'<br>2n → PC                                                             |                                                        |  |  |
| Operation:                                  | $(\overline{f} < b >) \to f < b >$                                                                                                                                                                                                                                                                                                                                                                                                                                            | Status Affected:                                                   | None                                                                    |                                                                                      |                                                        |  |  |
| Status Affected:                            | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Encoding:                                                          | 1110                                                                    | 0100 nn                                                                              | nn nnnn                                                |  |  |
| Encoding:<br>Description:                   | 0111bbbaffffffffBit 'b' in data memory location 'f' is<br>inverted.If 'a' is '0', the Access Bank is selected.If 'a' is '0', the BSR is used to select the<br>GPR bank.GPR bank.If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See Sec-<br>tion 35.2.3 "Byte-Oriented and Bit-<br>Oriented Instructions in Indexed Lit-<br>eral Offset Mode" for details. | Description:<br>Words:<br>Cycles:<br>Q Cycle Activity:<br>If Jump: | program wi<br>The 2's con<br>added to the<br>incremente<br>instruction, | nplement num<br>e PC. Since th<br>d to fetch the<br>the new addro<br>n. This instruc | iber '2n' is<br>le PC will have<br>next<br>ess will be |  |  |
| Words:                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Q1                                                                 | Q2                                                                      | Q3                                                                                   | Q4                                                     |  |  |
| Cycles:                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Decode                                                             | Read literal<br>'n'                                                     | Process<br>Data                                                                      | Write to PC                                            |  |  |
| Q Cycle Activity                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No                                                                 | No                                                                      | No                                                                                   | No                                                     |  |  |
| Q1<br>Decode                                | Q2Q3Q4ReadProcessWriteregister 'f'Dataregister 'f'                                                                                                                                                                                                                                                                                                                                                                                                                            | operation<br>If No Jump:<br>Q1                                     | operation<br>Q2                                                         | operation<br>Q3                                                                      | operation<br>Q4                                        |  |  |
| Example:                                    | BTG PORTC, 4, 0                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Decode                                                             | Read literal<br>'n'                                                     | Process<br>Data                                                                      | No<br>operation                                        |  |  |
| Before Inst<br>PORT<br>After Instru<br>PORT | C = 0111 0101 [75h]<br>ction:                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PC                                                                 | = ad<br>on<br>FLOW = 1;<br>= ad<br>FLOW = 0;                            | BOV Jump<br>dress (HERE<br>dress (Jump<br>dress (HERE                                | )                                                      |  |  |

## 35.2 Extended Instruction Set

In addition to the standard 75 instructions of the PIC18 instruction set, PIC18(L)F2x/4xK40 devices also provide an optional extension to the core CPU functionality. The added features include eight additional instructions that augment indirect and indexed addressing operations and the implementation of Indexed Literal Offset Addressing mode for many of the standard PIC18 instructions.

The additional features of the extended instruction set are disabled by default. To enable them, users must set the XINST Configuration bit.

The instructions in the extended set can all be classified as literal operations, which either manipulate the File Select Registers, or use them for indexed addressing. Two of the instructions, ADDFSR and SUBFSR, each have an additional special instantiation for using FSR2. These versions (ADDULNK and SUBULNK) allow for automatic return after execution.

The extended instructions are specifically implemented to optimize re-entrant program code (that is, code that is recursive or that uses a software stack) written in high-level languages, particularly C. Among other things, they allow users working in high-level languages to perform certain operations on data structures more efficiently. These include:

- dynamic allocation and deallocation of software stack space when entering and leaving subroutines
- function pointer invocation
- software Stack Pointer manipulation
- manipulation of variables located in a software stack

A summary of the instructions in the extended instruction set is provided in Table 35-3. Detailed descriptions are provided in **Section 35.2.2** "**Extended Instruction Set**". The opcode field descriptions in Table 35-1 apply to both the standard and extended PIC18 instruction sets.

| Note: | The instruction set extension and the       |
|-------|---------------------------------------------|
|       | Indexed Literal Offset Addressing mode      |
|       | were designed for optimizing applications   |
|       | written in C; the user may likely never use |
|       | these instructions directly in assembler.   |
|       | The syntax for these commands is pro-       |
|       | vided as a reference for users who may be   |
|       | reviewing code that has been generated      |
|       | by a compiler.                              |

### 35.2.1 EXTENDED INSTRUCTION SYNTAX

Most of the extended instructions use indexed arguments, using one of the File Select Registers and some offset to specify a source or destination register. When an argument for an instruction serves as part of indexed addressing, it is enclosed in square brackets ("[]"). This is done to indicate that the argument is used as an index or offset. MPASM<sup>™</sup> Assembler will flag an error if it determines that an index or offset value is not bracketed.

When the extended instruction set is enabled, brackets are also used to indicate index arguments in byteoriented and bit-oriented instructions. This is in addition to other changes in their syntax. For more details, see Section 35.2.3.1 "Extended Instruction Syntax with Standard PIC18 Commands".

**Note:** In the past, square brackets have been used to denote optional arguments in the PIC18 and earlier instruction sets. In this text and going forward, optional arguments are denoted by braces ("{ }").

| Mnemonic,<br>Operands |                                 | Description                              | Cycles | 16-Bit Instruction Word |      |      |      | Status   |
|-----------------------|---------------------------------|------------------------------------------|--------|-------------------------|------|------|------|----------|
|                       |                                 | Description                              | Cycles | MSb                     |      |      | LSb  | Affected |
| ADDFSR                | f, k                            | Add literal to FSR                       | 1      | 1110                    | 1000 | ffkk | kkkk | None     |
| ADDULNK               | k                               | Add literal to FSR2 and return           | 2      | 1110                    | 1000 | 11kk | kkkk | None     |
| CALLW                 |                                 | Call subroutine using WREG               | 2      | 0000                    | 0000 | 0001 | 0100 | None     |
| MOVSF                 | z <sub>s</sub> , f <sub>d</sub> | Move z <sub>s</sub> (source) to 1st word | 2      | 1110                    | 1011 | 0zzz | ZZZZ | None     |
|                       |                                 | f <sub>d</sub> (destination) 2nd word    |        | 1111                    | ffff | ffff | ffff |          |
| MOVSS                 | z <sub>s</sub> , z <sub>d</sub> | Move z <sub>s</sub> (source) to 1st word | 2      | 1110                    | 1011 | lzzz | ZZZZ | None     |
|                       |                                 | z <sub>d</sub> (destination) 2nd word    |        | 1111                    | xxxx | XZZZ | ZZZZ |          |
| PUSHL                 | k                               | Store literal at FSR2,                   | 1      | 1110                    | 1010 | kkkk | kkkk | None     |
|                       |                                 | decrement FSR2                           |        |                         |      |      |      |          |
| SUBFSR                | f, k                            | Subtract literal from FSR                | 1      | 1110                    | 1001 | ffkk | kkkk | None     |
| SUBULNK               | k                               | Subtract literal from FSR2 and           | 2      | 1110                    | 1001 | 11kk | kkkk | None     |
|                       |                                 | return                                   |        |                         |      |      |      |          |

### TABLE 35-3: EXTENSIONS TO THE PIC18 INSTRUCTION SET

| CALLW                                             | Subroutir                                                                                                                            | Subroutine Call Using WREG                                                                                                                                                             |                                                                                                                        |               | ′SF                                                                                                                      | Move Indexed to f                                                                                                                                                 |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:                                           | CALLW                                                                                                                                |                                                                                                                                                                                        |                                                                                                                        | Synta         | IX:                                                                                                                      | MOVSF                                                                                                                                                             | [z <sub>s</sub> ], f <sub>d</sub>                                                                                                                                                                             |                                                                                                                                                                |  |  |
| Operands:                                         | None                                                                                                                                 |                                                                                                                                                                                        |                                                                                                                        | Operation     | ands:                                                                                                                    | $0 \le z_s \le 12$                                                                                                                                                | 27                                                                                                                                                                                                            |                                                                                                                                                                |  |  |
| Operation:                                        | $(PC + 2) \rightarrow$                                                                                                               |                                                                                                                                                                                        |                                                                                                                        |               |                                                                                                                          |                                                                                                                                                                   | 95                                                                                                                                                                                                            |                                                                                                                                                                |  |  |
|                                                   | $(W) \rightarrow PCL$<br>(PCLATH) -                                                                                                  |                                                                                                                                                                                        |                                                                                                                        | •             | Operation: $((FSR2) + z_s) \rightarrow f_d$                                                                              |                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
|                                                   | (PCLATU) -                                                                                                                           |                                                                                                                                                                                        |                                                                                                                        |               | s Affected:                                                                                                              | None                                                                                                                                                              |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
| Status Affected:                                  | None                                                                                                                                 |                                                                                                                                                                                        |                                                                                                                        | Enco<br>1st w | ding:<br>ord (source)                                                                                                    | 1110                                                                                                                                                              | 1011 Oz                                                                                                                                                                                                       | zz zzzz <sub>s</sub>                                                                                                                                           |  |  |
| Encoding:                                         | 0000                                                                                                                                 | 0000 000                                                                                                                                                                               | 01 0100                                                                                                                |               | vord (destin.)                                                                                                           | 1111                                                                                                                                                              |                                                                                                                                                                                                               | ff ffffd                                                                                                                                                       |  |  |
| Description                                       | pushed ont<br>contents of<br>existing val<br>contents of<br>latched into<br>respectively<br>executed as<br>new next in<br>Unlike CAL | turn address (<br>o the return sta<br>W are written<br>ue is discarded<br>PCLATH and<br>PCH and PCI<br>y. The second<br>s a NOP instruction is fet<br>L, there is no<br>Status or BSR. | ack. Next, the<br>to PCL; the<br>d. Then, the<br>PCLATU are<br>J,<br>cycle is<br>ction while the<br>ched.<br>option to | Desc          | ription:                                                                                                                 | moved to<br>actual add<br>determine<br>offset 'z <sub>s</sub> ' i<br>FSR2. The<br>register is<br>'f <sub>d</sub> ' in the s<br>can be an<br>space (00<br>The MOVS | nts of the sound<br>destination reg<br>ress of the sound<br>d by adding the<br>n the first word<br>a address of th<br>specified by th<br>econd word. B<br>ywhere in the 4<br>Dh to FFFh).<br>F instruction ca | ister 'f <sub>d</sub> '. The<br>urce register is<br>e 7-bit literal<br>to the value of<br>e destination<br>e 12-bit literal<br>oth addresses<br>1096-byte data |  |  |
| Words:                                            | 1                                                                                                                                    |                                                                                                                                                                                        |                                                                                                                        |               |                                                                                                                          | PCL, TOS<br>destination                                                                                                                                           | U, TOSH or TO                                                                                                                                                                                                 | OSL as the                                                                                                                                                     |  |  |
| Cycles:                                           | 2                                                                                                                                    |                                                                                                                                                                                        |                                                                                                                        |               |                                                                                                                          |                                                                                                                                                                   | tant source ad                                                                                                                                                                                                | dress points t                                                                                                                                                 |  |  |
| Q Cycle Activity:                                 |                                                                                                                                      |                                                                                                                                                                                        |                                                                                                                        |               |                                                                                                                          |                                                                                                                                                                   | addressing re<br>ned will be 00                                                                                                                                                                               | •                                                                                                                                                              |  |  |
| Q1                                                | Q2                                                                                                                                   | Q3                                                                                                                                                                                     | Q4                                                                                                                     | Word          | e.                                                                                                                       | 2                                                                                                                                                                 |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
| Decode                                            | Read<br>WREG                                                                                                                         | PUSH PC to<br>stack                                                                                                                                                                    | No<br>operation                                                                                                        | Cycle         |                                                                                                                          | 2                                                                                                                                                                 |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
| No                                                | No                                                                                                                                   | No                                                                                                                                                                                     | No                                                                                                                     |               | cle Activity:                                                                                                            | -                                                                                                                                                                 |                                                                                                                                                                                                               |                                                                                                                                                                |  |  |
| operation                                         | operation                                                                                                                            | operation                                                                                                                                                                              | operation                                                                                                              | <u> </u>      | Q1                                                                                                                       | Q2                                                                                                                                                                | Q3                                                                                                                                                                                                            | Q4                                                                                                                                                             |  |  |
|                                                   |                                                                                                                                      |                                                                                                                                                                                        |                                                                                                                        |               | Decode                                                                                                                   | Determine                                                                                                                                                         | Determine                                                                                                                                                                                                     | Read                                                                                                                                                           |  |  |
| Example:                                          | HERE                                                                                                                                 | CALLW                                                                                                                                                                                  |                                                                                                                        |               | Decede                                                                                                                   | source add                                                                                                                                                        |                                                                                                                                                                                                               | source reg                                                                                                                                                     |  |  |
| Before Instru<br>PC<br>PCLAT<br>PCLAT<br>W        | = address<br>H = 10h                                                                                                                 | G (HERE)                                                                                                                                                                               |                                                                                                                        |               | Decode                                                                                                                   | No<br>operation<br>No dummy<br>read                                                                                                                               | No<br>operation                                                                                                                                                                                               | Write<br>register 'f'<br>(dest)                                                                                                                                |  |  |
| After Instruc<br>PC<br>TOS<br>PCLAT<br>PCLAT<br>W | = 001006<br>= address<br>H = 10h                                                                                                     | h<br>3 (HERE + 2                                                                                                                                                                       | )                                                                                                                      |               | nple:<br>Before Instruct<br>FSR2<br>Contents<br>of 85h<br>REG2<br>After Instructio<br>FSR2<br>Contents<br>of 85h<br>REG2 | = 8<br>= 3<br>= 1<br>on<br>= 8<br>= 3                                                                                                                             | [05h], REG<br>Dh<br>3h<br>Ih<br>Dh<br>3h<br>3h                                                                                                                                                                | 2                                                                                                                                                              |  |  |

| <b>TABLE 37-23</b> : | SPI MODE REQUIREMENTS |
|----------------------|-----------------------|
|----------------------|-----------------------|

| Standard Operating Conditions (unless otherwise stated) |                       |                                                                       |              |      |      |       |                                  |  |
|---------------------------------------------------------|-----------------------|-----------------------------------------------------------------------|--------------|------|------|-------|----------------------------------|--|
| Param<br>No.                                            | Symbol                | Characteristic                                                        | Min.         | Тур† | Max. | Units | Conditions                       |  |
| SP70*                                                   | TssL2scH,<br>TssL2scL | $\overline{SS}\downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ input | 2.25*Tcy     | —    | _    | ns    |                                  |  |
| SP71*                                                   | TscH                  | SCK input high time (Slave mode)                                      | Tcy + 20     |      | _    | ns    |                                  |  |
| SP72*                                                   | TscL                  | SCK input low time (Slave mode)                                       | Tcy + 20     | _    | _    | ns    |                                  |  |
| SP73*                                                   | TDIV2scH,<br>TDIV2scL | Setup time of SDI data input to SCK edge                              | 100          | —    | —    | ns    |                                  |  |
| SP74*                                                   | TscH2dlL,<br>TscL2dlL | Hold time of SDI data input to SCK edge                               | 100          | —    | —    | ns    |                                  |  |
| SP75* TDOR                                              | TDOR                  | SDO data output rise time                                             |              | 10   | 25   | ns    | $3.0V \leq V\text{DD} \leq 5.5V$ |  |
|                                                         |                       |                                                                       |              | 25   | 50   | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP76*                                                   | TdoF                  | SDO data output fall time                                             |              | 10   | 25   | ns    |                                  |  |
| SP77*                                                   | TssH2doZ              | SS↑ to SDO output high-impedance                                      | 10           |      | 50   | ns    |                                  |  |
| SP78*                                                   | TscR                  | SCK output rise time<br>(Master mode)                                 |              | 10   | 25   | ns    | $3.0V \leq V\text{DD} \leq 5.5V$ |  |
|                                                         |                       |                                                                       |              | 25   | 50   | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP79*                                                   | TscF                  | SCK output fall time (Master mode)                                    |              | 10   | 25   | ns    |                                  |  |
| SP80*                                                   | TscH2doV,<br>TscL2doV | SDO data output valid after SCK edge                                  |              |      | 50   | ns    | $3.0V \leq V\text{DD} \leq 5.5V$ |  |
|                                                         |                       |                                                                       |              | _    | 145  | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP81*                                                   | TDOV2scH,<br>TDOV2scL | SDO data output setup to SCK edge                                     | 1 Tcy        | —    | —    | ns    |                                  |  |
| SP82*                                                   | TssL2doV              | SDO data output valid after $\overline{SS}\downarrow$ edge            | _            | _    | 50   | ns    |                                  |  |
| SP83*                                                   | TscH2ssH,<br>TscL2ssH | SS ↑ after SCK edge                                                   | 1.5 Tcy + 40 | —    | —    | ns    |                                  |  |

These parameters are characterized but not tested.

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