



#### 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                      | 40MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, HLVD, POR, PWM, WDT                               |
| Number of I/O              | 25                                                                        |
| Program Memory Size        | 16KB (8K x 16)                                                            |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 768 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V                                                               |
| Data Converters            | A/D 10x10b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                   |
| Supplier Device Package    | 28-SPDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f2420-i-sp |

Email: info@E-XFL.COM

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

# 2.6 Internal Oscillator Block

The PIC18F2420/2520/4420/4520 devices include an internal oscillator block which generates two different clock signals; either can be used as the micro-controller's clock source. This may eliminate the need for external oscillator circuits on the OSC1 and/or OSC2 pins.

The main output (INTOSC) is an 8 MHz clock source which can be used to directly drive the device clock. It also drives a postscaler which can provide a range of clock frequencies from 31 kHz to 4 MHz. The INTOSC output is enabled when a clock frequency from 125 kHz to 8 MHz is selected.

The other clock source is the internal RC oscillator (INTRC), which provides a nominal 31 kHz output. INTRC is enabled if it is selected as the device clock source; it is also enabled automatically when any of the following are enabled:

- Power-up Timer
- · Fail-Safe Clock Monitor
- · Watchdog Timer
- · Two-Speed Start-up

These features are discussed in greater detail in **Section 23.0 "Special Features of the CPU"**.

The clock source frequency (INTOSC direct, INTRC direct or INTOSC postscaler) is selected by configuring the IRCF bits of the OSCCON register (page 30).

### 2.6.1 INTIO MODES

Using the internal oscillator as the clock source eliminates the need for up to two external oscillator pins, which can then be used for digital I/O. Two distinct configurations are available:

- In INTIO1 mode, the OSC2 pin outputs Fosc/4, while OSC1 functions as RA7 for digital input and output.
- In INTIO2 mode, OSC1 functions as RA7 and OSC2 functions as RA6, both for digital input and output.

### 2.6.2 INTOSC OUTPUT FREQUENCY

The internal oscillator block is calibrated at the factory to produce an INTOSC output frequency of 8.0 MHz.

The INTRC oscillator operates independently of the INTOSC source. Any changes in INTOSC across voltage and temperature are not necessarily reflected by changes in INTRC and vice versa.

### 2.6.3 OSCTUNE REGISTER

The internal oscillator's output has been calibrated at the factory but can be adjusted in the user's application. This is done by writing to the OSCTUNE register (Register 2-1). When the OSCTUNE register is modified, the INTOSC frequency will begin shifting to the new frequency. The INTRC clock will reach the new frequency within 8 clock cycles (approximately  $8 * 32 \ \mu s = 256 \ \mu s$ ). The INTOSC clock will stabilize within 1 ms. Code execution continues during this shift. There is no indication that the shift has occurred.

The OSCTUNE register also implements the INTSRC and PLLEN bits, which control certain features of the internal oscillator block. The INTSRC bit allows users to select which internal oscillator provides the clock source when the 31 kHz frequency option is selected. This is covered in greater detail in **Section 2.7.1 "Oscillator Control Register"**.

The PLLEN bit controls the operation of the frequency multiplier, PLL, in internal oscillator modes.

#### 2.6.4 PLL IN INTOSC MODES

The 4x frequency multiplier can be used with the internal oscillator block to produce faster device clock speeds than are normally possible with an internal oscillator. When enabled, the PLL produces a clock speed of up to 32 MHz.

Unlike HSPLL mode, the PLL is controlled through software. The control bit, PLLEN (OSCTUNE<6>), is used to enable or disable its operation.

The PLL is available when the device is configured to use the internal oscillator block as its primary clock source (FOSC<3:0> = 1001 or 1000). Additionally, the PLL will only function when the selected output frequency is either 4 MHz or 8 MHz (OSCCON<6:4> = 111or 110). If both of these conditions are not met, the PLL is disabled.

The PLLEN control bit is only functional in those internal oscillator modes where the PLL is available. In all other modes, it is forced to '0' and is effectively unavailable.

### 2.6.5 INTOSC FREQUENCY DRIFT

The factory calibrates the internal oscillator block output (INTOSC) for 8 MHz. However, this frequency may drift as VDD or temperature changes, which can affect the controller operation in a variety of ways. It is possible to adjust the INTOSC frequency by modifying the value in the OSCTUNE register. This has no effect on the INTRC clock source frequency.

Tuning the INTOSC source requires knowing when to make the adjustment, in which direction it should be made, and in some cases, how large a change is needed. Three compensation techniques are discussed in Section 2.6.5.1 "Compensating with the EUSART", Section 2.6.5.2 "Compensating with the Timers" and Section 2.6.5.3 "Compensating with the CCP Module in Capture Mode", but other techniques may be used.

### 2.7 Clock Sources and Oscillator Switching

Like previous PIC18 devices, the PIC18F2420/2520/ 4420/4520 family includes a feature that allows the device clock source to be switched from the main oscillator to an alternate low-frequency clock source. PIC18F2420/2520/4420/4520 devices offer two alternate clock sources. When an alternate clock source is enabled, the various power-managed operating modes are available.

Essentially, there are three clock sources for these devices:

- Primary oscillators
- · Secondary oscillators
- · Internal oscillator block

The **primary oscillators** include the External Crystal and Resonator modes, the External RC modes, the External Clock modes and the internal oscillator block. The particular mode is defined by the FOSC<3:0> Configuration bits. The details of these modes are covered earlier in this chapter. The **secondary oscillators** are those external sources not connected to the OSC1 or OSC2 pins. These sources may continue to operate even after the controller is placed in a power-managed mode.

PIC18F2420/2520/4420/4520 devices offer the Timer1 oscillator as a secondary oscillator. This oscillator, in all power-managed modes, is often the time base for functions such as a Real-Time Clock (RTC).

Most often, a 32.768 kHz watch crystal is connected between the RC0/T1OSO/T13CKI and RC1/T1OSI pins. Like the LP Oscillator mode circuit, loading capacitors are also connected from each pin to ground.

The Timer1 oscillator is discussed in greater detail in **Section 12.3 "Timer1 Oscillator"**.

In addition to being a primary clock source, the **internal oscillator block** is available as a power-managed mode clock source. The INTRC source is also used as the clock source for several special features, such as the WDT and Fail-Safe Clock Monitor.

The clock sources for the PIC18F2420/2520/4420/4520 devices are shown in Figure 2-8. See **Section 23.0 "Special Features of the CPU"** for Configuration register details.

### FIGURE 2-8: PIC18F2420/2520/4420/4520 CLOCK DIAGRAM



# 3.0 POWER-MANAGED MODES

PIC18F2420/2520/4420/4520 devices offer a total of seven operating modes for more efficient powermanagement. These modes provide a variety of options for selective power conservation in applications where resources may be limited (i.e., battery-powered devices).

There are three categories of power-managed modes:

- Run modes
- Idle modes
- · Sleep mode

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

The power-managed modes include several powersaving features offered on previous PIC<sup>®</sup> devices. One is the clock switching feature, offered in other PIC18 devices, allowing the controller to use the Timer1 oscillator in place of the primary oscillator. Also included is the Sleep mode, offered by all PIC devices, where all device clocks are stopped.

### 3.1 Selecting Power-Managed Modes

Selecting a power-managed mode requires two decisions: if the CPU is to be clocked or not and the selection of a clock source. The IDLEN bit (OSCCON<7>) controls CPU clocking, while the SCS<1:0> bits (OSCCON<1:0>) select the clock source. The individual modes, bit settings, clock sources and affected modules are summarized in Table 3-1.

# 3.1.1 CLOCK SOURCES

The SCS<1:0> bits allow the selection of one of three clock sources for power-managed modes. They are:

- the primary clock, as defined by the FOSC<3:0> Configuration bits
- the secondary clock (the Timer1 oscillator)
- the internal oscillator block (for RC modes)

#### 3.1.2 ENTERING POWER-MANAGED MODES

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

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

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

| Mada     | OSCCON<7,1:0> Bits   |          | Module          | Clocking | - Available Clock and Oscillator Source                                                                                                |  |  |  |
|----------|----------------------|----------|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| wode     | IDLEN <sup>(1)</sup> | SCS<1:0> | CPU Peripherals |          |                                                                                                                                        |  |  |  |
| Sleep    | 0                    | N/A      | Off             | Off      | None – All clocks are disabled                                                                                                         |  |  |  |
| PRI_RUN  | N/A                  | 00       | Clocked         | Clocked  | Primary – LP, XT, HS, HSPLL, RC, EC and<br>Internal Oscillator Block <sup>(2)</sup> .<br>This is the normal full-power execution mode. |  |  |  |
| SEC_RUN  | N/A                  | 01       | Clocked         | Clocked  | Secondary – Timer1 Oscillator                                                                                                          |  |  |  |
| RC_RUN   | N/A                  | 1x       | Clocked         | Clocked  | Internal Oscillator Block <sup>(2)</sup>                                                                                               |  |  |  |
| PRI_IDLE | 1                    | 00       | Off             | Clocked  | Primary – LP, XT, HS, HSPLL, RC, EC                                                                                                    |  |  |  |
| SEC_IDLE | 1                    | 01       | Off             | Clocked  | Secondary – Timer1 Oscillator                                                                                                          |  |  |  |
| RC_IDLE  | 1                    | 1x       | Off             | Clocked  | Internal Oscillator Block <sup>(2)</sup>                                                                                               |  |  |  |

TABLE 3-1: POWER-MANAGED MODES

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

2: Includes INTOSC and INTOSC postscaler, as well as the INTRC source.

The PLUSW register can be used to implement a form of Indexed Addressing in the data memory space. By manipulating the value in the W register, users can reach addresses that are fixed offsets from pointer addresses. In some applications, this can be used to implement some powerful program control structure, such as software stacks, inside of data memory.

### 5.4.3.3 Operations by FSRs on FSRs

Indirect Addressing operations that target other FSRs or virtual registers represent special cases. For example, using an FSR to point to one of the virtual registers will not result in successful operations. As a specific case, assume that FSR0H:FSR0L contains FE7h, the address of INDF1. Attempts to read the value of the INDF1 using INDF0 as an operand will return 00h. Attempts to write to INDF1 using INDF0 as the operand will result in a NOP.

On the other hand, using the virtual registers to write to an FSR pair may not occur as planned. In these cases, the value will be written to the FSR pair but without any incrementing or decrementing. Thus, writing to INDF2 or POSTDEC2 will write the same value to the FSR2H:FSR2L.

Since the FSRs are physical registers mapped in the SFR space, they can be manipulated through all direct operations. Users should proceed cautiously when working on these registers, particularly if their code uses indirect addressing.

Similarly, operations by Indirect Addressing are generally permitted on all other SFRs. Users should exercise the appropriate caution that they do not inadvertently change settings that might affect the operation of the device.

# 5.5 Data Memory and the Extended Instruction Set

Enabling the PIC18 extended instruction set (XINST Configuration bit = 1) significantly changes certain aspects of data memory and its addressing. Specifically, the use of the Access Bank for many of the core PIC18 instructions is different; this is due to the introduction of a new addressing mode for the data memory space.

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

## 5.5.1 INDEXED ADDRESSING WITH LITERAL OFFSET

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

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

- The use of the Access Bank is forced ('a' = 0) and
- The file address argument is less than or equal to 5Fh.

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

## 5.5.2 INSTRUCTIONS AFFECTED BY INDEXED LITERAL OFFSET MODE

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

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

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

### 7.3 Reading the Data EEPROM Memory

To read a data memory location, the user must write the address to the EEADR register, clear the EEPGD control bit (EECON1<7>) and then set control bit, RD (EECON1<0>). The data is available on the very next instruction cycle; therefore, the EEDATA register can be read by the next instruction. EEDATA will hold this value until another read operation, or until it is written to by the user (during a write operation).

The basic process is shown in Example 7-1.

# 7.4 Writing to the Data EEPROM Memory

To write an EEPROM data location, the address must first be written to the EEADR register and the data written to the EEDATA register. The sequence in Example 7-2 must be followed to initiate the write cycle.

The write will not begin if this sequence is not exactly followed (write 55h to EECON2, write 0AAh to EECON2, then set WR bit) for each byte. It is strongly recommended that interrupts be disabled during this code segment.

Additionally, the WREN bit in EECON1 must be set to enable writes. This mechanism prevents accidental writes to data EEPROM due to unexpected code execution (i.e., runaway programs). The WREN bit should be kept clear at all times, except when updating the EEPROM. The WREN bit is not cleared by hardware.

After a write sequence has been initiated, EECON1, EEADR and EEDATA cannot be modified. The WR bit will be inhibited from being set unless the WREN bit is set. Both WR and WREN cannot be set with the same instruction.

At the completion of the write cycle, the WR bit is cleared in hardware and the EEPROM Interrupt Flag bit, EEIF, is set. The user may either enable this interrupt or poll this bit. EEIF must be cleared by software.

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

EXAMPLE 7-1: DATA EEPROM READ

| MOVLW | DATA_EE_ADI | DR ; |                             |
|-------|-------------|------|-----------------------------|
| MOVWF | EEADR       | ;    | Data Memory Address to read |
| BCF   | EECON1, EEF | GD ; | Point to DATA memory        |
| BCF   | EECON1, CFG | ss ; | Access EEPROM               |
| BSF   | EECON1, RD  | ;    | EEPROM Read                 |
| MOVF  | EEDATA, W   | ;    | W = EEDATA                  |
|       |             |      |                             |

#### EXAMPLE 7-2: DATA EEPROM WRITE

|          | MOVLW | DATA_EE_ADDR  | i                                             |
|----------|-------|---------------|-----------------------------------------------|
|          | MOVWF | EEADR         | ; Data Memory Address to write                |
|          | MOVLW | DATA_EE_DATA  | i                                             |
|          | MOVWF | EEDATA        | ; Data Memory Value to write                  |
|          | BCF   | EECON1, EEPGD | ; Point to DATA memory                        |
|          | BCF   | EECON1, CFGS  | ; Access EEPROM                               |
|          | BSF   | EECON1, WREN  | ; Enable writes                               |
|          |       |               |                                               |
|          | BCF   | INTCON, GIE   | ; Disable Interrupts                          |
|          | MOVLW | 55h           | ;                                             |
| Required | MOVWF | EECON2        | ; Write 55h                                   |
| Sequence | MOVLW | 0AAh          | ;                                             |
|          | MOVWF | EECON2        | ; Write OAAh                                  |
|          | BSF   | EECON1, WR    | ; Set WR bit to begin write                   |
|          | BSF   | INTCON, GIE   | ; Enable Interrupts                           |
|          |       |               |                                               |
|          |       |               | ; User code execution                         |
|          | BCF   | EECON1, WREN  | ; Disable writes on write complete (EEIF set) |

NOTES:

### 10.3 PORTC, TRISC and LATC Registers

PORTC is an 8-bit wide, bidirectional port. The corresponding Data Direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a high-impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin).

The Data Latch register (LATC) is also memory mapped. Read-modify-write operations on the LATC register read and write the latched output value for PORTC.

PORTC is multiplexed with several peripheral functions (Table 10-5). The pins have Schmitt Trigger input buffers. RC1 is normally configured by Configuration bit, CCP2MX, as the default peripheral pin of the CCP2 module (default/erased state, CCP2MX = 1).

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. The user should refer to the corresponding peripheral section for additional information. Note: On a Power-on Reset, these pins are configured as digital inputs.

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.

| EXAIVIPLE 10-3 |  |
|----------------|--|

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

## 16.4 Enhanced PWM Mode

The Enhanced PWM mode provides additional PWM output options for a broader range of control applications. The module is a backward compatible version of the standard CCP module and offers up to four outputs, designated P1A through P1D. Users are also able to select the polarity of the signal (either active-high or active-low). The module's output mode and polarity are configured by setting the P1M<1:0> and CCP1M<3:0> bits of the CCP1CON register.

Figure 16-1 shows a simplified block diagram of PWM operation. All control registers are double-buffered and are loaded at the beginning of a new PWM cycle (the period boundary when Timer2 resets) in order to prevent glitches on any of the outputs. The exception is the PWM Dead-Band Delay register, PWM1CON, which is loaded at either the duty cycle boundary or the period boundary (whichever comes first). Because of the buffering, the module waits until the assigned timer resets instead of starting immediately. This means that Enhanced PWM waveforms do not exactly match the standard PWM waveforms, but are instead offset by one full instruction cycle (4 Tosc).

As before, the user must manually configure the appropriate TRIS bits for output.

#### 16.4.1 PWM PERIOD

The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following equation.

#### EQUATION 16-1:

$$PWM Period = [(PR2) + 1] \bullet 4 \bullet TOSC \bullet (TMR2 Prescale Value)$$

PWM frequency is defined as 1/[PWM period]. When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCP1 pin is set (if PWM duty cycle = 0%, the CCP1 pin will not be set)
- The PWM duty cycle is copied from CCPR1L into CCPR1H
  - Note: The Timer2 postscaler (see Section 13.0 "Timer2 Module") is not used in the determination of the PWM frequency. The postscaler could be used to have a servo update rate at a different frequency than the PWM output.

# FIGURE 16-1: SIMPLIFIED BLOCK DIAGRAM OF THE ENHANCED PWM MODULE



| REGIST     | ER 17-5: SSPC                                                                 | CON2: MSSP                                        |                                  | REGISTER 2 (                                       | (I <sup>2</sup> C™ MODE             | E)                                  |                       |  |
|------------|-------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------|----------------------------------------------------|-------------------------------------|-------------------------------------|-----------------------|--|
| R/W-0      | ) R/W-0                                                                       | R/W-0                                             | R/W-0                            | R/W-0                                              | R/W-0                               | R/W-0                               | R/W-0                 |  |
| GCEN       | ACKSTAT                                                                       | ACKDT <sup>(2)</sup>                              | ACKEN <sup>(1)</sup>             | RCEN <sup>(1)</sup>                                | PEN <sup>(1)</sup>                  | RSEN <sup>(1)</sup>                 | SEN <sup>(1)</sup>    |  |
| bit 7      |                                                                               |                                                   |                                  |                                                    |                                     |                                     | bit 0                 |  |
| Legend     |                                                                               |                                                   |                                  |                                                    |                                     |                                     |                       |  |
| R = Read   | lable bit                                                                     | W = Writable                                      | oit                              | U = Unimplem                                       | nented bit rea                      | d as '0'                            |                       |  |
| -n = Value | alue at POR $(1^{2} = Bit is set (0^{2} = Bit is cleared x = Bit is unknown)$ |                                                   |                                  |                                                    |                                     |                                     | own                   |  |
|            |                                                                               |                                                   |                                  |                                                    |                                     |                                     |                       |  |
| bit 7      | GCEN: Gene                                                                    | ral Call Enable                                   | bit (Slave mod                   | le only)                                           |                                     |                                     |                       |  |
|            | 1 = Enables i<br>0 = General d                                                | nterrupt when a call address dis                  | i general call a<br>abled.       | ddress (0000h)                                     | ) is received in                    | the SSPSR                           |                       |  |
| bit 6      | ACKSTAT: A                                                                    | cknowledge Sta                                    | itus bit (Mastei                 | r Transmit mod                                     | e only)                             |                                     |                       |  |
|            | 1 = Acknowle<br>0 = Acknowle                                                  | edge was not re<br>edge was receiv                | ceived from slave                | ave                                                |                                     |                                     |                       |  |
| bit 5      | ACKDT: Ack                                                                    | nowledge Data                                     | bit (Master Re                   | ceive mode onl                                     | y) <b>(2)</b>                       |                                     |                       |  |
|            | 1 = Not Ackn<br>0 = Acknowle                                                  | 1 = Not Acknowledge<br>0 = Acknowledge            |                                  |                                                    |                                     |                                     |                       |  |
| bit 4      | ACKEN: Ack                                                                    | nowledge Sequ                                     | ence Enable b                    | oit (Master Rece                                   | eive mode only                      | /) <sup>(1)</sup>                   |                       |  |
|            | 1 = Initiates<br>cleared b<br>0 = Acknowl                                     | Acknowledge se<br>by hardware.<br>edge sequence   | equence on SD                    | A and SCL pins                                     | and transmit <i>i</i>               | ACKDT data bit.                     | Automatically         |  |
| bit 3      | RCEN: Rece                                                                    | ive Enable bit (I                                 | Master mode o                    | only)(1)                                           |                                     |                                     |                       |  |
|            | 1 = Enables I<br>0 = Receive I                                                | Receive mode f                                    | or I <sup>2</sup> C              | .,                                                 |                                     |                                     |                       |  |
| bit 2      | PEN: Stop Co                                                                  | ondition Enable                                   | bit (Master mo                   | ode only) <sup>(1)</sup>                           |                                     |                                     |                       |  |
|            | 1 = Initiates S<br>0 = Stop cond                                              | Stop condition o<br>dition Idle                   | n SDA and SC                     | L pins. Automa                                     | tically cleared                     | by hardware.                        |                       |  |
| bit 1      | RSEN: Repe                                                                    | ated Start Cond                                   | ition Enable bi                  | it (Master mode                                    | only) <sup>(1)</sup>                |                                     |                       |  |
|            | 1 = Initiates<br>0 = Repeate                                                  | Repeated Start<br>d Start conditior               | condition on S<br>າ Idle         | DA and SCL pi                                      | ns. Automatica                      | ally cleared by h                   | ardware.              |  |
| bit 0      | SEN: Start C                                                                  | ondition Enable                                   | /Stretch Enabl                   | e bit <sup>(1)</sup>                               |                                     |                                     |                       |  |
|            | <u>In Master mo</u><br>1 = Initiates S<br>0 = Start cond                      | <u>de:</u><br>Start condition o<br>dition Idle    | n SDA and SC                     | CL pins. Automa                                    | itically cleared                    | by hardware.                        |                       |  |
|            | In Slave mod<br>1 = Clock stre<br>0 = Clock stre                              | <u>e:</u><br>etching is enabl<br>etching is disab | ed for both sla<br>ed            | ve transmit and                                    | l slave receive                     | (stretch enable                     | d)                    |  |
| Note 1:    | For bits ACKEN, set (no spooling)                                             | RCEN, PEN, R<br>and the SSPBL                     | SEN, SEN: If th<br>JF may not be | ne I <sup>2</sup> C module is<br>written (or write | s not in the Idle<br>es to the SSPE | e mode, these bi<br>3UF are disable | its may not be<br>d). |  |

2: Value that will be transmitted when the user initiates an Acknowledge sequence at the end of a receive.



#### FIGURE 18-7: ASYNCHRONOUS RECEPTION

| TABLE 18-6: REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTIO | <b>ABLE 18-6</b> : |
|-------------------------------------------------------------|--------------------|
|-------------------------------------------------------------|--------------------|

| Name    | Bit 7                                               | Bit 6       | Bit 5       | Bit 4        | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|---------|-----------------------------------------------------|-------------|-------------|--------------|-------|--------|--------|--------|----------------------------|
| INTCON  | GIE/GIEH                                            | PEIE/GIEL   | TMR0IE      | INT0IE       | RBIE  | TMR0IF | INT0IF | RBIF   | 49                         |
| PIR1    | PSPIF <sup>(1)</sup>                                | ADIF        | RCIF        | TXIF         | SSPIF | CCP1IF | TMR2IF | TMR1IF | 52                         |
| PIE1    | PSPIE <sup>(1)</sup>                                | ADIE        | RCIE        | TXIE         | SSPIE | CCP1IE | TMR2IE | TMR1IE | 52                         |
| IPR1    | PSPIP <sup>(1)</sup>                                | ADIP        | RCIP        | TXIP         | SSPIP | CCP1IP | TMR2IP | TMR1IP | 52                         |
| RCSTA   | SPEN                                                | RX9         | SREN        | CREN         | ADDEN | FERR   | OERR   | RX9D   | 51                         |
| RCREG   | EUSART Receive Register                             |             |             |              |       |        |        |        |                            |
| TXSTA   | CSRC                                                | TX9         | TXEN        | SYNC         | SENDB | BRGH   | TRMT   | TX9D   | 51                         |
| BAUDCON | ABDOVF                                              | RCIDL       | RXDTP       | TXCKP        | BRG16 | —      | WUE    | ABDEN  | 51                         |
| SPBRGH  | PBRGH EUSART Baud Rate Generator Register High Byte |             |             |              |       |        |        |        | 51                         |
| SPBRG   | EUSART E                                            | aud Rate Ge | enerator Re | gister Low E | Byte  |        |        |        | 51                         |

Legend: — = unimplemented locations read as '0'. Shaded cells are not used for asynchronous reception.

Note 1: Reserved in 28-pin devices; always maintain these bits clear.

#### 18.2.4 AUTO-WAKE-UP ON SYNC BREAK CHARACTER

During Sleep mode, all clocks to the EUSART are suspended. Because of this, the Baud Rate Generator is inactive and a proper byte reception cannot be performed. The auto-wake-up feature allows the controller to wake-up due to activity on the RX/DT line while the EUSART is operating in Asynchronous mode.

The auto-wake-up feature is enabled by setting the WUE bit (BAUDCON<1>). Once set, the typical receive sequence on RX/DT is disabled and the EUSART remains in an Idle state, monitoring for a wake-up event independent of the CPU mode. A wake-up event consists of a high-to-low transition on the RX/DT line. (This coincides with the start of a Sync Break or a Wake-up Signal character for the LIN protocol.)

Following a wake-up event, the module generates an RCIF interrupt. The interrupt is generated synchronously to the Q clocks in normal operating modes (Figure 18-8) and asynchronously, if the device is in Sleep mode (Figure 18-9). The interrupt condition is cleared by reading the RCREG register.

The WUE bit is automatically cleared once a low-tohigh transition is observed on the RX line following the wake-up event. At this point, the EUSART module is in Idle mode and returns to normal operation. This signals to the user that the Sync Break event is over.

# 19.0 10-BIT ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE

The Analog-to-Digital (A/D) Converter module has 10 inputs for the 28-pin devices and 13 for the 40/44-pin devices. This module allows conversion of an analog input signal to a corresponding 10-bit digital number.

The module has five registers:

- A/D Result High Register (ADRESH)
- A/D Result Low Register (ADRESL)
- A/D Control Register 0 (ADCON0)
- A/D Control Register 1 (ADCON1)
- A/D Control Register 2 (ADCON2)

The ADCON0 register, shown in Register 19-1, controls the operation of the A/D module. The ADCON1 register, shown in Register 19-2, configures the functions of the port pins. The ADCON2 register, shown in Register 19-3, configures the A/D clock source, programmed acquisition time and justification.

| U-0   | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0   | R/W-0 |
|-------|-----|-------|-------|-------|-------|---------|-------|
| _     | _   | CHS3  | CHS2  | CHS1  | CHS0  | GO/DONE | ADON  |
| 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-6 | Unimplemented: Read as '0 | , |
|---------|---------------------------|---|
|---------|---------------------------|---|

bit 5-2 CHS<3:0>: Analog Channel Select bits

|               | •                                |
|---------------|----------------------------------|
| 0000 <b>=</b> | Channel 0 (AN0)                  |
| 0001 =        | Channel 1 (AN1)                  |
| 0010 =        | Channel 2 (AN2)                  |
| 0011 =        | Channel 3 (AN3)                  |
| 0100 =        | Channel 4 (AN4)                  |
| 0101 =        | Channel 5 (AN5) <sup>(1,2)</sup> |
| 0110 =        | Channel 6 (AN6) <sup>(1,2)</sup> |
| 0111 =        | Channel 7 (AN7) <sup>(1,2)</sup> |
| 1000 =        | Channel 8 (AN8)                  |
| 1001 =        | Channel 9 (AN9)                  |
| 1010 =        | Channel 10 (AN10)                |
| 1011 =        | Channel 11 (AN11)                |
| 1100 =        | Channel 12 (AN12)                |
| 1101 =        | Unimplemented) <sup>(2)</sup>    |
| 1110 =        | Unimplemented) <sup>(2)</sup>    |

- 1111 = Unimplemented)<sup>(2)</sup>
- bit 1 **GO/DONE:** A/D Conversion Status bit <u>When ADON = 1:</u> 1 = A/D conversion in progress
  - 0 = A/D Idle
- bit 0 ADON: A/D On bit
  - 1 = A/D Converter module is enabled
  - 0 = A/D Converter module is disabled

#### **Note 1:** These channels are not implemented on 28-pin devices.

2: Performing a conversion on unimplemented channels will return a floating input measurement.

#### **REGISTER 23-3:** CONFIG2H: CONFIGURATION REGISTER 2 HIGH (BYTE ADDRESS 300003h) U-0 U-0 U-0 R/P-1 R/P-1 R/P-1 R/P-1 R/P-1 WDTPS3 WDTPS2 WDTPS1 WDTPS0 WDTEN \_\_\_ \_\_\_\_ \_\_\_ bit 7 bit 0 Legend: R = Readable bit U = Unimplemented bit, read as '0' P = Programmable bit u = Unchanged from programmed state -n = Value when device is unprogrammed bit 7-5 Unimplemented: Read as '0' bit 4-1 WDTPS<3:0>: Watchdog Timer Postscale Select bits 1111 = 1:32,768 1110 = 1:16,384 1101 = 1:8,192 1100 = 1:4,096 1011 = 1:2,048 1010 = 1:1,0241001 = 1:512 1000 = 1:256 0111 = 1:128 0110 = 1:64 0101 = 1:32 0100 = 1:16 0011 = 1:8 0010 = 1:4 0001 = 1:2 0000 = 1:1 bit 0 WDTEN: Watchdog Timer Enable bit 1 = WDT enabled

0 = WDT disabled (control is placed on the SWDTEN bit)

|                    | <b>4</b> 72.           |                                 |         |                         |      |      |      |                 |       |
|--------------------|------------------------|---------------------------------|---------|-------------------------|------|------|------|-----------------|-------|
| Mnem               | ionic,                 | Description                     | Civalaa | 16-Bit Instruction Word |      |      |      | Status          | Notos |
| Operands           |                        | Description                     | Cycles  | MSb                     |      |      | LSb  | Affected        | Notes |
| LITERAL OPERATIONS |                        |                                 |         |                         |      |      |      |                 |       |
| ADDLW              | k                      | Add Literal and WREG            | 1       | 0000                    | 1111 | kkkk | kkkk | C, DC, Z, OV, N |       |
| ANDLW              | k                      | AND Literal with WREG           | 1       | 0000                    | 1011 | kkkk | kkkk | Z, N            |       |
| IORLW              | k                      | Inclusive OR Literal with WREG  | 1       | 0000                    | 1001 | kkkk | kkkk | Z, N            |       |
| LFSR               | f, k                   | Move Literal (12-bit)2nd word   | 2       | 1110                    | 1110 | 00ff | kkkk | None            |       |
|                    |                        | to FSR(f) 1st word              |         | 1111                    | 0000 | kkkk | kkkk |                 |       |
| MOVLB              | k                      | Move Literal to BSR<3:0>        | 1       | 0000                    | 0001 | 0000 | kkkk | None            |       |
| MOVLW              | k                      | Move Literal to WREG            | 1       | 0000                    | 1110 | kkkk | kkkk | None            |       |
| MULLW              | k                      | Multiply Literal with WREG      | 1       | 0000                    | 1101 | kkkk | kkkk | None            |       |
| RETLW              | k                      | Return with Literal in WREG     | 2       | 0000                    | 1100 | kkkk | kkkk | None            |       |
| SUBLW              | k                      | Subtract WREG from Literal      | 1       | 0000                    | 1000 | kkkk | kkkk | C, DC, Z, OV, N |       |
| XORLW              | k                      | Exclusive OR Literal with WREG  | 1       | 0000                    | 1010 | kkkk | kkkk | Z, N            |       |
| DATA ME            | $MORY \leftrightarrow$ | PROGRAM MEMORY OPERATION        | IS      |                         |      |      |      |                 |       |
| TBLRD*             |                        | Table Read                      | 2       | 0000                    | 0000 | 0000 | 1000 | None            |       |
| TBLRD*+            |                        | Table Read with Post-Increment  |         | 0000                    | 0000 | 0000 | 1001 | None            |       |
| TBLRD*-            |                        | Table Read with Post-Decrement  |         | 0000                    | 0000 | 0000 | 1010 | None            |       |
| TBLRD+*            |                        | Table Read with Pre-Increment   |         | 0000                    | 0000 | 0000 | 1011 | None            |       |
| TBLWT*             |                        | Table Write                     | 2       | 0000                    | 0000 | 0000 | 1100 | None            |       |
| TBLWT*+            |                        | Table Write with Post-Increment |         | 0000                    | 0000 | 0000 | 1101 | None            |       |
| TBLWT*-            |                        | Table Write with Post-Decrement |         | 0000                    | 0000 | 0000 | 1110 | None            |       |
| TBLWT+*            |                        | Table Write with Pre-Increment  |         | 0000                    | 0000 | 0000 | 1111 | None            |       |
|                    |                        |                                 |         |                         |      |      |      |                 |       |

#### TABLE 24-2: PIC18FXXXX INSTRUCTION SET (CONTINUED)

**Note 1:** When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

2: If this instruction is executed on the TMR0 register (and where applicable, 'd' = 1), the prescaler will be cleared if assigned.

**3:** If the Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

4: Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction.

| DECFSZ Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                 |                                       |                                                              |                   |                     |                                                                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------|--------------------------------------------------------------|-------------------|---------------------|---------------------------------------------------------------------------------------------------|
| Synta                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ax:                                             | DECFSZ                                | f {,d {,a}}                                                  |                   |                     |                                                                                                   |
| Oper                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ands:                                           | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1] | 5                                                            |                   |                     |                                                                                                   |
| Oper                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ation:                                          | (f) – 1 $\rightarrow$ skip if res     | dest,<br>ult = 0                                             |                   |                     |                                                                                                   |
| Statu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | is Affected:                                    | None                                  |                                                              |                   |                     |                                                                                                   |
| Enco                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | oding:                                          | 0010                                  | 11da                                                         | fff               | f ff                | ff                                                                                                |
| Description:<br>The contents of register 'f' are<br>decremented. If 'd' is '0', the result is<br>placed in W. If 'd' is '1', the result is<br>placed back in register 'f' (default).<br>If the result is '0', the next instruction,<br>which is already fetched, is discarded<br>and a NOP is executed instead, makin<br>it a two-cycle instruction.<br>If 'a' is '0', the Access Bank is selecte<br>If 'a' is '1', the BSR is used to select th<br>GPR bank (default).<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operate<br>in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See<br>Section 24.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexe<br>Literal Offset Mode" for details. |                                                 |                                       |                                                              |                   |                     | is<br>s<br>on,<br>led<br>king<br>cted.<br>t the<br>stion<br>rates<br>g<br><b>nd</b><br><b>xed</b> |
| Worc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ls:                                             | 1                                     |                                                              |                   |                     |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | es:                                             | 1(2)<br>Note: 3<br>by                 | cycles if s<br>⁄ a 2-word                                    | kip and<br>instru | d followe<br>ction. | d                                                                                                 |
| QU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Q1                                              | 02                                    | Q                                                            | 3                 | Q4                  |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Decode                                          | Read<br>register 'f'                  | Proc                                                         | ess<br>ta         | Write<br>destina    | to<br>tion                                                                                        |
| lf sk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ip:                                             |                                       |                                                              |                   |                     |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Q1                                              | Q2                                    | Q                                                            | 3                 | Q4                  |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No<br>operation                                 | No                                    | No<br>opera                                                  | )<br>tion         | N0<br>operat        | ion                                                                                               |
| lf sk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ip and followe                                  | d by 2-word                           | instruction                                                  | :                 |                     |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Q1                                              | Q2                                    | Q                                                            | 3                 | Q4                  |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No                                              | No                                    | No                                                           | )<br>tion         | No                  | ion                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | No                                              | No                                    | Opera<br>No                                                  | non               | No                  |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | operation                                       | operation                             | opera                                                        | tion              | operat              | ion                                                                                               |
| Example:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                 | HERE<br>CONTINU                       | DECFS<br>GOTO<br>E                                           | 5Z                | CNT, 1,<br>LOOP     | , 1                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Before Instruc<br>PC<br>After Instructio<br>CNT | tion<br>= Addre<br>on<br>= CNT -      | ess (here<br>- 1                                             | 2)                |                     |                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | IT CN I<br>PC<br>If CNT<br>PC                   | = 0;<br>= Addre<br>≠ 0;<br>= Addre    | = 0;<br>= Address (CONTINUE)<br>≠ 0;<br>= Address (HERE + 2) |                   |                     |                                                                                                   |

| DCF         | CFSNZ Decrement f, Skip if Not 0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                             |                         |  |  |  |  |
|-------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------------------|--|--|--|--|
| Synta       | ax:                              | DCFSNZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | f {,d {,a}}                                 |                         |  |  |  |  |
| Oper        | ands:                            | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1]       |                         |  |  |  |  |
| Oper        | ation:                           | (f) – $1 \rightarrow de$ skip if resul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | est,<br>It ≠ 0                              |                         |  |  |  |  |
| Statu       | s Affected:                      | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                             |                         |  |  |  |  |
| Enco        | ding:                            | 0100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 11da fff                                    | f ffff                  |  |  |  |  |
| Desc        | ription:                         | The contents of register 'f' are<br>decremented. If 'd' is '0', the result is<br>placed in W. If 'd' is '1', the result is<br>placed back in register 'f' (default).<br>If the result is not '0', the next<br>instruction, which is already fetched, is<br>discarded and a NOP is executed<br>instead, making it a two-cycle<br>instruction.<br>If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank (default).<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever f $\leq$ 95 (5Fh). See<br><b>Section 24.2.3 "Byte-Oriented and<br/>Bit-Oriented Instructions in Indexed</b> |                                             |                         |  |  |  |  |
| Word        | ls:                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                             |                         |  |  |  |  |
| Cycle       | es:                              | 1(2)<br>Note: 3 o<br>by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | cycles if skip a<br>a 2-word instr          | nd followed<br>ruction. |  |  |  |  |
| QU          |                                  | 02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 03                                          | 04                      |  |  |  |  |
|             | Decode                           | Read<br>register 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Process<br>Data                             | Write to destination    |  |  |  |  |
| lf sk       | ip:                              | Ŭ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                             |                         |  |  |  |  |
|             | Q1                               | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q3                                          | Q4                      |  |  |  |  |
|             | No                               | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No                                          | No                      |  |  |  |  |
| lfsk        | in and follower                  | t by 2-word in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | struction:                                  | operation               |  |  |  |  |
|             | Q1                               | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q3                                          | Q4                      |  |  |  |  |
| 1           | No                               | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No                                          | No                      |  |  |  |  |
|             | operation                        | operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | operation                                   | operation               |  |  |  |  |
|             | No<br>operation                  | No<br>operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | No<br>operation                             | No<br>operation         |  |  |  |  |
| <u>Exan</u> | <u>nple:</u>                     | HERE ZERO<br>NZERO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | HERE DCFSNZ TEMP, 1, 0<br>ZERO :<br>NZERO : |                         |  |  |  |  |
|             | Betore Instruc                   | tion =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 2                                           |                         |  |  |  |  |
|             | After Instructio                 | on –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | •                                           |                         |  |  |  |  |
|             |                                  | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | TEMP – 1,                                   |                         |  |  |  |  |
|             | PC                               | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | o,<br>Address (2                            | ZERO)                   |  |  |  |  |
|             | If TEMP<br>PC                    | ≠<br>=                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0;<br>Address (1                            | NZERO)                  |  |  |  |  |

| POF                                     | 0                                                                                                                                                                                                                                                                                                    | Pop Top of Return Stack |               |                  |          |                |  |  |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------|------------------|----------|----------------|--|--|
| Synta                                   | ax:                                                                                                                                                                                                                                                                                                  | POP                     |               |                  |          |                |  |  |
| Oper                                    | ands:                                                                                                                                                                                                                                                                                                | None                    |               |                  |          |                |  |  |
| Oper                                    | ation:                                                                                                                                                                                                                                                                                               | $(TOS) \rightarrow b$   | it bucket     |                  |          |                |  |  |
| Statu                                   | is Affected:                                                                                                                                                                                                                                                                                         | None                    |               |                  |          |                |  |  |
| Enco                                    | oding:                                                                                                                                                                                                                                                                                               | 0000                    | 0000          | 000              | 0        | 0110           |  |  |
| Desc                                    | cription: The TOS value is pulled off the return<br>stack and is discarded. The TOS value<br>then becomes the previous value that<br>was pushed onto the return stack.<br>This instruction is provided to enable<br>the user to properly manage the return<br>stack to incorporate a software stack. |                         |               |                  |          |                |  |  |
| Word                                    | ds:                                                                                                                                                                                                                                                                                                  | 1                       |               |                  |          |                |  |  |
| Cycle                                   | es:                                                                                                                                                                                                                                                                                                  | 1                       |               |                  |          |                |  |  |
| QC                                      | ycle Activity:                                                                                                                                                                                                                                                                                       |                         |               |                  |          |                |  |  |
|                                         | Q1                                                                                                                                                                                                                                                                                                   | Q2                      | Q3            | 5                |          | Q4             |  |  |
|                                         | Decode                                                                                                                                                                                                                                                                                               | No<br>operation         | POP 1<br>valu | TOS<br>Ie        | op       | No<br>peration |  |  |
| <u>Exan</u>                             | nple:                                                                                                                                                                                                                                                                                                | POP<br>GOTO             | NEW           |                  |          |                |  |  |
| Before Instructio<br>TOS<br>Stack (1 le |                                                                                                                                                                                                                                                                                                      | tion<br>evel down)      | = C<br>= C    | )031A2<br>)14332 | 2h<br>?h |                |  |  |
|                                         | After Instructic<br>TOS<br>PC                                                                                                                                                                                                                                                                        | n                       | = C<br>= N    | )14332<br>JFW    | 2h       |                |  |  |

| PUSH Push Top of Return Stack                                                                                                                                                                                                                            |                                           |                                     |             |                         |    |                                                           |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------------------------------------|-------------|-------------------------|----|-----------------------------------------------------------|--|
| Synta                                                                                                                                                                                                                                                    | ax:                                       | PUSH                                |             |                         |    |                                                           |  |
| Operands: None                                                                                                                                                                                                                                           |                                           |                                     |             |                         |    |                                                           |  |
| Oper                                                                                                                                                                                                                                                     | ation:                                    | $(PC + 2) \rightarrow$              | TOS         |                         |    |                                                           |  |
| Status Affected: None                                                                                                                                                                                                                                    |                                           |                                     |             |                         |    |                                                           |  |
| Enco                                                                                                                                                                                                                                                     | oding:                                    | 0000                                | 0000        | 000                     | 0  | 0101                                                      |  |
| Description:<br>The PC + 2 is pushed onto the top o<br>the return stack. The previous TOS<br>value is pushed down on the stack.<br>This instruction allows implementing<br>software stack by modifying TOS and<br>then pushing it onto the return stack. |                                           |                                     |             |                         |    | e top of<br>TOS<br>stack.<br>enting a<br>OS and<br>stack. |  |
| Word                                                                                                                                                                                                                                                     | ls:                                       | 1                                   |             |                         |    |                                                           |  |
| Cycle                                                                                                                                                                                                                                                    | es:                                       | 1                                   |             |                         |    |                                                           |  |
| QC                                                                                                                                                                                                                                                       | ycle Activity:                            |                                     |             |                         |    |                                                           |  |
|                                                                                                                                                                                                                                                          | Q1                                        | Q2                                  | Q3          |                         |    | Q4                                                        |  |
|                                                                                                                                                                                                                                                          | Decode                                    | PUSH<br>PC + 2 onto<br>return stack | N<br>opera  | o<br>ation              | op | No<br>peration                                            |  |
| <u>Exan</u>                                                                                                                                                                                                                                              | nple:                                     | PUSH                                |             |                         |    |                                                           |  |
|                                                                                                                                                                                                                                                          | Before Instruc<br>TOS<br>PC               | tion                                | =<br>=      | 345Ah<br>0124h          |    |                                                           |  |
|                                                                                                                                                                                                                                                          | After Instructio<br>PC<br>TOS<br>Stack (1 | on<br>level down)                   | =<br>=<br>= | 0126h<br>0126h<br>345Ah |    |                                                           |  |

|               | Return from Subroutine                                                                                                                                                                                                                                                                             | RLCF              | Rotate Left f through Carry                                                                                                                                                                                                                                                                                                       |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:       | RETURN {s}                                                                                                                                                                                                                                                                                         | Syntax:           | RLCF f {,d {,a}}                                                                                                                                                                                                                                                                                                                  |
| Operands:     | s ∈ [0,1]                                                                                                                                                                                                                                                                                          | Operands:         | $0 \le f \le 255$                                                                                                                                                                                                                                                                                                                 |
| Operation:    | $(TOS) \rightarrow PC;$                                                                                                                                                                                                                                                                            |                   | $d \in [0,1]$                                                                                                                                                                                                                                                                                                                     |
|               | if s = 1,<br>(WS) $\rightarrow$ W,<br>(STATUSS) $\rightarrow$ STATUS,<br>(BSRS) $\rightarrow$ BSR,<br>DCI ATU DCI ATU are unchanged                                                                                                                                                                | Operation:        | $(f) \rightarrow dest,$<br>$(f<7>) \rightarrow C,$<br>$(C) \rightarrow dest<0>$                                                                                                                                                                                                                                                   |
| Status Affect | PCLAIO, PCLAIH are unchanged                                                                                                                                                                                                                                                                       | Status Affected:  | C, N, Z                                                                                                                                                                                                                                                                                                                           |
|               |                                                                                                                                                                                                                                                                                                    | Encoding:         | 0011 01da ffff ffff                                                                                                                                                                                                                                                                                                               |
| Encoding:     | 0000 0000 0001 001s                                                                                                                                                                                                                                                                                | Description:      | The contents of register 'f' are rotated                                                                                                                                                                                                                                                                                          |
| Description   | popped and the top of the stack (TOS)<br>is loaded into the program counter. If<br>'s'= 1, the contents of the shadow<br>registers, WS, STATUSS and BSRS,<br>are loaded into their corresponding<br>registers, W, STATUS and BSR. If<br>'s' = 0, no update of these registers<br>occurs (default). |                   | flag. If 'd' is '0', the result is placed in<br>W. If 'd' is '1', the result is stored back<br>in register 'f' (default).<br>If 'a' is '0', the Access Bank is<br>selected. If 'a' is '1', the BSR is used to<br>select the GPR bank (default).<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction |
| Words:        | 1                                                                                                                                                                                                                                                                                                  |                   | operates in Indexed Literal Offset                                                                                                                                                                                                                                                                                                |
| Cycles:       | 2                                                                                                                                                                                                                                                                                                  |                   | $f \le 95$ (5Fh). See Section 24.2.3                                                                                                                                                                                                                                                                                              |
| Q Cycle Ad    | ctivity:                                                                                                                                                                                                                                                                                           |                   | "Byte-Oriented and Bit-Oriented                                                                                                                                                                                                                                                                                                   |
|               | Q1 Q2 Q3 Q4                                                                                                                                                                                                                                                                                        |                   | Instructions in Indexed Literal Offset<br>Mode" for details                                                                                                                                                                                                                                                                       |
| Dec           | code No Process POP PC operation Data from stack                                                                                                                                                                                                                                                   |                   |                                                                                                                                                                                                                                                                                                                                   |
| ١             | No No No                                                                                                                                                                                                                                                                                           | \A/a ada.         | 4                                                                                                                                                                                                                                                                                                                                 |
| oper          | ration operation operation operation                                                                                                                                                                                                                                                               | words:            | 1                                                                                                                                                                                                                                                                                                                                 |
|               |                                                                                                                                                                                                                                                                                                    | Cycles:           | 1                                                                                                                                                                                                                                                                                                                                 |
| Example:      | RETURN                                                                                                                                                                                                                                                                                             | Q Cycle Activity: | 02 02 04                                                                                                                                                                                                                                                                                                                          |
| After Ir      | astruction:                                                                                                                                                                                                                                                                                        | Decode            | Q2 Q3 Q4                                                                                                                                                                                                                                                                                                                          |
| P             | C = TOS                                                                                                                                                                                                                                                                                            | Decode            | register 'f' Data destination                                                                                                                                                                                                                                                                                                     |
|               |                                                                                                                                                                                                                                                                                                    | Example:          | RLCF REG, 0, 0                                                                                                                                                                                                                                                                                                                    |
|               |                                                                                                                                                                                                                                                                                                    | Defens lasta      |                                                                                                                                                                                                                                                                                                                                   |

# TBLRD Table Read

| Syn  | tax:          | TBLRD ( *;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | *+; *- | -; +*)    |             |    |                                           |  |  |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|-------------|----|-------------------------------------------|--|--|
| Оре  | erands:       | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |           |             |    |                                           |  |  |
| Ope  | eration:      | if TBLRD *,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT,<br>TBLPTR – No Change;<br>if TBLRD *+,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT,<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR;<br>if TBLRD *-,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT,<br>(TBLPTR) - 1 $\rightarrow$ TBLPTR;<br>if TBLRD +*,<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT                                                                                                                                                   |        |           |             |    |                                           |  |  |
| Stat | us Affected:  | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |           |             |    |                                           |  |  |
| Enc  | oding:        | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00     | 000       | 000         | 00 | 10nn<br>nn=0 *<br>=1 *+<br>=2 *-<br>=3 +* |  |  |
|      |               | This instruction is used to read the contents<br>of Program Memory (P.M.). To address the<br>program memory, a pointer called Table<br>Pointer (TBLPTR) is used.<br>The TBLPTR (a 21-bit pointer) points to<br>each byte in the program memory. TBLPTR<br>has a 2-Mbyte address range.<br>TBLPTR<0> = 0:Least Significant Byte<br>of Program Memory<br>Word<br>TBLPTR<0> = 1:Most Significant Byte of<br>Program Memory<br>Word<br>The TBLRD instruction can modify the value<br>of TBLPTR as follows:<br>• no change<br>• post-increment |        |           |             |    |                                           |  |  |
| Wo   | rds:          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |           |             |    |                                           |  |  |
| Сус  | les:          | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |           |             |    |                                           |  |  |
| Q    | Cycle Activit | y:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |           |             |    |                                           |  |  |
|      | Q1            | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | C         | 23          |    | Q4                                        |  |  |
|      | Decode        | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1      | N<br>oper | lo<br>ation | 0  | No<br>operation                           |  |  |

# TBLRD Table Read (Continued)

| Example1:                            | TBLRD       | *+                           | ;           |                       |
|--------------------------------------|-------------|------------------------------|-------------|-----------------------|
| Before Instruction                   | n           |                              |             |                       |
| TABLAT<br>TBLPTR<br>MEMORY           | (00A356h    | I)                           | =<br>=<br>= | 55h<br>00A356h<br>34h |
| After Instruction                    |             |                              |             |                       |
| TABLAT<br>TBLPTR                     |             |                              | =<br>=      | 34h<br>00A357h        |
| Example2:                            | TBLRD       | +*                           | ;           |                       |
| Before Instruction                   | n           |                              |             |                       |
| TABLAT<br>TBLPTR<br>MEMORY<br>MEMORY | =<br>=<br>= | AAh<br>01A357h<br>12h<br>34h |             |                       |
| After Instruction                    |             |                              |             |                       |
| TABLAT<br>TBLPTR                     |             |                              | =<br>=      | 34h<br>01A358h        |

No

operation

No operation

(Read Program Memory) No

operation

No operation

(Write TABLAT)

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

| Note: | Enabling  | the   | PIC18        | instruction   | set   |
|-------|-----------|-------|--------------|---------------|-------|
|       | extension | may   | cause le     | gacy applicat | tions |
|       | to behave | errat | ically or fa | ail entirely. |       |

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

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

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

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

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

## 24.2.3.1 Extended Instruction Syntax with Standard PIC18 Commands

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

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

The destination argument, 'd', functions as before.

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

### 24.2.4 CONSIDERATIONS WHEN ENABLING THE EXTENDED INSTRUCTION SET

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

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

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

# DC Characteristics: Power-Down and Supply Current PIC18F2420/2520/4420/4520 (Industrial) PIC18LF2420/2520/4420/4520 (Industrial) (Continued)

| PIC18LF2<br>(Indus | 420/2520/4420/4520Standard Operating Conditions (unless otherwise stated)rial)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |                         |         |            |                                                                                                                                          |                                                                                          | <b>ted)</b><br>strial          |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------|------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------|--|
| PIC18F24<br>(Indus | 2 <b>20/2520/4420/4520</b><br>trial, Extended)                                                                                                            | <b>Standa</b><br>Operat | ard Ope | perating ( | $\begin{array}{l} \text{Conditions (unletermine)}\\ -40^{\circ}\text{C} \leq \text{T}\\ -40^{\circ}\text{C} \leq \text{T}\\ \end{array}$ | ess otherwise states $4 \le +85^{\circ}$ C for indus $4 \le +125^{\circ}$ C for external | <b>ted)</b><br>strial<br>ended |  |
| Param<br>No.       | Device                                                                                                                                                    | Тур                     | Max     | Units      | Conditions                                                                                                                               |                                                                                          |                                |  |
|                    | Supply Current (IDD) <sup>(2)</sup>                                                                                                                       |                         |         |            |                                                                                                                                          |                                                                                          |                                |  |
|                    | PIC18LF2X2X/4X20                                                                                                                                          | 165                     | 250     | μA         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 175                     | 250     | μΑ         | +25°C                                                                                                                                    | VDD = 2.0V                                                                               |                                |  |
|                    |                                                                                                                                                           | 190                     | 270     | μΑ         | +85°C                                                                                                                                    |                                                                                          |                                |  |
|                    | PIC18LF2X2X/4X20                                                                                                                                          | 250                     | 360     | μΑ         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 270                     | 360     | μA         | +25°C                                                                                                                                    | VDD = 3.0V                                                                               | FOSC = 1 MHz                   |  |
|                    |                                                                                                                                                           | 290                     | 380     | μA         | +85°C                                                                                                                                    | ]                                                                                        |                                |  |
|                    | All devices                                                                                                                                               | 500                     | 700     | μΑ         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 520                     | 700     | μA         | +25°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 550                     | 700     | μA         | +85°C                                                                                                                                    | VDD - 5.0V                                                                               |                                |  |
|                    | Extended devices only                                                                                                                                     | 0.6                     | 1       | mA         | +125°C                                                                                                                                   |                                                                                          |                                |  |
|                    | PIC18LF2X2X/4X20                                                                                                                                          | 340                     | 500     | μA         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 350                     | 500     | μA         | +25°C                                                                                                                                    | VDD = 2.0V                                                                               |                                |  |
|                    |                                                                                                                                                           | 360                     | 500     | μA         | +85°C                                                                                                                                    |                                                                                          |                                |  |
|                    | PIC18LF2X2X/4X20                                                                                                                                          | 520                     | 800     | μA         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 540                     | 800     | μA         | +25°C                                                                                                                                    | VDD = 3.0V                                                                               | FOSC = 4 MHZ                   |  |
|                    |                                                                                                                                                           | 580                     | 850     | μΑ         | +85°C                                                                                                                                    |                                                                                          | INTOSC source)                 |  |
|                    | All devices                                                                                                                                               | 1.0                     | 1.6     | mA         | -40°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 1.1                     | 1.4     | mA         | +25°C                                                                                                                                    |                                                                                          |                                |  |
|                    |                                                                                                                                                           | 1.1                     | 1.4     | mA         | +85°C                                                                                                                                    | vuu = 5.0v                                                                               |                                |  |
|                    | Extended devices only                                                                                                                                     | 1.1                     | 2.0     | mA         | +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 high-impedance state and tied to VDD or VSS and all features that add delta current disabled (such as WDT, Timer1 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 or VSS; MCLR = VDD; WDT enabled/disabled as specified.
- **3:** When operation below -10°C is expected, use T1OSC High-Power mode, where LPT1OSC (CONFIG3H<2>) = 0. When operation will always be above -10°C, then the low-power Timer1 oscillator may be selected.
- 4: BOR and HLVD enable internal band gap reference. With both modules enabled, current consumption will be less than the sum of both specifications.

NOTES: