



#### 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) | 2.3V ~ 5.5V                                                                 |
| Data Converters            | A/D 35x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                              |
| Supplier Device Package    | 28-SSOP                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f25k40t-i-ss |

Email: info@E-XFL.COM

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

| REGISTER 3-13: RE |           | SION ID: REVIS   | SION ID R | EGISTER          |      |                 |       |
|-------------------|-----------|------------------|-----------|------------------|------|-----------------|-------|
| R                 | R         | R                | R         | R                | R    | R               | R     |
| 1                 | 0         | 1                | 0         |                  | MJR  | REV<5:2>        |       |
| bit 15            |           |                  |           |                  |      |                 | bit 8 |
|                   |           |                  |           |                  |      |                 |       |
| R                 | R         | R                | R         | R                | R    | R               | R     |
| MJRREV<           |           |                  | MNRR      | EV<5:0>          |      |                 |       |
| bit 7             |           |                  |           |                  |      |                 | bit 0 |
| Legend:           |           |                  |           |                  |      |                 |       |
| R = Readable bit  |           | '1' = Bit is set |           | 0' = Bit is clea | ared | x = Bit is unki | nown  |
| bit 15-12 R       | ead as '1 | 010'             |           |                  |      |                 |       |

 bit 10 12
 These bits are fixed with value '1010' for all devices in this family.

 bit 11-6
 MJRREV<5:0>: Major Revision ID bits

 These bits are used to identify a major revision. A major revision is indicated by an all-layer revision (A0, B0, C0, etc.).

 Revision A = 6 'b00\_0000

 bit 5-0

 MNRREV<5:0>: Minor Revision ID bits

bit 5-0 **MNRREV<5:0>:** Minor Revision ID bits These bits are used to identify a minor revision.

| R-q/q            | R-q/q                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R-q/q              | R-q/q           | R-q/q            | R-q/q             | U-0              | R-q/q        |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------|------------------|-------------------|------------------|--------------|
| EXTOR            | HFOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | MFOR               | LFOR            | SOR              | ADOR              | —                | PLLR         |
| bit 7            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                 |                  |                   |                  | bit 0        |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                 |                  |                   |                  |              |
| Legend:          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                 |                  |                   |                  |              |
| R = Readable     | bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W = Writable       | bit             | U = Unimple      | mented bit, read  | d as '0'         |              |
| u = Bit is unch  | anged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | x = Bit is unkr    | iown            | -n/n = Value     | at POR and BC     | R/Value at all o | other Resets |
| '1' = Bit is set |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | '0' = Bit is clea  | ared            | q = Reset va     | lue is determine  | ed by hardware   | •            |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                 |                  |                   |                  |              |
| bit 7            | EXTOR: EXT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | OSC (external)     | Oscillator Re   | ady bit          |                   |                  |              |
|                  | 1 = The os                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | cillator is ready  | to be used      | t vot roodv to k |                   |                  |              |
| hit C            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    | ableu, or is no | i yel ready to i | be used           |                  |              |
| DILO             | 1 = The ose                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | cillator is ready  | to be used      |                  |                   |                  |              |
|                  | 0 = The osc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | illator is not en  | abled, or is no | t yet ready to b | be used           |                  |              |
| bit 5            | MFOR: MFIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ITOSC Oscillate    | or Ready        |                  |                   |                  |              |
|                  | 1 = The osc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | illator is ready   | to be used      |                  |                   |                  |              |
|                  | 0 = The osc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | illator is not en  | abled, or is no | t yet ready to b | be used           |                  |              |
| bit 4            | LFOR: LFINT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | FOSC Oscillato     | r Ready bit     |                  |                   |                  |              |
|                  | 1 = 1he oscillations = The oscillations of the oscillation of the os | cillator is ready  | to be used      | t vet ready to h |                   |                  |              |
| hit 3            | SOR: Second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | harv (Timer1) (    | scillator Read  | v hit            |                   |                  |              |
| bit 0            | 1 = The os                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | cillator is ready  | to be used      | y bit            |                   |                  |              |
|                  | 0 = The osc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | cillator is not en | abled, or is no | ot yet ready to  | be used           |                  |              |
| bit 2            | ADOR: ADC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Oscillator Read    | dy bit          |                  |                   |                  |              |
|                  | 1 = The os                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | cillator is ready  | to be used      |                  |                   |                  |              |
|                  | 0 = The osc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | cillator is not en | abled, or is no | ot yet ready to  | be used           |                  |              |
| bit 1            | Unimplemen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ited: Read as      | 0′              |                  |                   |                  |              |
| bit 0            | PLLR: PLL is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Ready bit          | uppd            |                  |                   |                  |              |
|                  | 1 = The PL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | is not enabled     | , the required  | input source is  | s not ready, or t | he PLL is not lo | ocked.       |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    | .,              |                  |                   |                  |              |

#### REGISTER 4-4: OSCSTAT: OSCILLATOR STATUS REGISTER 1

#### 5.5 **Register Definitions: Reference Clock**

Long bit name prefixes for the Reference Clock peripherals are shown in Table 5-1. Refer to Section 1.4.2.2 "Long Bit Names" for more information. TABLE 5-1:

#### Porinheral Dif Norm

| Peripheral | Bit Name Prefix |
|------------|-----------------|
| CLKR       | CLKR            |

#### **REGISTER 5-1: CLKRCON: REFERENCE CLOCK CONTROL REGISTER**

| R/W-0/0 | U-0 | U-0 | R/W-1/1 | R/W-0/0          | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|---------|-----|-----|---------|------------------|---------|---------|---------|
| EN      | -   | _   | DC<     | DC<1:0> DIV<2:0> |         |         |         |
| bit 7   |     |     |         |                  |         |         | bit 0   |

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

| bit 7   | EN: Reference Clock Module Enable bit                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul><li>1 = Reference clock module enabled</li><li>0 = Reference clock module is disabled</li></ul>                                                                                                                                                                                                          |
| bit 6-5 | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                   |
| bit 4-3 | DC<1:0>: Reference Clock Duty Cycle bits <sup>(1)</sup>                                                                                                                                                                                                                                                      |
|         | <ul> <li>11 = Clock outputs duty cycle of 75%</li> <li>10 = Clock outputs duty cycle of 50%</li> <li>01 = Clock outputs duty cycle of 25%</li> <li>00 = Clock outputs duty cycle of 0%</li> </ul>                                                                                                            |
| bit 2-0 | DIV<2:0>: Reference Clock Divider bits                                                                                                                                                                                                                                                                       |
|         | 111 = Base clock value divided by 128<br>110 = Base clock value divided by 64<br>101 = Base clock value divided by 32<br>100 = Base clock value divided by 16<br>011 = Base clock value divided by 8<br>010 = Base clock value divided by 4<br>001 = Base clock value divided by 2<br>000 = Base clock value |

Note 1: Bits are valid for reference clock divider values of two or larger, the base clock cannot be further divided.

# 12.0 8x8 HARDWARE MULTIPLIER

#### 12.1 Introduction

All PIC18 devices include an 8x8 hardware multiplier as part of the ALU. The multiplier performs an unsigned operation and yields a 16-bit result that is stored in the product register pair, PRODH:PRODL. The multiplier's operation does not affect any flags in the STATUS register.

Making multiplication a hardware operation allows it to be completed in a single instruction cycle. This has the advantages of higher computational throughput and reduced code size for multiplication algorithms and allows the PIC18 devices to be used in many applications previously reserved for digital signal processors. A comparison of various hardware and software multiply operations, along with the savings in memory and execution time, is shown in Table 12-1.

#### 12.2 Operation

Example 12-1 shows the instruction sequence for an 8x8 unsigned multiplication. Only one instruction is required when one of the arguments is already loaded in the WREG register.

Example 12-2 shows the sequence to do an 8x8 signed multiplication. To account for the sign bits of the arguments, each argument's Most Significant bit (MSb) is tested and the appropriate subtractions are done.

#### EXAMPLE 12-1: 8x8 UNSIGNED MULTIPLY ROUTINE

| MOVF  | ARG1, | W | ; |       |     |       |    |
|-------|-------|---|---|-------|-----|-------|----|
| MULWF | ARG2  |   | ; | ARG1  | *   | ARG2  | -> |
|       |       |   | ; | PRODI | 1:1 | PRODL |    |

# EXAMPLE 12-2: 8x8 SIGNED MULTIPLY

| MOVF  | ARG1, W  |   |                |
|-------|----------|---|----------------|
| MULWF | ARG2     | ; | ARG1 * ARG2 -> |
|       |          | ; | PRODH:PRODL    |
| BTFSC | ARG2, SB | ; | Test Sign Bit  |
| SUBWF | PRODH, F | ; | PRODH = PRODH  |
|       |          | ; | - ARG1         |
| MOVF  | ARG2, W  |   |                |
| BTFSC | ARG1, SB | ; | Test Sign Bit  |
| SUBWF | PRODH, F | ; | PRODH = PRODH  |
|       |          | ; | - ARG2         |
|       |          |   |                |

|                 |                           | Program           | Cvcles | Time     |          |          |         |  |
|-----------------|---------------------------|-------------------|--------|----------|----------|----------|---------|--|
| Routine         | Multiply Method           | Memory<br>(Words) | (Max)  | @ 64 MHz | @ 40 MHz | @ 10 MHz | @ 4 MHz |  |
| 9v9 uppigpod    | Without hardware multiply | 13                | 69     | 4.3 μs   | 6.9 μs   | 27.6 μs  | 69 μs   |  |
| oxo unsigned    | Hardware multiply         | 1                 | 1      | 62.5 ns  | 100 ns   | 400 ns   | 1 μs    |  |
| Que simo d      | Without hardware multiply | 33                | 91     | 5.7 μs   | 9.1 μs   | 36.4 μs  | 91 μs   |  |
| oxo signeu      | Hardware multiply         | 6                 | 6      | 375 ns   | 600 ns   | 2.4 μs   | 6 μs    |  |
| 16x16 unsigned  | Without hardware multiply | 21                | 242    | 15.1 μs  | 24.2 μs  | 96.8 μs  | 242 μs  |  |
| Tox to unsigned | Hardware multiply         | 28                | 28     | 1.8 μs   | 2.8 μs   | 11.2 μs  | 28 μs   |  |
|                 | Without hardware multiply | 52                | 254    | 15.9 μs  | 25.4 μs  | 102.6 μs | 254 μs  |  |
| Tox to signed   | Hardware multiply         | 35                | 40     | 2.5 μs   | 4.0 μs   | 16.0 μs  | 40 μs   |  |

#### TABLE 12-1: PERFORMANCE COMPARISON FOR VARIOUS MULTIPLY OPERATIONS

#### 13.6 CRC Check Value

The CRC check value will be located in the CRCACC registers after the CRC calculation has finished. The check value will depend on two mode settings of the CRCCON register: ACCM and SHIFTM.

When the ACCM bit is set, the CRC module augments the data with a number of zeros equal to the length of the polynomial to align the final check value. When the ACCM bit is not set, the CRC will stop at the end of the data. A number of zeros equal to the length of the polynomial can then be entered into CRCDAT to find the same check value as augmented mode. Alternatively, the expected check value can be entered at this point to make the final result equal 0.

When the CRC check value is computed with the SHIFTM bit set, selecting LSb first, and the ACCM bit is set then the final value in the CRCACC registers will be reversed such that the LSb will be in the MSb position and vice versa. This is the expected check value in bit reversed form. If you are creating a check value to be appended to a data stream then a bit reversal must be performed on the final value to achieve the correct checksum. You can use the CRC to do this reversal by the following method:

- Save CRCACC value in user RAM space
- Clear the CRCACC registers
- Clear the CRCXOR registers
- Write the saved CRCACC value to the CRCDAT input

The properly oriented check value will be in the CRCACC registers as the result.

#### 13.7 CRC Interrupt

The CRC will generate an interrupt when the BUSY bit transitions from 1 to 0. The CRCIF Interrupt Flag bit of the PIR7 register is set every time the BUSY bit transitions, regardless of whether or not the CRC interrupt is enabled. The CRCIF bit can only be cleared in software. The CRC interrupt enable is the CRCIE bit of the PIE7 register.

### 13.8 Configuring the CRC

The following steps illustrate how to properly configure the CRC.

- Determine if the automatic program memory scan will be used with the scanner or manual calculation through the SFR interface and perform the actions specified in Section 13.5 "CRC Data Sources", depending on which decision was made.
- 2. If desired, seed a starting CRC value into the CRCACCH/L registers.
- 3. Program the CRCXORH/L registers with the desired generator polynomial.
- Program the DLEN<3:0> bits of the CRCCON1 register with the length of the data word - 1 (refer to Example 13-1). This determines how many times the shifter will shift into the accumulator for each data word.
- 5. Program the PLEN<3:0> bits of the CRCCON1 register with the length of the polynomial -2 (refer to Example 13-1).
- Determine whether shifting in trailing zeros is desired and set the ACCM bit of the CRCCON0 register appropriately.
- 7. Likewise, determine whether the MSb or LSb should be shifted first and write the SHIFTM bit of the CRCCON0 register appropriately.
- 8. Write the CRCGO bit of the CRCCON0 register to begin the shifting process.
- 9a. If manual SFR entry is used, monitor the FULL bit of the CRCCON0 register. When FULL = 0, another word of data can be written to the CRCDATH/L registers, keeping in mind that CRCDATH should be written first if the data has more than eight bits, as the shifter will begin upon the CRCDATL register being written.
- 9b. If the scanner is used, the scanner will automatically stuff words into the CRCDATH/L registers as needed, as long as the SCANGO bit is set.
- 10a.If using the Flash memory scanner, monitor the SCANIF (or the SCANGO bit) for the scanner to finish pushing information into the CRCDATA registers. After the scanner is completed, monitor the BUSY bit to determine that the CRC has been completed and the check value can be read from the CRCACC registers. If both the interrupt flags are set (or both BUSY and SCANGO bits are cleared), the completed CRC calculation can be read from the CRCACCH/L registers.
- 10b. If manual entry is used, monitor the BUSY bit to determine when the CRCACC registers will hold the check value.

| 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 |
|-----------------|----------------------------------|---------------------------------|----------------------------------|----------------------------|------------------|-----------------|---------|
| _               | —                                | TMR6IF                          | TMR5IF                           | TMR4IF                     | TMR3IF           | TMR2IF          | TMR1IF  |
| bit 7           |                                  |                                 |                                  |                            |                  |                 | bit 0   |
|                 |                                  |                                 |                                  |                            |                  |                 |         |
| Legend:         |                                  |                                 |                                  |                            |                  |                 |         |
| R = Readable    | bit                              | W = Writable                    | bit                              | U = Unimpler               | mented bit, read | as '0'          |         |
| -n = Value at P | OR                               | '1' = Bit is set                |                                  | '0' = Bit is cle           | ared             | x = Bit is unkr | nown    |
|                 |                                  |                                 |                                  |                            |                  |                 |         |
| bit 7-6         | Unimplemen                       | ted: Read as '                  | כ'                               |                            |                  |                 |         |
| bit 5           | TMR6IF: TMF                      | R6 to PR6 Mate                  | ch Interrupt Fla                 | ag bit                     | (thurse)         |                 |         |
|                 | 0 = No TMR6 to r                 | to PR6 match                    | occurred                         |                            | ntware)          |                 |         |
| bit 4           | TMR5IF: TMF                      | R5 Overflow Int                 | errupt Flag bi                   | t                          |                  |                 |         |
|                 | 1 = TMR5 reg                     | ister overflowe                 | d (must be cl                    | eared in softwa            | are)             |                 |         |
|                 | 0 = IMR5 reg                     | lister did not ov               | verflow                          |                            |                  |                 |         |
| bit 3           | TMR4IF: $IMF$<br>1 = TMR4 to F   | R4 to PR4 Mate<br>PR4 match occ | h Interrupt Fla<br>urred (must b | ag bit<br>le cleared in sc | oftware)         |                 |         |
|                 | 0 = No TMR4                      | to PR4 match                    | occurred                         |                            | (itital c)       |                 |         |
| bit 2           | TMR3IF: TMF                      | R3 Overflow Int                 | errupt Flag bi                   | t                          |                  |                 |         |
|                 | 1 = TMR3 reg                     | ister overflowe                 | d (must be cl                    | eared in softwa            | are)             |                 |         |
|                 | 0 = IMR3 reg                     | lister did not ov               | rentiow                          |                            |                  |                 |         |
| bit 1           | TMR2IF: $IMF$<br>1 = TMR2 to $I$ | R2 to PR2 Mate<br>PR2 match occ | h Interrupt Fla<br>urred (must b | ag bit<br>le cleared in sc | oftware)         |                 |         |
|                 | 0 = No TMR2                      | to PR2 match                    | occurred                         |                            | (itware)         |                 |         |
| bit 0           | TMR1IF: TMF                      | R1 Overflow Int                 | errupt Flag bi                   | t                          |                  |                 |         |
|                 | 1 = TMR1 reg                     | ister overflowe                 | d (must be cl                    | eared in softwa            | are)             |                 |         |
|                 | 0 = IMR1 reg                     | lister did not ov               | retiow                           |                            |                  |                 |         |

### REGISTER 14-6: PIR4: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 4

#### 20.5.2 HARDWARE GATE MODE

The Hardware Gate modes operate the same as the Software Gate mode except the TMRx\_ers external signal can also gate the timer. When used with the CCP the gating extends the PWM period. If the timer is stopped when the PWM output is high then the duty cycle is also extended.

When MODE<4:0> = 00001 then the timer is stopped when the external signal is high. When MODE<4:0> = 00010 then the timer is stopped when the external signal is low.

Figure 20-5 illustrates the Hardware Gating mode for MODE<4:0> = 00001 in which a high input level starts the counter.



| Rev. 10.000 1988<br>5/30/2014                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MODE 0b00001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| TMRx_ers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| PRx 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| $TMRx \left( \begin{array}{c} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 1 \\ 2 \\ 2 \\ 3 \\ 4 \\ 5 \\ 1 \\ 2 \\ 2 \\ 1 \\ 2 \\ 2 \\ 1 \\ 2 \\ 2 \\ 1 \\ 2 \\ 2$ |  |
| TMRx_postscaled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| PWM Duty   3     Cycle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |

| R/W-0/0         | R/W-1/1                                                                      | R/W-0/0                                                                                            | R/W-1/1                                                              | R/W-0/0                                              | R/W-1/1                                               | R/W-0/0                                | R/W-1/1 |
|-----------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|----------------------------------------|---------|
| P4TSE           | L<1:0>                                                                       | P3TSEL<1:0>                                                                                        |                                                                      | C2TSE                                                | EL<1:0>                                               | C1TSEI                                 | _<1:0>  |
| bit 7           |                                                                              |                                                                                                    |                                                                      | ·                                                    |                                                       |                                        | bit 0   |
|                 |                                                                              |                                                                                                    |                                                                      |                                                      |                                                       |                                        |         |
| Legend:         |                                                                              |                                                                                                    |                                                                      |                                                      |                                                       |                                        |         |
| R = Readable I  | bit                                                                          | W = Writable                                                                                       | oit                                                                  | U = Unimplem                                         | nented bit, read                                      | as '0'                                 |         |
| -n = Value at P | OR                                                                           | '1' = Bit is set                                                                                   |                                                                      | '0' = Bit is clea                                    | ared                                                  | x = Bit is unkno                       | own     |
| bit 7-6         | P4TSEL<1:0><br>11 = PWM4 1<br>10 = PWM4 1<br>01 = PWM4 1<br>00 = Reserve     | <ul> <li>PWM4 Times<br/>based on TMR<br/>based on TMR<br/>based on TMR<br/>based on TMR</li> </ul> | <sup>-</sup> Selection bit<br>6<br>4<br>2                            | 'S                                                   |                                                       |                                        |         |
| bit 5-4         | P3TSEL<1:0><br>11 = PWM3 =<br>10 = PWM3 =<br>01 = PWM3 =<br>00 = Reserve     | <ul> <li>PWM3 Times<br/>based on TMR<br/>based on TMR<br/>based on TMR<br/>ed</li> </ul>           | <sup>-</sup> Selection bit<br>6<br>4<br>2                            | is                                                   |                                                       |                                        |         |
| bit 3-2         | C2TSEL<1:02<br>11 = CCP2 is<br>10 = CCP2 is<br>01 = CCP2 is<br>00 = Reserve  | CCP2 Timer<br>based off Time<br>based off Time<br>based off Time<br>d                              | Selection bits<br>er5 in Capture<br>er3 in Capture<br>er1 in Capture | s<br>e/Compare mod<br>e/Compare mod<br>e/Compare mod | e and Timer6 ir<br>e and Timer4 ir<br>e and Timer2 ir | n PWM mode<br>n PWM mode<br>n PWM mode |         |
| bit 1-0         | C1TSEL<1:0><br>11 = CCP1 is<br>10 = CCP1 is<br>01 = CCP1 is<br>00 = Reserver | CCP1 Timer<br>based off Time<br>based off Time<br>based off Time<br>d                              | Selection bits<br>er5 in Capture<br>er3 in Capture<br>er1 in Capture | s<br>e/Compare mod<br>e/Compare mod<br>e/Compare mod | e and Timer6 ir<br>e and Timer4 ir<br>e and Timer2 ir | n PWM mode<br>n PWM mode<br>n PWM mode |         |

#### REGISTER 21-2: CCPTMRS: CCP TIMERS CONTROL REGISTER





#### 24.2.2 PUSH-PULL MODE

In Push-Pull mode, two output signals are generated, alternating copies of the input as illustrated in Figure 24-4. This alternation creates the push-pull effect required for driving some transformer-based power supply designs. Steering modes are not used in Push-Pull mode. A basic block diagram for the Push-Pull mode is shown in Figure 24-3.

The push-pull sequencer is reset whenever EN = 0 or if an auto-shutdown event occurs. The sequencer is clocked by the first input pulse, and the first output appears on CWG1A.

The unused outputs CWG1C and CWG1D drive copies of CWG1A and CWG1B, respectively, but with polarity controlled by the POLC and POLD bits of the CWG1CON1 register, respectively.

# 24.14 Register Definitions: CWG Control

Long bit name prefixes for the CWG peripheral is shown in Table 24-2. Refer to **Section 1.4.2.2 "Long Bit Names"** for more information.

#### TABLE 24-2:

| Peripheral | Bit Name Prefix |
|------------|-----------------|
| CWG        | CWG             |

L

#### REGISTER 24-1: CWG1CON0: CWG CONTROL REGISTER 0

| R/W-0/0 | R/W/HC-0/0        | U-0 | U-0 | U-0 | R/W-0/0 | R/W-0/0   | R/W-0/0 |
|---------|-------------------|-----|-----|-----|---------|-----------|---------|
| EN      | LD <sup>(1)</sup> | —   | —   | —   |         | MODE<2:0> |         |
| bit 7   |                   |     |     |     |         |           | bit 0   |

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

| bit 7     | EN: CWG1 Enable bit<br>1 = Module is enabled<br>0 = Module is disabled                                                                                                                                                                                                                                                                                                                               |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6     | <ul> <li>LD: CWG1 Load Buffers bit<sup>(1)</sup></li> <li>1 = Dead-band count buffers to be loaded on CWG data rising edge, following first falling edge after this bit is set</li> <li>0 = Buffers remain unchanged</li> </ul>                                                                                                                                                                      |
| bit 5-3   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                           |
| bit 2-0   | MODE<2:0>: CWG1 Mode bits<br>111 = Reserved<br>110 = Reserved<br>101 = CWG outputs operate in Push-Pull mode<br>100 = CWG outputs operate in Half-Bridge mode<br>011 = CWG outputs operate in Reverse Full-Bridge mode<br>010 = CWG outputs operate in Forward Full-Bridge mode<br>001 = CWG outputs operate in Synchronous Steering mode<br>000 = CWG outputs operate in Asynchronous Steering mode |
| Note 1: T | his bit can only be set after EN = 1; it cannot be set in the same cycle when EN is set.                                                                                                                                                                                                                                                                                                             |

#### 26.10.8 ACKNOWLEDGE SEQUENCE TIMING

An Acknowledge sequence is enabled by setting the Acknowledge Sequence Enable bit, ACKEN bit of the SSPxCON2 register. When this bit is set, the SCL pin is pulled low and the contents of the Acknowledge data bit are presented on the SDA pin. If the user wishes to generate an Acknowledge, then the ACKDT bit should be cleared. If not, the user should set the ACKDT bit before starting an Acknowledge sequence. The Baud Rate Generator then counts for one rollover period (TBRG) and the SCL pin is deasserted (pulled high). When the SCL pin is sampled high (clock arbitration), the Baud Rate Generator counts for TBRG. The SCL pin is then pulled low. Following this, the ACKEN bit is automatically cleared, the Baud Rate Generator is turned off and the MSSP module then goes into Idle mode (Figure 26-30).

#### 26.10.8.1 WCOL Status Flag

If the user writes the SSPxBUF when an Acknowledge sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

#### 26.10.9 STOP CONDITION TIMING

A Stop bit is asserted on the SDA pin at the end of a receive/transmit by setting the Stop Sequence Enable bit, PEN bit of the SSPxCON2 register. At the end of a receive/transmit, the SCL line is held low after the falling edge of the ninth clock. When the PEN bit is set, the master will assert the SDA line low. When the SDA line is sampled low, the Baud Rate Generator is reloaded and counts down to '0'. When the Baud Rate Generator times out, the SCL pin will be brought high and one TBRG (Baud Rate Generator rollover count) later, the SDA pin will be deasserted. When the SDA pin is sampled high while SCL is high, the P bit of the SSPxSTAT register is set. A TBRG later, the PEN bit is cleared and the SSPxIF bit is set (Figure 26-31).

#### 26.10.9.1 WCOL Status Flag

If the user writes the SSPxBUF when a Stop sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

#### FIGURE 26-30: ACKNOWLEDGE SEQUENCE WAVEFORM



#### FIGURE 26-31: STOP CONDITION RECEIVE OR TRANSMIT MODE



#### 31.1.5 INTERRUPTS

The ADC module allows for the ability to generate an interrupt upon completion of an Analog-to-Digital conversion. The ADC Interrupt Flag is the ADIF bit in the PIR1 register. The ADC Interrupt Enable is the ADIE bit in the PIE1 register. The ADIF bit must be cleared in software.

| Note 1: T | The ADIF bit is set at the completion of |
|-----------|------------------------------------------|
| e         | every conversion, regardless of whether  |
| o         | or not the ADC interrupt is enabled.     |

**2:** The ADC operates during Sleep only when the FRC oscillator is selected.

This interrupt can be generated while the device is operating or while in Sleep. If the device is in Sleep, the interrupt will wake-up the device. Upon waking from Sleep, the next instruction following the SLEEP instruction is always executed. If the user is attempting to wake-up from Sleep and resume in-line code execution, the ADIE bit of the PIE1 register and the PEIE bit of the INTCON register must both be set and the GIE bit of the INTCON register must be cleared. If all three of these bits are set, the execution will switch to the Interrupt Service Routine.

#### 31.1.6 RESULT FORMATTING

The 10-bit ADC conversion result can be supplied in two formats, left justified or right justified. The ADFM bits of the ADCON0 register controls the output format.

Figure 31-3 shows the two output formats.

#### FIGURE 31-3: 10-BIT ADC CONVERSION RESULT FORMAT



| 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      |
|----------------------------------------|---------------------|-------------------|---------------|------------------|---------------|----------------|--------------|
| —                                      | —                   |                   |               | ADCS             | 6<5:0>        |                |              |
| bit 7                                  |                     |                   |               |                  |               |                | bit 0        |
|                                        |                     |                   |               |                  |               |                |              |
| Legend:                                |                     |                   |               |                  |               |                |              |
| R = Readable bit W = Writable bit      |                     |                   | U = Unimpler  | nented bit, read | d as '0'      |                |              |
| u = Bit is unchanged x = Bit is unknow |                     |                   | nown          | -n/n = Value a   | at POR and BC | R/Value at all | other Resets |
| '1' = Bit is set                       |                     | '0' = Bit is clea | ared          |                  |               |                |              |
|                                        |                     |                   |               |                  |               |                |              |
| bit 7-6                                | Unimplemer          | nted: Read as '   | כ'            |                  |               |                |              |
| bit 5-0                                | ADCS<5:0>:          | ADC Conversion    | on Clock Sele | ect bits         |               |                |              |
|                                        | 111111 <b>= F</b> c | osc/128           |               |                  |               |                |              |
|                                        | 111110 = Fosc/126   |                   |               |                  |               |                |              |
|                                        | 111101 <b>= F</b> c | osc/124           |               |                  |               |                |              |
|                                        | •                   |                   |               |                  |               |                |              |
|                                        | •                   |                   |               |                  |               |                |              |
|                                        | •                   |                   |               |                  |               |                |              |
|                                        | 000000 = Fo         | osc/2             |               |                  |               |                |              |

#### REGISTER 31-6: ADCLK: ADC CLOCK SELECTION REGISTER

#### REGISTER 31-7: ADREF: ADC REFERENCE SELECTION REGISTER

| U-0   | U-0 | U-0 | R/W-0/0 | U-0 | U-0 | R/W-0/0 | R/W-0/0 |
|-------|-----|-----|---------|-----|-----|---------|---------|
| —     | —   | —   | ADNREF  | —   | —   | ADPRE   | F<1:0>  |
| bit 7 |     |     |         |     |     |         | bit 0   |

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

| bit 7-5<br>bit 4 | Unimplemented: Read as '0'<br>ADNREF: ADC Negative Voltage Reference Selection bit<br>1 = VREF- is connected to external VREF-<br>0 = VREF- is connected to AVss                                                                  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 3-2          | Unimplemented: Read as '0'                                                                                                                                                                                                        |
| bit 1-0          | ADPREF: ADC Positive Voltage Reference Selection bits<br>11 = VREF+ is connected to internal Fixed Voltage Reference (FVR) module<br>10 = VREF+ is connected to external VREF+<br>01 = Reserved<br>00 = VREF+ is connected to VDD |

### 32.3 Comparator Control

Each comparator has two control registers: CMxCON0 and CMxCON1.

The CMxCON0 register (see Register 32-1) contains Control and Status bits for the following:

- Enable
- Output
- Output polarity
- · Hysteresis enable
- · Timer1 output synchronization

The CMxCON1 register (see Register 32-2) contains Control bits for the following:

- Interrupt on positive/negative edge enables
- · Positive input channel selection
- Negative input channel selection

#### 32.3.1 COMPARATOR ENABLE

Setting the EN bit of the CMxCON0 register enables the comparator for operation. Clearing the CxEN bit disables the comparator resulting in minimum current consumption.

#### 32.3.2 COMPARATOR OUTPUT

The output of the comparator can be monitored by reading either the CxOUT bit of the CMxCON0 register or the MCxOUT bit of the CMOUT register.

The comparator output can also be routed to an external pin through the RxyPPS register (Register 17-2). The corresponding TRIS bit must be clear to enable the pin as an output.

Note 1: The internal output of the comparator is latched with each instruction cycle. Unless otherwise specified, external outputs are not latched.

#### 32.3.3 COMPARATOR OUTPUT POLARITY

Inverting the output of the comparator is functionally equivalent to swapping the comparator inputs. The polarity of the comparator output can be inverted by setting the CxPOL bit of the CMxCON0 register. Clearing the CxPOL bit results in a non-inverted output.

Table 32-2 shows the output state versus input conditions, including polarity control.

#### TABLE 32-2: COMPARATOR OUTPUT STATE VS. INPUT CONDITIONS

| Input Condition | CxPOL | CxOUT |
|-----------------|-------|-------|
| CxVN > CxVP     | 0     | 0     |
| CxVN < CxVP     | 0     | 1     |
| CxVN > CxVP     | 1     | 1     |
| CxVN < CxVP     | 1     | 0     |



#### 33.5 Applications

In many applications, it is desirable to detect a drop below, or rise above, a particular voltage threshold. For example, the HLVD module could be periodically enabled to detect Universal Serial Bus (USB) attach or detach. This assumes the device is powered by a lower voltage source than the USB when detached. An attach would indicate a High-Voltage Detect from, for example, 3.3V to 5V (the voltage on USB) and vice versa for a detach. This feature could save a design a few extra components and an attach signal (input pin).

For general battery applications, Figure 33-4 shows a possible voltage curve. Over time, the device voltage decreases. When the device voltage reaches voltage, VA, the HLVD logic generates an interrupt at time, TA. The interrupt could cause the execution of an Interrupt Service Routine (ISR), which would allow the application to perform "housekeeping tasks" and a controlled shutdown before the device voltage exits the valid operating range at TB. This would give the application a time window, represented by the difference between TA and TB, to safely exit.



# PIC18(L)F24/25K40

| RLNCF                                                      | Rotate Le                                                                                                                                                                                                              | eft f (No Car                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ry)         |  |  |  |
|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|
| Syntax:                                                    | RLNCF                                                                                                                                                                                                                  | f {,d {,a}}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |  |  |  |
| Operands:                                                  | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1]                                                                                                                                                                                  | $0 \le f \le 255$<br>d $\in [0,1]$<br>a $\in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |  |  |  |
| Operation:                                                 | $(f \le n >) \rightarrow d$<br>$(f \le 7 >) \rightarrow d$                                                                                                                                                             | $(f \le n >) \rightarrow dest \le n + 1 >,$<br>$(f \le 7 >) \rightarrow dest \le 0 >$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |  |  |  |
| Status Affected:                                           | N, Z                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| Encoding:                                                  | 0100                                                                                                                                                                                                                   | 01da ff:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ff ffff     |  |  |  |
| Description:                                               | The conter<br>one bit to t<br>is placed ir<br>stored bac<br>If 'a' is '0', t<br>If 'a' is '1', t<br>GPR bank.<br>If 'a' is '0' a<br>set is enab<br>in Indexed<br>mode when<br>tion 35.2.3<br>Oriented I<br>eral Offset | The contents of register 'f' are rotated<br>one bit to the left. If 'd' is '0', the result<br>is placed in W. If 'd' is '1', the result is<br>stored back in register 'f' (default).<br>If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank.<br>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. |             |  |  |  |
|                                                            |                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| Words:                                                     | 1                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| Cycles:                                                    | 1                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| Q Cycle Activity:                                          |                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| Q1                                                         | Q2                                                                                                                                                                                                                     | Q3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Q4          |  |  |  |
| Decode                                                     | register 'f'                                                                                                                                                                                                           | Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | destination |  |  |  |
| Example:                                                   | RLNCF                                                                                                                                                                                                                  | REG, 1,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |  |  |  |
| Before Instruction<br>REG = 1010 1011<br>After Instruction |                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |
| REG = 0101 0111                                            |                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |

| RRCF               | Rotate Right f through Carry                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:            | RRCF f{,                                                                                                                                                                                                                               | d {,a}}                                                                                                                                                                                                                                                        |                                                                                                                                                                                                |  |  |
| Operands:          | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                                                    |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| Operation:         | $(f < n >) \rightarrow de$<br>$(f < 0 >) \rightarrow C$<br>$(C) \rightarrow dest$                                                                                                                                                      | est <n 1="" –="">,<br/>,<br/>&lt;7&gt;</n>                                                                                                                                                                                                                     |                                                                                                                                                                                                |  |  |
| Status Affected:   | C, N, Z                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| Encoding:          | 0011                                                                                                                                                                                                                                   | 00da ffi                                                                                                                                                                                                                                                       | f ffff                                                                                                                                                                                         |  |  |
|                    | one bit to th<br>flag. If 'd' is<br>If 'd' is '1', t<br>register 'f' (<br>If 'a' is '0', t<br>If 'a' is '1', t<br>GPR bank.<br>If 'a' is '0' a<br>set is enabl<br>in Indexed<br>mode wher<br>tion 35.2.3<br>Oriented In<br>eral Offset | the right through<br>'0', the result is play<br>default).<br>the Access Bar<br>the BSR is use<br>and the extended<br>ed, this instruct<br>Literal Offset A<br>tever $f \le 95$ (5f<br><b>"Byte-Oriental<br/>Instructions in<br/>Mode"</b> for deta<br>register | n the CARRY<br>s placed in W.<br>uced back in<br>hk is selected.<br>d to select the<br>ed instruction<br>tion operates<br>uddressing<br>Fh). See Sec-<br>ed and Bit-<br>Indexed Lit-<br>tails. |  |  |
| Words <sup>.</sup> | 1                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| Cycles:            | 1                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
|                    | ·                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| Q1                 | Q2                                                                                                                                                                                                                                     | Q3                                                                                                                                                                                                                                                             | Q4                                                                                                                                                                                             |  |  |
| Decode             | Read<br>register 'f'                                                                                                                                                                                                                   | Process<br>Data                                                                                                                                                                                                                                                | Write to destination                                                                                                                                                                           |  |  |
|                    |                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| Example:           | RRCF                                                                                                                                                                                                                                   | REG, 0, 0                                                                                                                                                                                                                                                      | )                                                                                                                                                                                              |  |  |
| Before Instruc     | tion                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| REG                | = 1110 (<br>= 0                                                                                                                                                                                                                        | 110                                                                                                                                                                                                                                                            |                                                                                                                                                                                                |  |  |
| After Instructio   | on                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
| REG                | = 1110 0                                                                                                                                                                                                                               | 0110                                                                                                                                                                                                                                                           |                                                                                                                                                                                                |  |  |
| W                  | = 0111 0                                                                                                                                                                                                                               | 0011                                                                                                                                                                                                                                                           |                                                                                                                                                                                                |  |  |
| С                  | = 0                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |
|                    |                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                |                                                                                                                                                                                                |  |  |

#### 35.2.2 EXTENDED INSTRUCTION SET

| ADD   | DFSR           | Add Literal to FSR                                                          |                                 |    |          |  |  |  |
|-------|----------------|-----------------------------------------------------------------------------|---------------------------------|----|----------|--|--|--|
| Synta | ax:            | ADDFSR                                                                      | ADDFSR f, k                     |    |          |  |  |  |
| Oper  | ands:          | 0 ≤ k ≤ 63<br>f ∈ [ 0, 1, 2                                                 | 0 ≤ k ≤ 63<br>f ∈ [ 0, 1, 2 ]   |    |          |  |  |  |
| Oper  | ation:         | FSR(f) + k                                                                  | $FSR(f) + k \rightarrow FSR(f)$ |    |          |  |  |  |
| Statu | is Affected:   | None                                                                        | None                            |    |          |  |  |  |
| Enco  | oding:         | 1110 1000 ffkk kkkk                                                         |                                 |    |          |  |  |  |
| Desc  | cription:      | The 6-bit literal 'k' is added to the contents of the FSR specified by 'f'. |                                 |    |          |  |  |  |
| Word  | ls:            | 1                                                                           |                                 |    |          |  |  |  |
| Cycle | es:            | 1                                                                           |                                 |    |          |  |  |  |
| QC    | ycle Activity: |                                                                             |                                 |    |          |  |  |  |
|       | Q1             | Q2                                                                          | Q3                              |    | Q4       |  |  |  |
|       | Decode         | Read                                                                        | Proce                           | SS | Write to |  |  |  |
|       |                | literal 'k' Data FSR                                                        |                                 |    |          |  |  |  |

| Example: | ADDFSR | 2, | 23h |
|----------|--------|----|-----|

| Before Instru  | ction |       |
|----------------|-------|-------|
| FSR2           | =     | 03FFh |
| After Instruct | ion   |       |
| FSR2           | =     | 0422h |

| ADDULNK             | Add Literal to FSR2 and Return                                                                                                                                                                                                                                                                                                             |      |      |      |  |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|--|--|
| Syntax:             | ADDULNK k                                                                                                                                                                                                                                                                                                                                  |      |      |      |  |  |
| Operands:           | $0 \le k \le 63$                                                                                                                                                                                                                                                                                                                           | 3    |      |      |  |  |
| Operation:          | $FSR2 + k \rightarrow FSR2$ ,                                                                                                                                                                                                                                                                                                              |      |      |      |  |  |
|                     | $(TOS) \rightarrow$                                                                                                                                                                                                                                                                                                                        | PC   |      |      |  |  |
| Status Affected:    | None                                                                                                                                                                                                                                                                                                                                       |      |      |      |  |  |
| Encoding:           | 1110                                                                                                                                                                                                                                                                                                                                       | 1000 | 11kk | kkkk |  |  |
| Description:        | The 6-bit literal 'k' is added to the contents of FSR2. A RETURN is then executed by loading the PC with the TOS.<br>The instruction takes two cycles to execute; a NOP is performed during the second cycle.<br>This may be thought of as a special case of the ADDFSR instruction, where $f = 3$ (binary '11'); it operates only on FSR2 |      |      |      |  |  |
| Words:              | 1                                                                                                                                                                                                                                                                                                                                          |      |      |      |  |  |
| Cycles:             | 2                                                                                                                                                                                                                                                                                                                                          |      |      |      |  |  |
| O Cuelo A stivit :: |                                                                                                                                                                                                                                                                                                                                            |      |      |      |  |  |

Q Cycle Activity:

| Q1        | Q2          | Q3        | Q4        |
|-----------|-------------|-----------|-----------|
| Decode    | Read        | Process   | Write to  |
|           | literal 'k' | Data      | FSR       |
| No        | No          | No        | No        |
| Operation | Operation   | Operation | Operation |

Example: ADDULNK 23h

| -     |   |  |  |  |  |  |
|-------|---|--|--|--|--|--|
|       |   |  |  |  |  |  |
|       |   |  |  |  |  |  |
|       |   |  |  |  |  |  |
|       |   |  |  |  |  |  |
| <br>_ | - |  |  |  |  |  |

| Before Instru  |   |       |
|----------------|---|-------|
| FSR2           | = | 03FFh |
| PC             | = | 0100h |
| After Instruct |   |       |
| FSR2           | = | 0422h |
| PC             | = | (TOS) |

**Note:** All PIC18 instructions may take an optional label argument preceding the instruction mnemonic for use in symbolic addressing. If a label is used, the instruction syntax then becomes: {label} instruction argument(s).

| PIC18LF | 24/25K40       |                                           |      | Standard Operating Con |                    |           | ditions (unless otherwise stated) |            |                       |
|---------|----------------|-------------------------------------------|------|------------------------|--------------------|-----------|-----------------------------------|------------|-----------------------|
| PIC18F2 | PIC18F24/25K40 |                                           |      | <b>Standa</b><br>VREGF | rd Opera<br>PM = 1 | ating Con | ditions                           | (unless    | otherwise stated)     |
| Param.  | 0h.e.l         | Device Oberratoriation                    |      | Max.                   | Max.               |           |                                   | Conditions |                       |
| No.     | Symbol         | Device Characteristics                    | Min. | Typ.†                  | +85°C              | +125°C    | Units                             | VDD        | Note                  |
| D200    | IPD            | IPD Base                                  | —    | 0.05                   | 2                  | 9         | μΑ                                | 3.0V       |                       |
| D200    | IPD            | IPD Base                                  |      | 0.4                    | 4                  | 12        | μΑ                                | 3.0V       |                       |
| D200A   |                |                                           |      | 20                     | _                  | _         | μΑ                                | 3.0V       | VREGPM = 0            |
| D201    | IPD_WDT        | Low-Frequency Internal Oscillator/<br>WDT | —    | 0.4                    | 3                  | 10        | μA                                | 3.0V       |                       |
| D201    | IPD_WDT        | Low-Frequency Internal Oscillator/<br>WDT | _    | 0.6                    | 5                  | 13        | μΑ                                | 3.0V       |                       |
| D202    | IPD_SOSC       | Secondary Oscillator (Sosc)               | _    | 0.6                    | 5                  | 13        | μΑ                                | 3.0V       |                       |
| D202    | IPD_SOSC       | Secondary Oscillator (SOSC)               | -    | 0.8                    | 8.5                | 15        | μΑ                                | 3.0V       |                       |
| D203    | IPD_FVR        | FVR                                       |      | 31                     | —                  | —         | μΑ                                | 3.0V       | FVRCON = 0X81 or 0x84 |
| D203    | IPD_FVR        | FVR                                       |      | 32                     | —                  | —         | μΑ                                | 3.0V       | FVRCON = 0X81 or 0x84 |
| D204    | IPD_BOR        | Brown-out Reset (BOR)                     | _    | 9                      | 14                 | 18        | μΑ                                | 3.0V       |                       |
| D204    | IPD_BOR        | Brown-out Reset (BOR)                     | _    | 14                     | 19                 | 21        | μΑ                                | 3.0V       |                       |
| D205    | IPD_LPBOR      | Low-Power Brown-out Reset (LPBOR)         | -    | 0.5                    | _                  | _         | μΑ                                | 3.0V       |                       |
| D205    | IPD_LPBOR      | Low-Power Brown-out Reset (LPBOR)         |      | 0.7                    | _                  | _         | μΑ                                | 3.0V       |                       |
| D206    | IPD_HLVD       | High/Low Voltage Detect (HLVD)            | -    | 31                     | _                  | _         | μΑ                                | 3.0V       |                       |
| D206    | IPD_HLVD       | High/Low Voltage Detect (HLVD)            | -    | 32                     | _                  | _         | μΑ                                | 3.0V       |                       |
| D207    | IPD_ADCA       | ADC - Active                              |      | 250                    | _                  | _         | μΑ                                | 3.0V       | ADC is converting (4) |
| D207    | IPD_ADCA       | ADC - Active                              | _    | 280                    | _                  | —         | μΑ                                | 3.0V       | ADC is converting (4) |
| D208    | IPD_CMP        | Comparator                                |      | 25                     | 38                 | 40        | μΑ                                | 3.0V       |                       |
| D208    | IPD CMP        | Comparator                                | _    | 28                     | 50                 | 60        | μA                                | 3.0V       |                       |

# TABLE 37-3: POWER-DOWN CURRENT (IPD)<sup>(1,2)</sup>

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

Note 1: The peripheral current is the sum of the base IDD and the additional current consumed when this peripheral is enabled. The peripheral △ current can be determined by subtracting the base IDD or IPD current from this limit. Max. values should be used when calculating total current consumption.

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

3: All peripheral currents listed are on a per-peripheral basis if more than one instance of a peripheral is available.

4: ADC clock source is FRC.

#### **37.4** AC Characteristics



