



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

Email: info@E-XFL.COM

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

NOTES:

### REGISTER 3-1: OSCCON: OSCILLATOR CONTROL REGISTER (CONTINUED)

| bit 2 | HFIOFS: HF-INTOSC Frequency Stable bit           |
|-------|--------------------------------------------------|
|       | 1 = HF-INTOSC oscillator frequency is stable     |
|       | 0 = HF-INTOSC oscillator frequency is not stable |

- bit 1-0 SCS<1:0>: System Clock Select bits<sup>(4)</sup>
  - 1x = Internal oscillator block (LF-INTOSC, MF-INTOSC or HF-INTOSC)
  - 01 = SOSC oscillator
  - 00 = Default primary oscillator (OSC1/OSC2 or HF-INTOSC with or without PLL; defined by the FOSC<3:0> Configuration bits, CONFIG1H<3:0>)
- Note 1: The Reset state depends on the state of the IESO Configuration bit (CONFIG1H<7>).
  - 2: Modifying these bits will cause an immediate clock frequency switch if the internal oscillator is providing the device clocks.
  - 3: The source is selected by the INTSRC bit (OSCTUNE<7>).
  - 4: Modifying these bits will cause an immediate clock source switch.
  - 5: INTSRC = OSCTUNE<7> and MFIOSEL = OSCCON2<0>.
  - 6: This is the lowest power option for an internal source.

#### REGISTER 3-2: OSCCON2: OSCILLATOR CONTROL REGISTER 2

| U-0   | R-0     | U-0 | R/W-1                  | R/W-0    | U-0 | R-x    | R/W-0   |
|-------|---------|-----|------------------------|----------|-----|--------|---------|
| —     | SOSCRUN | _   | SOSCDRV <sup>(1)</sup> | SOSCGO — | —   | MFIOFS | MFIOSEL |
| bit 7 |         |     |                        |          |     |        | bit 0   |

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

| bit 7   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                      |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | SOSCRUN: SOSC Run Status bit                                                                                                                                                                                                                                                                    |
|         | <ul><li>1 = System clock comes from a secondary SOSC</li><li>0 = System clock comes from an oscillator other than SOSC</li></ul>                                                                                                                                                                |
| bit 5   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                      |
| bit 4   | SOSCDRV: Secondary Oscillator Drive Control bit <sup>(1)</sup>                                                                                                                                                                                                                                  |
|         | <ul> <li>1 = High-power SOSC circuit is selected</li> <li>0 = Low/high-power select is done via the SOSCSEL&lt;1:0&gt; Configuration bits</li> </ul>                                                                                                                                            |
| bit 3   | SOSCGO: Oscillator Start Control bit                                                                                                                                                                                                                                                            |
|         | <ul> <li>1 = Oscillator is running even if no other sources are requesting it.</li> <li>0 = Oscillator is shut off if no other sources are requesting it (When the SOSC is selected to run from<br/>a digital clock input, rather than an external crystal, this bit has no effect.)</li> </ul> |
| bit 2   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                      |
| bit 1   | MFIOFS: MF-INTOSC Frequency Stable bit                                                                                                                                                                                                                                                          |
|         | 1 = MF-INTOSC is stable<br>0 = MF-INTOSC is not stable                                                                                                                                                                                                                                          |
| bit 0   | MFIOSEL: MF-INTOSC Select bit                                                                                                                                                                                                                                                                   |
|         | <ul> <li>1 = MF-INTOSC is used in place of HF-INTOSC frequencies of 500 kHz, 250 kHz and 31.25 kHz</li> <li>0 = MF-INTOSC is not used</li> </ul>                                                                                                                                                |
| Note 1: | When SOSC is selected to run from a digital clock input, rather than an external crystal, this bit has no effect.                                                                                                                                                                               |





### REGISTER 7-1: EECON1: EEPROM CONTROL REGISTER 1

| R/W-x | R/W-x | U-0 | R/W-0 | R/W-x                | R/W-0 | R/S-0 | R/S-0 |
|-------|-------|-----|-------|----------------------|-------|-------|-------|
| EEPGD | CFGS  | —   | FREE  | WRERR <sup>(1)</sup> | WREN  | WR    | RD    |
| bit 7 |       |     |       |                      |       |       | bit 0 |

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

| bit 7  | EEPGD: Flash Program or Data EEPROM Memory Select bit                                                                                                 |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | 1 = Accesses Flash program memory                                                                                                                     |
|        | 0 = Accesses data EEPROM memory                                                                                                                       |
| bit 6  | CFGS: Flash Program/Data EEPROM or Configuration Select bit                                                                                           |
|        | 1 = Accesses Configuration registers                                                                                                                  |
|        | 0 = Accesses Flash program or data EEPROM memory                                                                                                      |
| bit 5  | Unimplemented: Read as '0'                                                                                                                            |
| bit 4  | FREE: Flash Row Erase Enable bit                                                                                                                      |
|        | 1 = Erases the program memory row addressed by TBLPTR on the next WR command                                                                          |
|        | (cleared by completion of erase operation)                                                                                                            |
| 1.11.0 | 0 = Performs write-only                                                                                                                               |
| bit 3  | WRERR: Flash Program/Data EEPROM Error Flag bit"                                                                                                      |
|        | 1 = A write operation is prematurely terminated (any Reset during self-timed programming in normal operation or an improper write attempt)            |
|        | 0 = The write operation completed                                                                                                                     |
| bit 2  | WREN: Flash Program/Data EEPROM Write Enable bit                                                                                                      |
|        | 1 = Allows write cycles to Flash program/data EEPROM                                                                                                  |
|        | 0 = Inhibits write cycles to Flash program/data EEPROM                                                                                                |
| bit 1  | WR: Write Control bit                                                                                                                                 |
|        | 1 = Initiates a data EEPROM erase/write cycle or, a program memory erase cycle or write cycle.                                                        |
|        | (The operation is self-timed and the bit is cleared by hardware once the write is complete.<br>The WR bit can only be set (not cleared) in software ) |
|        | 0 = Write cvcle to the EEPROM is complete                                                                                                             |
| bit 0  | RD: Read Control bit                                                                                                                                  |
|        | 1 = Initiates an EEPROM read (Read takes one cycle, RD is cleared in hardware. The RD bit can only                                                    |
|        | be set (not cleared) in software. RD bit cannot be set when EEPGD = 1 or CFGS = 1.)                                                                   |
|        | 0 = Does not initiate an EEPROM read                                                                                                                  |
|        |                                                                                                                                                       |

**Note 1:** When a WRERR occurs, the EEPGD and CFGS bits are not cleared. This allows tracing of the error condition.

| EXAMPLE 7-3: | WRITING TO FLASH PROGRAM MEMORY (CONTINUED) |
|--------------|---------------------------------------------|

| PROGRAM_MEMORY | PROGRAM_MEMORY |         |       |                                 |  |  |  |
|----------------|----------------|---------|-------|---------------------------------|--|--|--|
|                | BSF            | EECON1, | EEPGD | ; point to Flash program memory |  |  |  |
|                | BCF            | EECON1, | CFGS  | ; access Flash program memory   |  |  |  |
|                | BSF            | EECON1, | WREN  | ; enable write to memory        |  |  |  |
|                | BCF            | INTCON, | GIE   | ; disable interrupts            |  |  |  |
|                | MOVLW          | 55h     |       |                                 |  |  |  |
| Required       | MOVWF          | EECON2  |       | ; write 55h                     |  |  |  |
| Sequence       | MOVLW          | 0AAh    |       |                                 |  |  |  |
|                | MOVWF          | EECON2  |       | ; write OAAh                    |  |  |  |
|                | BSF            | EECON1, | WR    | ; start program (CPU stall)     |  |  |  |
|                | BSF            | INTCON, | GIE   | ; re-enable interrupts          |  |  |  |
|                | BCF            | EECON1, | WREN  | ; disable write to memory       |  |  |  |

#### 7.5.2 WRITE VERIFY

Depending on the application, good programming practice may dictate that the value written to the memory should be verified against the original value. This should be used in applications where excessive writes can stress bits near the specification limit.

# 7.5.3 UNEXPECTED TERMINATION OF WRITE OPERATION

If a write is terminated by an unplanned event, such as loss of power or an unexpected Reset, the memory location just programmed should be verified and reprogrammed if needed. If the write operation is interrupted by a MCLR Reset or a WDT Time-out Reset during normal operation, the user can check the WRERR bit and rewrite the location(s) as needed.

#### 7.5.4 PROTECTION AGAINST SPURIOUS WRITES

To protect against spurious writes to Flash program memory, the write initiate sequence must also be followed. See Section 28.0 "Special Features of the CPU" for more detail.

## 7.6 Flash Program Operation During Code Protection

See Section 28.6 "Program Verification and Code Protection" for details on code protection of Flash program memory.

| Name    | Bit 7                                                                             | Bit 6          | Bit 5        | Bit 4           | Bit 3                 | Bit 2  | Bit 1         | Bit 0  |
|---------|-----------------------------------------------------------------------------------|----------------|--------------|-----------------|-----------------------|--------|---------------|--------|
| TBLPTRU | — — bit 21 <sup>(1)</sup> Program Memory Table Pointer Upper Byte (TBLPTR<20:16>) |                |              |                 |                       |        | 20:16>)       |        |
| TBPLTRH | Program Me                                                                        | mory Table P   | ointer High  | n Byte (TBLPT   | <sup>-</sup> R<15:8>) |        |               |        |
| TBLPTRL | Program Me                                                                        | mory Table P   | ointer Low   | Byte (TBLPT     | R<7:0>)               |        |               |        |
| TABLAT  | Program Memory Table Latch                                                        |                |              |                 |                       |        |               |        |
| INTCON  | GIE/GIEH                                                                          | PEIE/GIEL      | TMR0IE       | INT0IE          | RBIE                  | TMR0IF | <b>INT0IF</b> | RBIF   |
| EECON2  | EEPROM Co                                                                         | ontrol Registe | r 2 (not a p | physical regist | ter)                  |        |               |        |
| EECON1  | EEPGD                                                                             | CFGS           | —            | FREE            | WRERR                 | WREN   | WR            | RD     |
| IPR4    | TMR4IP                                                                            | EEIP           | CMP2IP       | CMP1IP          | _                     | CCP5IP | CCP4IP        | CCP3IP |
| PIR4    | TMR4IF                                                                            | EEIF           | CMP2IF       | CMP1IF          |                       | CCP5IF | CCP4IF        | CCP3IF |
| PIE4    | TMR4IE                                                                            | EEIE           | CMP2IE       | CMP1IE          | _                     | CCP5IE | CCP4IE        | CCP3IE |

### TABLE 7-2: REGISTERS ASSOCIATED WITH PROGRAM FLASH MEMORY

Legend: — = unimplemented, read as '0'. Shaded cells are not used during Flash/EEPROM access.

**Note 1:** Bit 21 of the TBLPTRU allows access to the device Configuration bits.

# 11.4 PORTC, TRISC and LATC Registers

PORTC is an eight-bit wide, bidirectional port. The corresponding Data Direction and Output Latch registers are TRISC and LATC. Only PORTC pins, RC2 through RC7, are digital only pins.

PORTC is multiplexed with CCP, MSSP and EUSARTx peripheral functions (Table 11-5). The pins have Schmitt Trigger input buffers. The pins for CCP, SPI and EUSARTx are also configurable for open-drain output whenever these functions are active. Open-drain configuration is selected by setting the SSPOD, CCPxOD and U1OD control bits in the ODCON register.

RC1 is configurable for open-drain output when CCP2 is active on this pin. Open-drain configuration is selected by setting the CCP2OD control bit (ODCON<3>).

When enabling peripheral functions, use care in defining TRIS bits for each PORTC pin. Some peripherals can override the TRIS bit to make a pin an output or input. Consult the corresponding peripheral section for the correct TRIS bit settings.

Note: These pins are configured as digital inputs on any device Reset.

The contents of the TRISC register are affected by peripheral overrides. Reading TRISC always returns the current contents, even though a peripheral device may be overriding one or more of the pins.

| EXAMPL | _E 11-3: | INITIALIZING PORTC                         |
|--------|----------|--------------------------------------------|
| CLRF   | PORTC    | ; Initialize PORTC by<br>; clearing output |
|        |          | ; data latches                             |
| CLRF   | LATC     | ; Alternate method                         |
|        |          | ; to clear output                          |
|        |          | ; data latches                             |
| MOVLW  | OCFh     | ; Value used to                            |
|        |          | ; initialize data                          |
|        |          | ; direction                                |
| MOVWF  | TRISC    | ; Set RC<3:0> as inputs                    |
|        |          | ; RC<5:4> as outputs                       |
|        |          | ; RC<7:6> as inputs                        |

#### PORTE, TRISE and 11.6 LATE Registers

PORTE is a seven-bit-wide, bidirectional port. The corresponding Data Direction and Output Latch registers are TRISE and LATE.

| Note: | PORTE is unavailable on 28-pin devices. |
|-------|-----------------------------------------|
|-------|-----------------------------------------|

All pins on PORTE are implemented with Schmitt Trigger input buffers. Each pin is individually configurable as an input or output.

Note: These pins are configured as digital inputs on any device Reset.

Each of the PORTE pins has a weak internal pull-up. A single control bit can turn off all the pull-ups. This is performed by clearing bit, REPU (PADCFG1<6>). The

weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on any device Reset.

PORTE is also multiplexed with the Parallel Slave Port address lines. RE1 and RE0 are multiplexed with the Parallel Slave Port (PSP) control signals, WR and RD.

| EXAMPL | _E 11-5: |   | INITIALIZING PORTE    |
|--------|----------|---|-----------------------|
| CLRF   | PORTE    | ; | Initialize PORTE by   |
|        |          | ; | clearing output       |
|        |          | ; | data latches          |
| CLRF   | LATE     | ; | Alternate method      |
|        |          | ; | to clear output       |
|        |          | ; | data latches          |
| MOVLW  | 03h      | ; | Value used to         |
|        |          | ; | initialize data       |
|        |          | ; | direction             |
| MOVWF  | TRISE    | ; | Set RE<1:0> as inputs |
|        |          | ; | RE<7:2> as outputs    |
|        |          |   |                       |

| Pin Name         | Function               | TRIS<br>Setting | I/O | I/O Type | Description                                                                              |  |  |
|------------------|------------------------|-----------------|-----|----------|------------------------------------------------------------------------------------------|--|--|
| RE0/AN5/RD       | RE0                    | 0               | 0   | DIG      | LATE<0> data output.                                                                     |  |  |
|                  |                        | 1               | Ι   | ST       | PORTE<0> data input.                                                                     |  |  |
|                  | AN5                    | 1               | Ι   | ANA      | A/D Input Channel 5. Default input configuration on POR; does not affect digital output. |  |  |
|                  | RD                     | x               | 0   | DIG      | Parallel Slave Port read strobe pin.                                                     |  |  |
|                  |                        | x               | Ι   | ST       | Parallel Slave Port read pin.                                                            |  |  |
| RE1/AN <u>6/</u> | RE1                    | 0               | 0   | DIG      | LATE<1> data output.                                                                     |  |  |
| C10UT/WR         |                        | 1               | -   | ST       | PORTE<1> data input.                                                                     |  |  |
|                  | AN6                    | 1               | Ι   | ANA      | A/D Input Channel 5. Default input configuration on POR; does not affect digital output. |  |  |
|                  | C10UT                  | 0               | 0   | DIG      | Comparator 1 output; takes priority over port data.                                      |  |  |
|                  | WR                     | x               | 0   | DIG      | Parallel Slave Port write strobe pin.                                                    |  |  |
|                  |                        | x               | Ι   | ST       | Parallel Slave Port write pin.                                                           |  |  |
| RE2/AN <u>7/</u> | RE2                    | 0               | 0   | DIG      | LATE<2> data output.                                                                     |  |  |
| C2OUT/CS         |                        | 1               | Ι   | ST       | PORTE<2> data input.                                                                     |  |  |
|                  | AN7                    | 1               | I   | ANA      | A/D Input Channel 7. Default input configuration on POR; does not affect digital output. |  |  |
|                  | C2OUT                  | 0               | 0   | DIG      | Comparator 2 output; takes priority over port data.                                      |  |  |
|                  | CS                     | x               | Ι   | ST       | Parallel Slave Port chip select.                                                         |  |  |
| RE3              | RE3                    | 1               | Ι   | ST       | PORT<3> data input.                                                                      |  |  |
| RE4/CANRX        | RE4 <sup>(1)</sup>     | 0               | 0   | DIG      | LATE<4> data output.                                                                     |  |  |
|                  |                        | 1               | Ι   | ST       | PORTE<4> data input.                                                                     |  |  |
|                  | CANRX <sup>(1,2)</sup> | 1               | Ι   | ST       | CAN bus RX.                                                                              |  |  |

#### TABLE 11-9: PORTE FUNCTIONS

∟egend: Input, ANA = Analog Signal, DIG = CMOS Output, ST = Schmitt Trigger Buffer Input,

x = Don't care (TRIS bit does not affect port direction or is overridden for this option)

Note 1: These bits are unavailable for 40 and 44-pin devices (PIC18F4XK0).

2: This is the alternate pin assignment for CANRX and CANTX on 64-pin devices (PIC18F6XK80) when the CANMX Configuration bit is cleared.

### REGISTER 12-1: MDCON: MODULATION CONTROL REGISTER

| R/W-0        | R/W-0           | R/W-1            | R/W-0           | R/W-0            | U-0                       | U-0               | R/W-0  |
|--------------|-----------------|------------------|-----------------|------------------|---------------------------|-------------------|--------|
| MDEN         | MDOE            | MDSLR            | MDOPOL          | MDO              | —                         | —                 | MDBIT  |
| bit 7        |                 |                  |                 |                  |                           |                   | bit 0  |
|              |                 |                  |                 |                  |                           |                   |        |
| Legend:      |                 |                  |                 |                  |                           |                   |        |
| R = Readab   | le bit          | W = Writable     | bit             | U = Unimpler     | mented bit, read          | as '0'            |        |
| -n = Value a | t POR           | '1' = Bit is set | :               | '0' = Bit is cle | ared                      | x = Bit is unkr   | nown   |
|              |                 |                  |                 |                  |                           |                   |        |
| bit 7        | MDEN: Modu      | lator Module E   | nable bit       |                  |                           |                   |        |
|              | 1 = Modulato    | or module is en  | abled and mix   | ing input signa  | als                       |                   |        |
|              | 0 = Modulato    | or module is dis | sabled and has  | s no output      |                           |                   |        |
| bit 6        | MDOE: Modu      | lator Module F   | Pin Output Ena  | ble bit          |                           |                   |        |
|              | 1 = Modulato    | or pin output is | enabled         |                  |                           |                   |        |
|              | 0 = Modulato    | or pin output is | disabled        |                  |                           |                   |        |
| bit 5        | MDSLR: MDO      | OUT Pin Slew     | Rate Limiting I | oit              |                           |                   |        |
|              | 1 = MDOUT       | pin slew rate li | miting is enabl | led              |                           |                   |        |
|              | 0 = MDOUT       | pin slew rate li | miting is disab | led              |                           |                   |        |
| bit 4        | MDOPOL: M       | odulator Outpu   | t Polarity Sele | ct bit           |                           |                   |        |
|              | 1 = Modulato    | or output signa  | is inverted     |                  |                           |                   |        |
|              |                 | or output signa  | is not inverted | נ                |                           |                   |        |
| bit 3        | MDO: Modula     | ator Output bit  |                 |                  | . (2)                     |                   |        |
|              | Displays the o  | current output   | value of the me | odulator modu    | le.(2)                    |                   |        |
| bit 2-1      | Unimplemen      | ted: Read as '   | 0'              |                  |                           |                   |        |
| bit 0        | MDBIT: Modu     | ulator Source In | nput bit        |                  |                           |                   |        |
|              | Allows softwa   | are to manually  | set modulatio   | n source input   | to module. <sup>(1)</sup> |                   |        |
| Note 1: ⊤    | he MDBIT must b | be selected as   | the modulatior  | n source in the  | MDSRC registe             | er for this opera | ation. |

2: The modulated output frequency can be greater and asynchronous from the clock that updates this register bit. The bit value may not be valid for higher speed modulator or carrier signals.

The CTMU current source may be trimmed with the trim bits in CTMUICON, using an iterative process to get the exact current desired. Alternatively, the nominal value without adjustment may be used. That value may be stored by software, for use in all subsequent capacitive or time measurements.

To calculate the optimal value for RCAL, the nominal current must be chosen.

For example, if the A/D Converter reference voltage is 3.3V, use 70% of full scale (or 2.31V) as the desired approximate voltage to be read by the A/D Converter. If the range of the CTMU current source is selected to be 0.55  $\mu$ A, the resistor value needed is calculated as RCAL = 2.31V/0.55  $\mu$ A, for a value of 4.2 MΩ. Similarly, if the current source is chosen to be 5.5  $\mu$ A, RCAL would be 420,000Ω, and 42,000Ω if the current source is set to 55  $\mu$ A.

#### FIGURE 18-2: CTMU CURRENT SOURCE CALIBRATION CIRCUIT



A value of 70% of full-scale voltage is chosen to make sure that the A/D Converter is in a range that is well above the noise floor. If an exact current is chosen to incorporate the trimming bits from CTMUICON, the resistor value of RCAL may need to be adjusted accordingly. RCAL also may be adjusted to allow for available resistor values. RCAL should be of the highest precision available, in light of the precision needed for the circuit that the CTMU will be measuring. A recommended minimum would be 0.1% tolerance.

The following examples show a typical method for performing a CTMU current calibration.

• Example 18-1 demonstrates how to initialize the A/D Converter and the CTMU.

This routine is typical for applications using both modules.

• Example 18-2 demonstrates one method for the actual calibration routine.

This method manually triggers the A/D Converter to demonstrate the entire step-wise process. It is also possible to automatically trigger the conversion by setting the CTMU's CTTRIG bit (CTMUCONH<0>).

### EXAMPLE 18-4: ROUTINE FOR CAPACITIVE TOUCH SWITCH

```
#include "p18cxxx.h"
#define COUNT 500
                                         //@ 8MHz = 125uS.
#define DELAY for(i=0;i<COUNT;i++)</pre>
#define OPENSW 1000
                                         //Un-pressed switch value
#define TRIP 300
                                         //Difference between pressed
                                         //and un-pressed switch
#define HYST 65
                                         //amount to change
                                         //from pressed to un-pressed
#define PRESSED 1
#define UNPRESSED 0
int main(void)
ł
   unsigned int Vread;
                                         //storage for reading
   unsigned int switchState;
   int i;
    //assume CTMU and A/D have been setup correctly
    //see Example 25-1 for CTMU & A/D setup
   setup();
   CTMUCONHbits.CTMUEN = 1;
                                         //Enable the CTMU
   CTMUCONHbits.IDISSEN = 1;
                                         //drain charge on the circuit
                                         //wait 125us
   DELAY;
   CTMUCONHbits.IDISSEN = 0;
                                         //end drain of circuit
   CTMUCONLbits.EDG1STAT = 1;
                                         //Begin charging the circuit
                                         //using CTMU current source
                                         //wait for 125us
   DELAY;
   CTMUCONLbits.EDG1STAT = 0;
                                         //Stop charging circuit
   PIR1bits.ADIF = 0;
                                         //make sure A/D Int not set
                                         //and begin A/D conv.
   ADCON0bits.GO=1;
   while(!PIR1bits.ADIF);
                                         //Wait for A/D convert complete
   Vread = ADRES;
                                         //Get the value from the A/D
    if(Vread < OPENSW - TRIP)
    {
       switchState = PRESSED;
   else if(Vread > OPENSW - TRIP + HYST)
    {
       switchState = UNPRESSED;
    }
```



# 25.0 COMPARATOR VOLTAGE REFERENCE MODULE

The comparator voltage reference is a 32-tap resistor ladder network that provides a selectable reference voltage. Although its primary purpose is to provide a reference for the analog comparators, it may also be used independently of them.

A block diagram of the module is shown in Figure 25-1. The resistor ladder is segmented to provide a range of CVREF values and has a power-down function to conserve power when the reference is not being used. The module's supply reference can be provided from either device VDD/VSS or an external voltage reference.

## 25.1 Configuring the Comparator Voltage Reference

The comparator voltage reference module is controlled through the CVRCON register (Register 25-1). The comparator voltage reference provides a range of output voltage with 32 levels.

The CVR<4:0> selection bits (CVRCON<4:0>) offer a range of output voltages. Equation 25-1 shows the how the comparator voltage reference is computed.

# EQUATION 25-1:

$$\frac{\text{If CVRSS} = 1:}{\text{CVREF}} = \left(\text{VREF} + \frac{\text{CVR} < 4:0>}{32}\right) \cdot (\text{VREF} + - \text{VREF})$$

$$\frac{\text{If CVRSS} = 0:}{\text{CVREF}} = \left(\text{AVSS} + \frac{\text{CVR} < 4:0>}{32}\right) \cdot (\text{AVDD} - \text{AVSS})$$

The comparator reference supply voltage can come from either VDD and Vss, or the external VREF+ and VREF- that are multiplexed with RA3 and RA2. The voltage source is selected by the CVRSS bit (CVRCON<5>).

The settling time of the comparator voltage reference must be considered when changing the CVREF output (see Table 31-2 in **Section 31.0** "**Electrical Characteristics**").

# **REGISTER 25-1: CVRCON: COMPARATOR VOLTAGE REFERENCE CONTROL REGISTER**

| R/W-0         | R/W-0            | R/W-0               | R/W-0          | R/W-0               | R/W-0             | R/W-0           | R/W-0 |
|---------------|------------------|---------------------|----------------|---------------------|-------------------|-----------------|-------|
| CVREN         | CVROE            | CVRSS               | CVR4           | CVR3                | CVR2              | CVR1            | CVR0  |
| bit 7         |                  |                     |                |                     |                   |                 | bit 0 |
|               |                  |                     |                |                     |                   |                 |       |
| Legend:       |                  |                     |                |                     |                   |                 |       |
| R = Readable  | e bit            | W = Writable b      | bit            | U = Unimplem        | nented bit, read  | d as '0'        |       |
| -n = Value at | POR              | '1' = Bit is set    |                | '0' = Bit is clea   | ared              | x = Bit is unkr | nown  |
|               |                  |                     |                |                     |                   |                 |       |
| bit 7         | CVREN: Com       | parator Voltage     | Reference E    | nable bit           |                   |                 |       |
|               | 1 = CVREF ci     | rcuit powered o     | n              |                     |                   |                 |       |
|               | 0 = CVREF ci     | rcuit powered d     | own            |                     |                   |                 |       |
| bit 6         | CVROE: Com       | nparator VREF C     | utput Enable   | bit                 |                   |                 |       |
|               | 1 = CVREF VC     | oltage level is o   | utput on CVRE  | F pin               |                   |                 |       |
|               | 0 = CVREF vc     | oltage level is di  | sconnected fr  | om CVREF pin        |                   |                 |       |
| bit 5         | CVRSS: Com       | parator VREF S      | ource Selectio | on bit              |                   |                 |       |
|               | 1 = Compara      | tor reference so    | ource, CVRSRO  | c = VREF + - VR     | EF-               |                 |       |
|               | 0 = Compara      | tor reference so    | ource, CVRSRO  | c = AVDD - AVS      | S                 |                 |       |
| bit 4-0       | CVR<4:0>: C      | omparator VRE       | Value Select   | ion $0 \le CVR < 4$ | $:0> \le 31$ bits |                 |       |
|               | When CVRSS       | S = 1:              |                |                     |                   |                 |       |
|               | CVREF = (VRE     | EF-) + (CVR<4:0     | I>/32) ● (VREF | + – VREF-)          |                   |                 |       |
|               | <u>When CVRS</u> | 5 = 0:<br>(C)/P<4.0 |                |                     |                   |                 |       |
|               | GVREF - (AVS     | 55) + (UVK-4.0      | ~132) • (AVDD  | - AV33)             |                   |                 |       |

# 27.4.3 MODE 2 – ENHANCED FIFO MODE

In Mode 2, two or more receive buffers are used to form the receive FIFO (first in, first out) buffer. There is no one-to-one relationship between the receive buffer and acceptance filter registers. Any filter that is enabled and linked to any FIFO receive buffer can generate acceptance and cause FIFO to be updated.

FIFO length is user-programmable, from 2-8 buffers deep. FIFO length is determined by the very first programmable buffer that is configured as a transmit buffer. For example, if Buffer 2 (B2) is programmed as a transmit buffer, FIFO consists of RXB0, RXB1, B0 and B1, creating a FIFO length of 4. If all programmable buffers are configured as receive buffers, FIFO will have the maximum length of 8.

The following is the list of resources available in Mode 2:

- Three transmit buffers: TXB0, TXB1 and TXB2
- Two receive buffers: RXB0 and RXB1
- Six buffers programmable as TX or RX; receive buffers form FIFO: B0-B5
- Automatic RTR handling on B0-B5
- Sixteen acceptance filters: RXF0-RXF15
- Two dedicated acceptance mask registers; RXF15 programmable as third mask: RXM0-RXM1, RXF15
- Programmable data filter on standard identifier messages: SDFLC, useful for DeviceNet protocol

# 27.5 CAN Message Buffers

### 27.5.1 DEDICATED TRANSMIT BUFFERS

The PIC18F66K80 family devices implement three dedicated transmit buffers – TXB0, TXB1 and TXB2. Each of these buffers occupies 14 bytes of SRAM and are mapped into the SFR memory map. These are the only transmit buffers available in Mode 0. Mode 1 and 2 may access these and other additional buffers.

Each transmit buffer contains one Control register (TXBnCON), four Identifier registers (TXBnSIDL, TXBnSIDH, TXBnEIDL, TXBnEIDH), one Data Length Count register (TXBnDLC) and eight Data Byte registers (TXBnDm).

# 27.5.2 DEDICATED RECEIVE BUFFERS

The PIC18F66K80 family devices implement two dedicated receive buffers: RXB0 and RXB1. Each of these buffers occupies 14 bytes of SRAM and are mapped into SFR memory map. These are the only receive buffers available in Mode 0. Mode 1 and 2 may access these and other additional buffers. Each receive buffer contains one Control register (RXBnCON), four Identifier registers (RXBnSIDL, RXBnSIDH, RXBnEIDL, RXBnEIDH), one Data Length Count register (RXBnDLC) and eight Data Byte registers (RXBnDm).

There is also a separate Message Assembly Buffer (MAB) which acts as an additional receive buffer. MAB is always committed to receiving the next message from the bus and is not directly accessible to user firmware. The MAB assembles all incoming messages one by one. A message is transferred to appropriate receive buffers only if the corresponding acceptance filter criteria is met.

## 27.5.3 PROGRAMMABLE TRANSMIT/ RECEIVE BUFFERS

The ECAN module implements six new buffers: B0-B5. These buffers are individually programmable as either transmit or receive buffers. These buffers are available only in Mode 1 and 2. As with dedicated transmit and receive buffers, each of these programmable buffers occupies 14 bytes of SRAM and are mapped into SFR memory map.

Each buffer contains one Control register (BnCON), four Identifier registers (BnSIDL, BnSIDH, BnEIDL, BnEIDH), one Data Length Count register (BnDLC) and eight Data Byte registers (BnDm). Each of these registers contains two sets of control bits. Depending on whether the buffer is configured as transmit or receive, one would use the corresponding control bit set. By default, all buffers are configured as receive buffers. Each buffer can be individually configured as a transmit or receive buffer by setting the corresponding TXENn bit in the BSEL0 register.

When configured as transmit buffers, user firmware may access transmit buffers in any order similar to accessing dedicated transmit buffers. In receive configuration with Mode 1 enabled, user firmware may also access receive buffers in any order required. But in Mode 2, all receive buffers are combined to form a single FIFO. Actual FIFO length is programmable by user firmware. Access to FIFO must be done through the FIFO Pointer bits (FP<4:0>) in the CANCON register. It must be noted that there is no hardware protection against out of order FIFO reads.

#### 27.5.4 PROGRAMMABLE AUTO-RTR BUFFERS

In Mode 1 and 2, any of six programmable transmit/ receive buffers may be programmed to automatically respond to predefined RTR messages without user firmware intervention. Automatic RTR handling is enabled by setting the TX2EN bit in the BSEL0 register and the RTREN bit in the BnCON register. After this setup, when an RTR request is received, the TXREQ bit is automatically set and the current buffer content is automatically queued for transmission as a RTR response. As with all transmit buffers, once the TXREQ bit is set, buffer registers become read-only and any writes to them will be ignored.

The following outlines the steps required to automatically handle RTR messages:

- 1. Set buffer to Transmit mode by setting the TXnEN bit to '1' in the BSEL0 register.
- 2. At least one acceptance filter must be associated with this buffer and preloaded with the expected RTR identifier.
- 3. Bit, RTREN in the BnCON register, must be set to '1'.
- 4. Buffer must be preloaded with the data to be sent as a RTR response.

Normally, user firmware will keep buffer data registers up to date. If firmware attempts to update the buffer while an automatic RTR response is in the process of transmission, all writes to buffers are ignored.

# 27.6 CAN Message Transmission

### 27.6.1 INITIATING TRANSMISSION

For the MCU to have write access to the message buffer, the TXREQ bit must be clear, indicating that the message buffer is clear of any pending message to be transmitted. At a minimum, the SIDH, SIDL and DLC registers must be loaded. If data bytes are present in the message, the Data registers must also be loaded. If the message is to use extended identifiers, the EIDH:EIDL registers must also be loaded and the EXIDE bit set.

To initiate message transmission, the TXREQ bit must be set for each buffer to be transmitted. When TXREQ is set, the TXABT, TXLARB and TXERR bits will be cleared. To successfully complete the transmission, there must be at least one node with matching baud rate on the network. Setting the TXREQ bit does not initiate a message transmission; it merely flags a message buffer as ready for transmission. Transmission will start when the device detects that the bus is available. The device will then begin transmission of the highest priority message that is ready.

When the transmission has completed successfully, the TXREQ bit will be cleared, the TXBnIF bit will be set and an interrupt will be generated if the TXBnIE bit is set.

If the message transmission fails, the TXREQ will remain set, indicating that the message is still pending for transmission and one of the following condition flags will be set. If the message started to transmit but encountered an error condition, the TXERR and the IRXIF bits will be set and an interrupt will be generated. If the message lost arbitration, the TXLARB bit will be set.

# 27.6.2 ABORTING TRANSMISSION

The MCU can request to abort a message by clearing the TXREQ bit associated with the corresponding message buffer (TXBnCON<3> or BnCON<3>). Setting the ABAT bit (CANCON<4>) will request an abort of all pending messages. If the message has not yet started transmission, or if the message started but is interrupted by loss of arbitration or an error, the abort will be processed. The abort is indicated when the module sets the TXABT bit for the corresponding buffer (TXBnCON<6> or BnCON<6>). If the message has started to transmit, it will attempt to transmit the current message fully. If the current message is transmitted fully and is not lost to arbitration or an error, the TXABT bit will not be set because the message was transmitted successfully. Likewise, if a message is being transmitted during an abort request and the message is lost to arbitration or an error, the message will not be retransmitted and the TXABT bit will be set, indicating that the message was successfully aborted.

Once an abort is requested by setting the ABAT or TXABT bits, it cannot be cleared to cancel the abort request. Only CAN module hardware or a POR condition can clear it.

# 28.4 Two-Speed Start-up

The Two-Speed Start-up feature helps to minimize the latency period from oscillator start-up to code execution by allowing the microcontroller to use the INTOSC (LF-INTOSC, MF-INTOSC, HF-INTOSC) oscillator as a clock source until the primary clock source is available. It is enabled by setting the IESO Configuration bit.

Two-Speed Start-up should be enabled only if the primary oscillator mode is LP, XT or HS (Crystal-Based modes). Other sources do not require an OST start-up delay; for these, Two-Speed Start-up should be disabled.

When enabled, Resets and wake-ups from Sleep mode cause the device to configure itself to run from the internal oscillator block as the clock source, following the time-out of the Power-up Timer after a Power-on Reset is enabled. This allows almost immediate code execution while the primary oscillator starts and the OST is running. Once the OST times out, the device automatically switches to PRI\_RUN mode.

To use a higher clock speed on wake-up, the INTOSC or postscaler clock sources can be selected to provide a higher clock speed by setting bits, IRCF<2:0>, immediately after Reset. For wake-ups from Sleep, the INTOSC or postscaler clock sources can be selected by setting the IRCF2:0> bits prior to entering Sleep mode.

In all other power-managed modes, Two-Speed Startup is not used. The device will be clocked by the currently selected clock source until the primary clock source becomes available. The setting of the IESO bit is ignored.

## 28.4.1 SPECIAL CONSIDERATIONS FOR USING TWO-SPEED START-UP

While using the INTOSC oscillator in Two-Speed Startup, the device still obeys the normal command sequences for entering power-managed modes, including multiple SLEEP instructions (refer to **Section 4.1.4 "Multiple Sleep Commands**"). In practice, this means that user code can change the SCS<1:0> bit settings or issue SLEEP instructions before the OST times out. This would allow an application to briefly wake-up, perform routine "housekeeping" tasks and return to Sleep before the device starts to operate from the primary oscillator.

User code can also check if the primary clock source is currently providing the device clocking by checking the status of the OSTS bit (OSCCON<3>). If the bit is set, the primary oscillator is providing the clock. Otherwise, the internal oscillator block is providing the clock during wake-up from Reset or Sleep mode.



### FIGURE 28-3: TIMING TRANSITION FOR TWO-SPEED START-UP (INTOSC TO HSPLL)

#### 28.6.2 DATA EEPROM CODE PROTECTION

The entire data EEPROM is protected from external reads and writes by two bits: CPD and WRTD. CPD inhibits external reads and writes of data EEPROM. WRTD inhibits internal and external writes to data EEPROM. The CPU can always read data EEPROM under normal operation, regardless of the protection bit settings.

#### 28.6.3 CONFIGURATION REGISTER PROTECTION

The Configuration registers can be write-protected. The WRTC bit controls protection of the Configuration registers. In normal execution mode, the WRTC bit is readable only. WRTC can only be written via ICSP or an external programmer.

# 28.7 ID Locations

Eight memory locations (20000h-200007h) are designated as ID locations, where the user can store checksum or other code identification numbers. These locations are both readable and writable during normal execution through the TBLRD and TBLWT instructions or during program/verify. The ID locations can be read when the device is code-protected.

# 28.8 In-Circuit Serial Programming

The PIC18F66K80 family of devices can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data and three other lines for power, ground and the programming voltage. This allows customers to manufacture boards with unprogrammed devices and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

For the various programming modes, see the programming specification

# 28.9 In-Circuit Debugger

When the  $\overline{\text{DEBUG}}$  Configuration bit is programmed to a '0', the In-Circuit Debugger functionality is enabled. This function allows simple debugging functions when used with MPLAB<sup>®</sup> IDE. When the microcontroller has this feature enabled, some resources are not available for general use. Table 28-5 shows which resources are required by the background debugger.

| TABLE 28-5: | DEBUGGER | RESOURCES |
|-------------|----------|-----------|
|-------------|----------|-----------|

| I/O Pins:       | RB6, RB7   |
|-----------------|------------|
| Stack:          | Two levels |
| Program Memory: | 512 bytes  |
| Data Memory:    | 10 bytes   |

To use the In-Circuit Debugger function of the microcontroller, the design must implement In-Circuit Serial Programming connections to MCLR/RE3, VDD, VSS, RB7 and RB6. This will interface to the In-Circuit Debugger module available from Microchip or one of the third-party development tool companies.

| BNC          |                         | Branch if N                                                                               | Branch if Not Carry                                                              |                                                      |                                                         |                 |  |  |  |  |  |
|--------------|-------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------|-----------------|--|--|--|--|--|
| Synta        | ax:                     | BNC n                                                                                     |                                                                                  |                                                      |                                                         | Syntax          |  |  |  |  |  |
| Oper         | ands:                   | -128 ≤ n ≤ 1                                                                              | 127                                                                              |                                                      |                                                         | Operan          |  |  |  |  |  |
| Oper         | ation:                  | if Carry bit i<br>(PC) + 2 + 2                                                            | s '0',<br>2n → PC                                                                |                                                      |                                                         | Operati         |  |  |  |  |  |
| Statu        | is Affected:            | None                                                                                      |                                                                                  |                                                      |                                                         | Status          |  |  |  |  |  |
| Enco         | oding:                  | 1110                                                                                      | 0011                                                                             | nnnn                                                 | nnnn                                                    | Encodi          |  |  |  |  |  |
| Desc         | cription:               | If the Carry will branch.                                                                 | bit is '0', f                                                                    | then the                                             | e program                                               | Descrip         |  |  |  |  |  |
|              |                         | The 2's con<br>added to the<br>incrementer<br>instruction,<br>PC + 2 + 2r<br>two-cycle in | nplement<br>e PC. Sind<br>d to fetch<br>the new a<br>n. This ins<br>instruction. | number<br>ce the P<br>the nex<br>iddress<br>truction | ; '2n', is<br>'C will have<br>t<br>will be<br>is then a |                 |  |  |  |  |  |
| Word         | ls:                     | 1                                                                                         |                                                                                  |                                                      |                                                         | Words:          |  |  |  |  |  |
| Cycle        | es:                     | 1(2)                                                                                      |                                                                                  |                                                      |                                                         | Cycles:         |  |  |  |  |  |
| Q C<br>If Ju | ycle Activity:<br>Imp:  |                                                                                           |                                                                                  |                                                      |                                                         | Q Cyc<br>If Jum |  |  |  |  |  |
|              | Q1                      | Q2                                                                                        | Q3                                                                               |                                                      | Q4                                                      |                 |  |  |  |  |  |
|              | Decode                  | Read literal<br>'n'                                                                       | Proces<br>Data                                                                   | s                                                    | Write to<br>PC                                          |                 |  |  |  |  |  |
|              | No                      | No                                                                                        | No                                                                               |                                                      | No                                                      |                 |  |  |  |  |  |
|              | operation               | operation                                                                                 | operatio                                                                         | on c                                                 | operation                                               |                 |  |  |  |  |  |
| If No        | o Jump:                 |                                                                                           |                                                                                  |                                                      |                                                         | lf No J         |  |  |  |  |  |
|              | Q1                      | Q2                                                                                        | Q3                                                                               |                                                      | Q4                                                      |                 |  |  |  |  |  |
|              | Decode                  | Read literal                                                                              | Proces                                                                           | s                                                    | No                                                      |                 |  |  |  |  |  |
|              |                         | 'n'                                                                                       | Data                                                                             | C                                                    | peration                                                | J L             |  |  |  |  |  |
| <u>Exar</u>  | nple:                   | HERE                                                                                      | BNC J                                                                            | ump                                                  |                                                         | Examp           |  |  |  |  |  |
|              | Before Instruc          | tion                                                                                      |                                                                                  |                                                      |                                                         | Be              |  |  |  |  |  |
|              | PC<br>After Instruction | = ad                                                                                      | dress (H                                                                         | ERE)                                                 |                                                         | ۸ 4             |  |  |  |  |  |
|              | If Carry                | = 0.                                                                                      |                                                                                  |                                                      |                                                         | AI              |  |  |  |  |  |
|              | PC                      | = ad                                                                                      | dress (J                                                                         | ump)                                                 |                                                         |                 |  |  |  |  |  |
|              | If Carry<br>PC          | = 1;<br>= ad                                                                              | dress (H                                                                         | ERE +                                                | 2)                                                      |                 |  |  |  |  |  |

| BNN               |                        | Branch                                                         | Branch if Not Negative                                    |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|-------------------|------------------------|----------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------|----------------------------------------------|--|--|--|--|
| Synta             | ax:                    | BNN                                                            | BNN n                                                     |                                                                     |                                                     |                                          |                                              |  |  |  |  |
| Oper              | ands:                  | -128 ≤ I                                                       | n ≤ 1                                                     | 27                                                                  |                                                     |                                          |                                              |  |  |  |  |
| Oper              | ation:                 | if Nega<br>(PC) + :                                            | tive  <br>2 + 2                                           | bit is '0',<br>$2n \rightarrow PC$                                  | ;                                                   |                                          |                                              |  |  |  |  |
| Statu             | s Affected:            | None                                                           | None                                                      |                                                                     |                                                     |                                          |                                              |  |  |  |  |
| Enco              | oding:                 | 1110                                                           | )                                                         | 0111                                                                | nnr                                                 | ın                                       | nnnn                                         |  |  |  |  |
| Desc              | cription:              | If the N<br>program                                            | If the Negative bit is '0', then the program will branch. |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|                   |                        | The 2's<br>added t<br>increme<br>instruct<br>PC + 2<br>two-cyc | con<br>to the<br>enter<br>ion,<br>+ 2r<br>cle in          | plemen<br>PC. Sin<br>to fetch<br>the new<br>n. This in<br>struction | t numl<br>nce the<br>n the r<br>addre<br>struction. | per, '<br>e PC<br>next<br>ss w<br>ion is | i2n', is<br>will have<br>/ill be<br>s then a |  |  |  |  |
| Word              | ls:                    | 1                                                              | 1                                                         |                                                                     |                                                     |                                          |                                              |  |  |  |  |
| Cycle             | es:                    | 1(2)                                                           |                                                           |                                                                     |                                                     |                                          |                                              |  |  |  |  |
| Q C<br>If Ju      | ycle Activity:<br>imp: |                                                                |                                                           |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|                   | Q1                     | Q2                                                             |                                                           | Q3                                                                  | ;                                                   |                                          | Q4                                           |  |  |  |  |
|                   | Decode                 | Read lite<br>'n'                                               | ral                                                       | Process<br>Data                                                     |                                                     | V                                        | /rite to<br>PC                               |  |  |  |  |
|                   | No                     | No                                                             |                                                           | No                                                                  |                                                     |                                          | No                                           |  |  |  |  |
|                   | operation              | operatio                                                       | n                                                         | operat                                                              | ion                                                 | ор                                       | eration                                      |  |  |  |  |
| lf No             | o Jump:                |                                                                |                                                           |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|                   | Q1                     | Q2                                                             |                                                           | Q3                                                                  | 6                                                   |                                          | Q4                                           |  |  |  |  |
|                   | Decode                 | Read lite                                                      | ral                                                       | Proce                                                               | SS                                                  |                                          | No                                           |  |  |  |  |
|                   |                        | ʻn'                                                            |                                                           | Data                                                                | a                                                   | ор                                       | eration                                      |  |  |  |  |
| Example:          |                        | HERE                                                           |                                                           | BNN                                                                 | Jump                                                |                                          |                                              |  |  |  |  |
|                   | Before Instruc         | tion                                                           |                                                           |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|                   | PC                     | =                                                              | ade                                                       | dress (                                                             | HERE)                                               |                                          |                                              |  |  |  |  |
| After Instruction |                        | on –                                                           | <u>.</u> .                                                |                                                                     |                                                     |                                          |                                              |  |  |  |  |
|                   | PC                     | /e =                                                           | u;<br>ado                                                 | dress ()                                                            | Jump)                                               |                                          |                                              |  |  |  |  |
|                   | If Negativ             | /e =                                                           | 1;                                                        | ( ·                                                                 |                                                     | _                                        |                                              |  |  |  |  |
|                   | PC                     | =                                                              | add                                                       | uess ()                                                             | HERE                                                | + 2                                      | :)                                           |  |  |  |  |

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

| PIC18F66K80 Family<br>(Industrial/Extended) |                          | $\begin{tabular}{ c c c c c } \hline Standard Operating Conditions (unless otherwise stated) \\ Operating temperature & -40^\circ C \le TA \le +85^\circ C \text{ for industrial} \\ -40^\circ C \le TA \le +125^\circ C \text{ for extended} \\ \hline \end{tabular}$ |     |       |        |                                                 |              |  |  |  |
|---------------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|--------|-------------------------------------------------|--------------|--|--|--|
| Param<br>No.                                | Device                   | Тур                                                                                                                                                                                                                                                                    | Max | Units |        | Conditions                                      |              |  |  |  |
|                                             | Supply Current (IDD) Cor | nt. <sup>(2,3)</sup>                                                                                                                                                                                                                                                   |     |       |        |                                                 |              |  |  |  |
|                                             | PIC18LFXXK80             | 260                                                                                                                                                                                                                                                                    | 380 | μA    | -40°C  |                                                 |              |  |  |  |
|                                             |                          | 260                                                                                                                                                                                                                                                                    | 380 | μA    | +25°C  |                                                 |              |  |  |  |
|                                             |                          | 260                                                                                                                                                                                                                                                                    | 380 | μA    | +60°C  | VDD = 1.8V <sup>(4)</sup><br>Regulator Disabled |              |  |  |  |
|                                             |                          | 270                                                                                                                                                                                                                                                                    | 390 | μA    | +85°C  |                                                 |              |  |  |  |
|                                             |                          | 280                                                                                                                                                                                                                                                                    | 420 | μA    | +125°C |                                                 |              |  |  |  |
|                                             | PIC18LFXXK80             | 400                                                                                                                                                                                                                                                                    | 500 | μA    | -40°C  |                                                 |              |  |  |  |
|                                             |                          | 400                                                                                                                                                                                                                                                                    | 500 | μA    | +25°C  | ) (= = = 0 0) ( <b>(4</b> )                     |              |  |  |  |
|                                             |                          | 400                                                                                                                                                                                                                                                                    | 500 | μA    | +60°C  | VDD = 3.3V <sup>(4)</sup><br>Regulator Disabled |              |  |  |  |
|                                             |                          | 410                                                                                                                                                                                                                                                                    | 520 | μA    | +85°C  |                                                 |              |  |  |  |
|                                             |                          | 420                                                                                                                                                                                                                                                                    | 580 | μA    | +125°C |                                                 | Fosc = 1 MHz |  |  |  |
|                                             | PIC18FXXK80              | 430                                                                                                                                                                                                                                                                    | 560 | μA    | -40°C  |                                                 | HF-INTOSC)   |  |  |  |
|                                             |                          | 430                                                                                                                                                                                                                                                                    | 560 | μA    | +25°C  | ) ( ) (5)                                       |              |  |  |  |
|                                             |                          | 430                                                                                                                                                                                                                                                                    | 560 | μA    | +60°C  | VDD = 3.3V <sup>(0)</sup><br>Regulator Enabled  |              |  |  |  |
|                                             |                          | 450                                                                                                                                                                                                                                                                    | 580 | μA    | +85°C  |                                                 |              |  |  |  |
|                                             |                          | 480                                                                                                                                                                                                                                                                    | 620 | μA    | +125°C |                                                 |              |  |  |  |
|                                             | PIC18FXXK80              | 450                                                                                                                                                                                                                                                                    | 620 | μA    | -40°C  | -                                               |              |  |  |  |
|                                             |                          | 450                                                                                                                                                                                                                                                                    | 620 | μA    | +25°C  |                                                 |              |  |  |  |
|                                             |                          | 450                                                                                                                                                                                                                                                                    | 620 | μA    | +60°C  | $VDD = 5V^{(3)}$<br>Regulator Enabled           |              |  |  |  |
|                                             |                          | 470                                                                                                                                                                                                                                                                    | 640 | μA    | +85°C  |                                                 |              |  |  |  |
|                                             |                          | 500                                                                                                                                                                                                                                                                    | 680 | μA    | +125°C |                                                 |              |  |  |  |

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

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

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

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

- OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD;
- MCLR = VDD; WDT enabled/disabled as specified.
- **3:** Standard, low-cost 32 kHz crystals have an operating temperature range of -10°C to +70°C. Extended temperature crystals are available at a much higher cost.
- 4: For LF devices, RETEN (CONFIG1L<0>) = 1.
- 5: For F devices, SRETEN (WDTCON<4>) = 1 and  $\overline{RETEN}$  (CONFIG1L<0>) = 0.

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

| PIC18F66K80 Family<br>(Industrial/Extended) |                        | Standard<br>Operating                  | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |       |        |                                                 |                |  |  |  |  |  |  |
|---------------------------------------------|------------------------|----------------------------------------|------------------------------------------------------|-------|--------|-------------------------------------------------|----------------|--|--|--|--|--|--|
| Param<br>No.                                | Device                 | Тур                                    | Max                                                  | Units |        | Conditions                                      | 5              |  |  |  |  |  |  |
|                                             | Supply Current (IDD) ( | / Current (IDD) Cont. <sup>(2,3)</sup> |                                                      |       |        |                                                 |                |  |  |  |  |  |  |
|                                             | PIC18LFXXK80           | 270                                    | 600                                                  | μA    | -40°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 270                                    | 600                                                  | μA    | +25°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 270                                    | 600                                                  | μA    | +60°C  | VDD = 1.8V <sup>(4)</sup><br>Regulator Disabled |                |  |  |  |  |  |  |
|                                             |                        | 300                                    | 700                                                  | μA    | +85°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 320                                    | 850                                                  | μΑ    | +125°C |                                                 |                |  |  |  |  |  |  |
|                                             | PIC18LFXXK80           | 540                                    | 1000                                                 | μA    | -40°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 540                                    | 1000                                                 | μA    | +25°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 540                                    | 1000                                                 | μA    | +60°C  | VDD = 3.3V(*)<br>Regulator Disabled             |                |  |  |  |  |  |  |
|                                             |                        | 550                                    | 1100                                                 | μA    | +85°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 560                                    | 1200                                                 | μA    | +125°C |                                                 | Fosc = 4 MHz   |  |  |  |  |  |  |
|                                             | PIC18FXXK80            | 566                                    | 1020                                                 | μΑ    | -40°C  |                                                 | EC oscillator) |  |  |  |  |  |  |
|                                             |                        | 585                                    | 1020                                                 | μΑ    | +25°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 590                                    | 1020                                                 | μΑ    | +60°C  | VDD = 3.3V <sup>(3)</sup><br>Regulator Enabled  |                |  |  |  |  |  |  |
|                                             |                        | 595                                    | 1120                                                 | μA    | +85°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 600                                    | 1220                                                 | μΑ    | +125°C |                                                 |                |  |  |  |  |  |  |
|                                             | PIC18FXXK80            | 630                                    | 2000                                                 | μA    | -40°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 630                                    | 2000                                                 | μΑ    | +25°C  | (5)                                             |                |  |  |  |  |  |  |
|                                             |                        | 630                                    | 2000                                                 | μΑ    | +60°C  | $VDD = 5V^{(3)}$<br>Regulator Enabled           |                |  |  |  |  |  |  |
|                                             |                        | 640                                    | 2000                                                 | μA    | +85°C  |                                                 |                |  |  |  |  |  |  |
|                                             |                        | 650                                    | 2000                                                 | μA    | +125°C |                                                 |                |  |  |  |  |  |  |

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

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

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

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

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

MCLR = VDD; WDT enabled/disabled as specified.

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

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

31.2

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

| PIC18F66K80 Family<br>(Industrial/Extended) |                                   | Standard<br>Operating | $ \begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for industrial} \\ -40^\circ C \leq TA \leq +125^\circ C \mbox{ for extended} \end{array} $ |                 |                 |                                              |                       |  |  |  |  |  |
|---------------------------------------------|-----------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|----------------------------------------------|-----------------------|--|--|--|--|--|
| Param<br>No.                                | m Device Typ Max Units Conditions |                       |                                                                                                                                                                                                                                                              |                 |                 |                                              |                       |  |  |  |  |  |
|                                             | Module Differential Cu            | urrents (∆lwDT,       | $\Delta$ IBOR, $\Delta$                                                                                                                                                                                                                                      | Ihlvd, $\Delta$ | IADC)           |                                              |                       |  |  |  |  |  |
| D022                                        | Watchdog Timer                    |                       |                                                                                                                                                                                                                                                              |                 |                 |                                              |                       |  |  |  |  |  |
| (ΔIWDT)                                     | PIC18LFXXK80                      | 0.4                   | 2                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 1.8V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18LFXXK80                      | 0.6                   | 3                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 0.6                   | 3                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Enabled  |                       |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 0.8                   | 4                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 5.5V<br>Regulator Enabled  |                       |  |  |  |  |  |
| D022A                                       | Brown-out Reset                   |                       |                                                                                                                                                                                                                                                              |                 |                 |                                              |                       |  |  |  |  |  |
| ( $\Delta$ IBOR)                            | PIC18LFXXK80                      | 4.6                   | 20                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 1.8V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 4.6                   | 20                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Enabled  | High-Power BOR        |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 4.6                   | 20                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 5.5V<br>Regulator Enabled  |                       |  |  |  |  |  |
| D022B                                       | High/Low-Voltage Detect           |                       |                                                                                                                                                                                                                                                              |                 |                 |                                              |                       |  |  |  |  |  |
| ∆İHLVD                                      | PIC18LFXXK80                      | 3.8                   | 10                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 1.8V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18LFXXK80                      | 4.5                   | 12                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 3.8                   | 12                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Enabled  |                       |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 4.9                   | 13                                                                                                                                                                                                                                                           | μA              | -40°C to +125°C | V <sub>DD</sub> = 5.5V<br>Regulator Enabled  |                       |  |  |  |  |  |
| D026                                        | A/D Converter                     |                       |                                                                                                                                                                                                                                                              |                 |                 |                                              |                       |  |  |  |  |  |
| AIADC                                       | PIC18LFXXK80                      | 0.4                   | 1.5                                                                                                                                                                                                                                                          |                 | -40°C to +125°C | V <sub>DD</sub> = 1.8V<br>Regulator Disabled |                       |  |  |  |  |  |
|                                             | PIC18LFXXK80                      | 0.5                   | 2                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Disabled | A/D on not converting |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 0.5                   | 3                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 3.3V<br>Regulator Enabled  | AD on, not converting |  |  |  |  |  |
|                                             | PIC18FXXK80                       | 1                     | 3                                                                                                                                                                                                                                                            | μA              | -40°C to +125°C | V <sub>DD</sub> = 5.5V<br>Regulator Enabled  |                       |  |  |  |  |  |

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

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

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

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

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

MCLR = VDD; WDT enabled/disabled as specified.

- 3: Standard, low-cost 32 kHz crystals have an operating temperature range of -10°C to +70°C. Extended temperature crystals are available at a much higher cost.
- 4: For LF devices, RETEN (CONFIG1L<0>) = 1.

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