



#### 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                      | 25MHz                                                                     |
| 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 ~ 125°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-e-sp |

Email: info@E-XFL.COM

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

### 3.3 Sleep Mode

The power-managed Sleep mode in the PIC18F2420/ 2520/4420/4520 devices is identical to the legacy Sleep mode offered in all other PIC devices. It is entered by clearing the IDLEN bit (the default state on device Reset) and executing the SLEEP instruction. This shuts down the selected oscillator (Figure 3-5). All clock source status bits are cleared.

Entering the Sleep mode from any other mode does not require a clock switch. This is because no clocks are needed once the controller has entered Sleep. If the WDT is selected, the INTRC source will continue to operate. If the Timer1 oscillator is enabled, it will also continue to run.

When a wake event occurs in Sleep mode (by interrupt, Reset or WDT time-out), the device will not be clocked until the clock source selected by the SCS<1:0> bits becomes ready (see Figure 3-6), or it will be clocked from the internal oscillator block if either the Two-Speed Start-up or the Fail-Safe Clock Monitor are enabled (see **Section 23.0 "Special Features of the CPU"**). In either case, the OSTS bit is set when the primary clock is providing the device clocks. The IDLEN and SCS bits are not affected by the wake-up.

### 3.4 Idle Modes

The Idle modes allow the controller's CPU to be selectively shut down while the peripherals continue to operate. Selecting a particular Idle mode allows users to further manage power consumption.

If the IDLEN bit is set to '1' when a SLEEP instruction is executed, the peripherals will be clocked from the clock source selected using the SCS<1:0> bits; however, the CPU will not be clocked. The clock source status bits are not affected. Setting IDLEN and executing a SLEEP instruction provides a quick method of switching from a given Run mode to its corresponding Idle mode.

If the WDT is selected, the INTRC source will continue to operate. If the Timer1 oscillator is enabled, it will also continue to run.

Since the CPU is not executing instructions, the only exits from any of the Idle modes are by interrupt, WDT time-out or a Reset. When a wake event occurs, CPU execution is delayed by an interval of TcsD (parameter 38, Table 26-10) while it becomes ready to execute code. When the CPU begins executing code, it resumes with the same clock source for the current Idle mode. For example, when waking from RC\_IDLE mode, the internal oscillator block will clock the CPU and peripherals (in other words, RC\_RUN mode). The IDLEN and SCS bits are not affected by the wake-up.

While in any Idle mode or the Sleep mode, a WDT time-out will result in a WDT wake-up to the Run mode currently specified by the SCS1:SCS0 bits.









### 5.3 Data Memory Organization

Note: The operation of some aspects of data memory are changed when the PIC18 extended instruction set is enabled. See Section 5.5 "Data Memory and the Extended Instruction Set" for more information.

The data memory in PIC18 devices is implemented as static RAM. Each register in the data memory has a 12-bit address, allowing up to 4096 bytes of data memory. The memory space is divided into as many as 16 banks that contain 256 bytes each; PIC18F2420/2520/4420/4520 devices implement all 16 banks. Figure 5-5 shows the data memory organization for the PIC18F2420/2520/4420/4520 devices.

The data memory contains Special Function Registers (SFRs) and General Purpose Registers (GPRs). The SFRs are used for control and status of the controller and peripheral functions, while GPRs are used for data storage and scratchpad operations in the user's application. Any read of an unimplemented location will read as '0's.

The instruction set and architecture allow operations across all banks. The entire data memory may be accessed by Direct, Indirect or Indexed Addressing modes. Addressing modes are discussed later in this subsection.

To ensure that commonly used registers (SFRs and select GPRs) can be accessed in a single cycle, PIC18 devices implement an Access Bank. This is a 256-byte memory space that provides fast access to SFRs and the lower portion of GPR Bank 0 without using the BSR. **Section 5.3.2** "Access Bank" provides a detailed description of the Access RAM.

#### 5.3.1 BANK SELECT REGISTER (BSR)

Large areas of data memory require an efficient addressing scheme to make rapid access to any address possible. Ideally, this means that an entire address does not need to be provided for each read or write operation. For PIC18 devices, this is accomplished with a RAM banking scheme. This divides the memory space into 16 contiguous banks of 256 bytes. Depending on the instruction, each location can be addressed directly by its full 12-bit address, or an 8-bit low-order address and a 4-bit Bank Pointer.

Most instructions in the PIC18 instruction set make use of the Bank Pointer, known as the Bank Select Register (BSR). This SFR holds the 4 Most Significant bits of a location's address; the instruction itself includes the 8 Least Significant bits. Only the four lower bits of the BSR are implemented (BSR<3:0>). The upper four bits are unused; they will always read '0' and cannot be written to. The BSR can be loaded directly by using the MOVLB instruction.

The value of the BSR indicates the bank in data memory; the 8 bits in the instruction show the location in the bank and can be thought of as an offset from the bank's lower boundary. The relationship between the BSR's value and the bank division in data memory is shown in Figure 5-7.

Since up to 16 registers may share the same low-order address, the user must always be careful to ensure that the proper bank is selected before performing a data read or write. For example, writing what should be program data to an 8-bit address of F9h while the BSR is 0Fh will end up resetting the program counter.

While any bank can be selected, only those banks that are actually implemented can be read or written to. Writes to unimplemented banks are ignored, while reads from unimplemented banks will return '0's. Even so, the STATUS register will still be affected as if the operation was successful. The data memory map in Figure 5-5 indicates which banks are implemented.

In the core PIC18 instruction set, only the MOVFF instruction fully specifies the 12-bit address of the source and target registers. This instruction ignores the BSR completely when it executes. All other instructions include only the low-order address as an operand and must use either the BSR or the Access Bank to locate their target registers.

### 5.5.3 MAPPING THE ACCESS BANK IN INDEXED LITERAL OFFSET MODE

The use of Indexed Literal Offset Addressing mode effectively changes how the first 96 locations of Access RAM (00h to 5Fh) are mapped. Rather than containing just the contents of the bottom half of Bank 0, this mode maps the contents from Bank 0 and a user-defined "window" that can be located anywhere in the data memory space. The value of FSR2 establishes the lower boundary of the addresses mapped into the window, while the upper boundary is defined by FSR2 plus 95 (5Fh). Addresses in the Access RAM above 5Fh are mapped as previously described (see **Section 5.3.2 "Access Bank**"). An example of Access Bank remapping in this addressing mode is shown in Figure 5-10. Remapping of the Access Bank applies *only* to operations using the Indexed Literal Offset mode. Operations that use the BSR (Access RAM bit is '1') will continue to use Direct Addressing as before.

### 5.6 PIC18 Instruction Execution and the Extended Instruction Set

Enabling the extended instruction set adds eight additional commands to the existing PIC18 instruction set. These instructions are executed as described in **Section 24.2 "Extended Instruction Set"**.

### FIGURE 5-10: REMAPPING THE ACCESS BANK WITH INDEXED LITERAL OFFSET ADDRESSING

### Example Situation:

ADDWF f, d, a FSR2H:FSR2L = 120h

Locations in the region from the FSR2 Pointer (120h) to the pointer plus 05Fh (17Fh) are mapped to the bottom of the Access RAM (000h-05Fh).

Locations in Bank 0 from 060h to 07Fh are mapped, as usual, to the middle half of the Access Bank.

Special Function Registers at F80h through FFFh are mapped to 80h through FFh, as usual.

Bank 0 addresses below 5Fh can still be addressed by using the BSR.



### 6.3 Reading the Flash Program Memory

The TBLRD instruction is used to retrieve data from program memory and places it into data RAM. Table reads from program memory are performed one byte at a time.

TBLPTR points to a byte address in program space. Executing TBLRD places the byte pointed to into TABLAT. In addition, TBLPTR can be modified automatically for the next table read operation.

The internal program memory is typically organized by words. The Least Significant bit of the address selects between the high and low bytes of the word. Figure 6-4 shows the interface between the internal program memory and the TABLAT.

### FIGURE 6-4: READS FROM FLASH PROGRAM MEMORY



### EXAMPLE 6-1: READING A FLASH PROGRAM MEMORY WORD

|           | MOVLW<br>MOVWF<br>MOVLW<br>MOVUF<br>MOVLW<br>MOVWF | CODE_ADDR_UPPER<br>TBLPTRU<br>CODE_ADDR_HIGH<br>TBLPTRH<br>CODE_ADDR_LOW<br>TBLPTRL | ;; | : Load TBLPTR with the base<br>: address of the word |
|-----------|----------------------------------------------------|-------------------------------------------------------------------------------------|----|------------------------------------------------------|
| READ_WORD |                                                    |                                                                                     |    |                                                      |
|           | TBLRD*-                                            | ÷                                                                                   | ;  | ; read into TABLAT and increment                     |
|           | MOVF                                               | TABLAT, W                                                                           | ;  | ; get data                                           |
|           | MOVWF                                              | WORD_EVEN                                                                           |    |                                                      |
|           | TBLRD*-                                            | +                                                                                   | ;  | ; read into TABLAT and increment                     |
|           | MOVFW                                              | TABLAT, W                                                                           | ;  | ; get data                                           |
|           | MOVF                                               | WORD_ODD                                                                            |    |                                                      |
|           |                                                    |                                                                                     |    |                                                      |

### 9.6 INTx Pin Interrupts

External interrupts on the RB0/INT0, RB1/INT1 and RB2/INT2 pins are edge-triggered. If the corresponding INTEDGx bit in the INTCON2 register is set (= 1), the interrupt is triggered by a rising edge; if the bit is clear, the trigger is on the falling edge. When a valid edge appears on the RBx/INTx pin, the corresponding flag bit, INTxIF, is set. This interrupt can be disabled by clearing the corresponding enable bit, INTxIE. Flag bit, INTxIF, must be cleared in software in the Interrupt Service Routine before re-enabling the interrupt.

All external interrupts (INT0, INT1 and INT2) can wakeup the processor from Idle or Sleep modes if bit INTxIE was set prior to going into those modes. If the Global Interrupt Enable bit, GIE, is set, the processor will branch to the interrupt vector following wake-up.

Interrupt priority for INT1 and INT2 is determined by the value contained in the Interrupt Priority bits, INT1IP (INTCON3<6>) and INT2IP (INTCON3<7>). There is no priority bit associated with INT0. It is always a high-priority interrupt source.

### 9.7 TMR0 Interrupt

In 8-bit mode (which is the default), an overflow in the TMR0 register (FFh  $\rightarrow$  00h) will set flag bit, TMR0IF. In 16-bit mode, an overflow in the TMR0H:TMR0L register pair (FFFFh  $\rightarrow$  0000h) will set TMR0IF. The interrupt can be enabled/disabled by setting/clearing enable bit, TMR0IE (INTCON<5>). Interrupt priority for Timer0 is determined by the value contained in the interrupt priority bit, TMR0IP (INTCON2<2>). See Section 11.0 "Timer0 Module" for further details on the Timer0 module.

### 9.8 PORTB Interrupt-on-Change

An input change on PORTB<7:4> sets flag bit, RBIF (INTCON<0>). The interrupt can be enabled/disabled by setting/clearing enable bit, RBIE (INTCON<3>). Interrupt priority for PORTB interrupt-on-change is determined by the value contained in the interrupt priority bit, RBIP (INTCON2<0>).

### 9.9 Context Saving During Interrupts

During interrupts, the return PC address is saved on the stack. Additionally, the WREG, STATUS and BSR registers are saved on the Fast Return Stack. If a fast return from interrupt is not used (see **Section 5.3 "Data Memory Organization"**), the user may need to save the WREG, STATUS and BSR registers on entry to the Interrupt Service Routine. Depending on the user's application, other registers may also need to be saved. Example 9-1 saves and restores the WREG, STATUS and BSR registers during an Interrupt Service Routine.

MOVWF W TEMP ; W\_TEMP is in virtual bank MOVFF STATUS, STATUS TEMP ; STATUS TEMP located anywhere MOVEE ; BSR TMEP located anywhere BSR, BSR TEMP ; ; USER ISR CODE ; BSR\_TEMP, BSR MOVFF ; Restore BSR W TEMP, W MOVE ; Restore WREG MOVEE STATUS TEMP, STATUS ; Restore STATUS

EXAMPLE 9-1: SAVING STATUS, WREG AND BSR REGISTERS IN RAM

### TABLE 10-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD

| Name                 | Bit 7                                                    | Bit 6               | Bit 5    | Bit 4   | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|----------------------|----------------------------------------------------------|---------------------|----------|---------|--------|--------|--------|--------|----------------------------|
| PORTD                | RD7                                                      | RD6                 | RD5      | RD4     | RD3    | RD2    | RD1    | RD0    | 52                         |
| LATD                 | PORTD Data Latch Register (Read and Write to Data Latch) |                     |          |         |        |        |        |        |                            |
| TRISD                | PORTD Da                                                 | ata Direction       | Register |         |        |        |        |        | 52                         |
| TRISE <sup>(1)</sup> | IBF                                                      | OBF                 | IBOV     | PSPMODE | —      | TRISE2 | TRISE1 | TRISE0 | 52                         |
| CCP1CON              | P1M1 <sup>(1)</sup>                                      | P1M0 <sup>(1)</sup> | DC1B1    | DC1B0   | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 | 51                         |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by PORTD.

Note 1: These registers and/or bits are unimplemented on 28-oin devices.

### 17.0 MASTER SYNCHRONOUS SERIAL PORT (MSSP) MODULE

### 17.1 Master SSP (MSSP) Module Overview

The Master Synchronous Serial Port (MSSP) module is a serial interface, useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D Converters, etc. The MSSP module can operate in one of two modes:

- Serial Peripheral Interface (SPI)
- Inter-Integrated Circuit (I<sup>2</sup>C)
  - Full Master mode
  - Slave mode (with general address call)

The  $I^2C$  interface supports the following modes in hardware:

- Master mode
- · Multi-Master mode
- Slave mode

### 17.2 Control Registers

The MSSP module has three associated registers. These include a status register (SSPSTAT) and two control registers (SSPCON1 and SSPCON2). The use of these registers and their individual configuration bits differ significantly depending on whether the MSSP module is operated in SPI or  $I^2C$  mode.

Additional details are provided under the individual sections.

### 17.3 SPI Mode

The SPI mode allows 8 bits of data to be synchronously transmitted and received simultaneously. All four modes of SPI are supported. To accomplish communication, typically three pins are used:

- Serial Data Out (SDO) RC5/SDO
- Serial Data In (SDI) RC4/SDI/SDA
- Serial Clock (SCK) RC3/SCK/SCL

Additionally, a fourth pin may be used when in a Slave mode of operation:

Slave Select (SS) – RA5/SS

Figure 17-1 shows the block diagram of the MSSP module when operating in SPI mode.





### 17.4.4.5 Clock Synchronization and the CKP bit

When the CKP bit is cleared, the SCL output is forced to '0'. However, clearing the CKP bit will not assert the SCL output low until the SCL output is already sampled low. Therefore, the CKP bit will not assert the SCL line until an external  $I^2C$  master device has

already asserted the SCL line. The SCL output will remain low until the CKP bit is set and all other devices on the  $I^2$ C bus have deasserted SCL. This ensures that a write to the CKP bit will not violate the minimum high time requirement for SCL (see Figure 17-12).





### 17.4.8 I<sup>2</sup>C MASTER MODE START CONDITION TIMING

To initiate a Start condition, the user sets the Start Enable bit, SEN (SSPCON2<0>). If the SDA and SCL pins are sampled high, the Baud Rate Generator is reloaded with the contents of SSPADD<6:0> and starts its count. If SCL and SDA are both sampled high when the Baud Rate Generator times out (TBRG), the SDA pin is driven low. The action of the SDA being driven low while SCL is high is the Start condition and causes the S bit (SSPSTAT<3>) to be set. Following this, the Baud Rate Generator is reloaded with the contents of SSPADD<6:0> and resumes its count. When the Baud Rate Generator times out (TBRG), the SEN bit (SSPCON2<0>) will be automatically cleared by hardware; the Baud Rate Generator is suspended, leaving the SDA line held low and the Start condition is complete.

**Note:** If, at the beginning of the Start condition, the SDA and SCL pins are already sampled low, or if during the Start condition, the SCL line is sampled low before the SDA line is driven low, a bus collision occurs, the Bus Collision Interrupt Flag, BCLIF, is set, the Start condition is aborted and the I<sup>2</sup>C module is reset into its Idle state.

### 17.4.8.1 WCOL Status Flag

If the user writes the SSPBUF when a Start sequence is in progress, the WCOL is set and the contents of the buffer are unchanged (the write doesn't occur).

Note: Because queueing of events is not allowed, writing to the lower 5 bits of SSPCON2 is disabled until the Start condition is complete.



### FIGURE 17-19: FIRST START BIT TIMING

| REGISTER     | 18-2: RCS                                                                                  | TA: RECEIVE                                                                                  | E STATUS AI                                                                      | ND CONTROL                            | REGISTER                          | 2                                 |                       |
|--------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------|-----------------------------------|-----------------------------------|-----------------------|
| R/W-0        | R/W-0                                                                                      | R/W-0                                                                                        | R/W-0                                                                            | R/W-0                                 | R-0                               | R-0                               | R-x                   |
| SPEN         | RX9                                                                                        | SREN                                                                                         | CREN                                                                             | ADDEN                                 | FERR                              | OERR                              | RX9D                  |
| bit 7        |                                                                                            |                                                                                              |                                                                                  |                                       |                                   |                                   | bit (                 |
| Legend:      |                                                                                            |                                                                                              |                                                                                  |                                       |                                   |                                   |                       |
| R = Readab   | le bit                                                                                     | W = Writable                                                                                 | bit                                                                              | U = Unimplem                          | nented bit, rea                   | ad as '0'                         |                       |
| -n = Value a | t POR                                                                                      | '1' = Bit is se                                                                              | t                                                                                | '0' = Bit is clea                     | ared                              | x = Bit is unkn                   | iown                  |
| bit 7        | <b>SPEN:</b> Seria<br>1 = Serial po<br>0 = Serial po                                       | al Port Enable b<br>ort enabled (co<br>ort disabled (he                                      | it<br>nfigures RX/D⊺<br>ld in Reset)                                             | Г and TX/CK pin                       | s as serial po                    | rt pins)                          |                       |
| bit 6        | <b>RX9:</b> 9-Bit R                                                                        | eceive Enable                                                                                | bit                                                                              |                                       |                                   |                                   |                       |
|              | 1 = Selects<br>0 = Selects                                                                 | 9-bit reception<br>8-bit reception                                                           |                                                                                  |                                       |                                   |                                   |                       |
| bit 5        | SREN: Singl                                                                                | le Receive Ena                                                                               | ble bit                                                                          |                                       |                                   |                                   |                       |
|              | <u>Asynchronou</u><br>Don't care.                                                          | <u>us mode</u> :                                                                             |                                                                                  |                                       |                                   |                                   |                       |
|              | Synchronous<br>1 = Enables<br>0 = Disables<br>This bit is cle<br>Synchronous<br>Don't care | s mode – Maste<br>s single receive<br>s single receive<br>eared after rece<br>s mode – Slave | er:<br>ption is comple                                                           | ete.                                  |                                   |                                   |                       |
| hit 1        | CPEN: Cont                                                                                 |                                                                                              | Enable bit                                                                       |                                       |                                   |                                   |                       |
| Dit 4        | Asynchronou<br>1 = Enables<br>0 = Disables                                                 | us mode:<br>receiver<br>s receiver                                                           |                                                                                  |                                       |                                   |                                   |                       |
|              | Synchronous<br>1 = Enables<br>0 = Disables                                                 | <u>s mode:</u><br>continuous rec<br>s continuous re                                          | ceive until enat                                                                 | ble bit, CREN, is                     | cleared (CRI                      | EN overrides SR                   | EN)                   |
| bit 3        | ADDEN: Add                                                                                 | dress Detect Er                                                                              | nable bit                                                                        |                                       |                                   |                                   |                       |
|              | Asynchronou<br>1 = Enables<br>0 = Disables<br>Asynchronou<br>Don't care.                   | <u>us mode 9-Bit (</u><br>address detec<br>s address detec<br>us mode 9-Bit (                | <u>RX9 = 1)</u> :<br>tion, enables ir<br>ction, all bytes (<br><u>RX9 = 0</u> ): | nterrupt and load<br>are received and | ds the receive<br>d ninth bit can | buffer when RS<br>be used as pari | R<8> is set<br>ty bit |
| bit 2        | FERR: Fram                                                                                 | ning Error bit                                                                               |                                                                                  |                                       |                                   |                                   |                       |
|              | 1 = Framing<br>0 = No fram                                                                 | error (can be o<br>ing error                                                                 | cleared by read                                                                  | ling RCREG reg                        | jister and rece                   | eiving next valid                 | byte)                 |
| bit 1        | OERR: Over                                                                                 | rrun Error bit                                                                               |                                                                                  |                                       |                                   |                                   |                       |
|              | 1 = Overrun<br>0 = No over                                                                 | error (can be c<br>run error                                                                 | cleared by clea                                                                  | ring bit, CREN)                       |                                   |                                   |                       |
| bit 0        | <b>RX9D:</b> 9th B<br>This can be a                                                        | it of Received I<br>address/data bi                                                          | Data<br>it or a parity bit                                                       | and must be ca                        | lculated by us                    | ser firmware.                     |                       |

### 18.2 EUSART Asynchronous Mode

The Asynchronous mode of operation is selected by clearing the SYNC bit (TXSTA<4>). In this mode, the EUSART uses standard Non-Return-to-Zero (NRZ) format (one Start bit, eight or nine data bits and one Stop bit). The most common data format is 8 bits. An on-chip, dedicated 8-bit/16-bit Baud Rate Generator can be used to derive standard baud rate frequencies from the oscillator.

The EUSART transmits and receives the LSb first. The EUSART's transmitter and receiver are functionally independent but use the same data format and baud rate. The Baud Rate Generator produces a clock, either x16 or x64 of the bit shift rate depending on the BRGH and BRG16 bits (TXSTA<2> and BAUDCON<3>). Parity is not supported by the hardware but can be implemented in software and stored as the 9th data bit.

When operating in Asynchronous mode, the EUSART module consists of the following important elements:

- Baud Rate Generator
- Sampling Circuit
- Asynchronous Transmitter
- Asynchronous Receiver
- Auto-Wake-up on Sync Break Character
- 12-Bit Break Character Transmit
- Auto-Baud Rate Detection

#### 18.2.1 EUSART ASYNCHRONOUS TRANSMITTER

The EUSART transmitter block diagram is shown in Figure 18-3. The heart of the transmitter is the Transmit (Serial) Shift Register (TSR). The Shift register obtains its data from the Read/Write Transmit Buffer register, TXREG. The TXREG register is loaded with data in software. The TSR register is not loaded until the Stop bit has been transmitted from the previous load. As soon as the Stop bit is transmitted, the TSR is loaded with new data from the TXREG register (if available). Once the TXREG register transfers the data to the TSR register (occurs in one TCY), the TXREG register is empty and the TXIF flag bit (PIR1<4>) is set. This interrupt can be enabled or disabled by setting or clearing the interrupt enable bit, TXIE (PIE1<4>). TXIF will be set regardless of the state of TXIE; it cannot be cleared in software. TXIF is also not cleared immediately upon loading TXREG, but becomes valid in the second instruction cycle following the load instruction. Polling TXIF immediately following a load of TXREG will return invalid results.

While TXIF indicates the status of the TXREG register, another bit, TRMT (TXSTA<1>), shows the status of the TSR register. TRMT is a read-only bit which is set when the TSR register is empty. No interrupt logic is tied to this bit so the user has to poll this bit in order to determine if the TSR register is empty.

Note 1: The TSR register is not mapped in data memory so it is not available to the user.
2: Flag bit, TXIF, is set when enable bit, TXEN, is set.

To set up an Asynchronous Transmission:

- 1. Initialize the SPBRGH:SPBRG registers for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Enable the asynchronous serial port by clearing bit, SYNC, and setting bit, SPEN.
- 3. If interrupts are desired, set enable bit, TXIE.
- 4. If 9-bit transmission is desired, set transmit bit, TX9. Can be used as address/data bit.
- 5. Enable the transmission by setting bit, TXEN, which will also set bit, TXIF.
- 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit, TX9D.
- 7. Load data to the TXREG register (starts transmission).
- If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

### FIGURE 18-3: EUSART TRANSMIT BLOCK DIAGRAM





| 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 F                                      | Receive Regis | ster         |              |       |        |        |        | 51                         |
| TXSTA   | CSRC                                          | TX9           | TXEN         | SYNC         | SENDB | BRGH   | TRMT   | TX9D   | 51                         |
| BAUDCON | ABDOVF                                        | RCIDL         | RXDTP        | TXCKP        | BRG16 | _      | WUE    | ABDEN  | 51                         |
| SPBRGH  | EUSART Baud Rate Generator Register High Byte |               |              |              |       |        |        |        |                            |
| SPBRG   | EUSART E                                      | Baud Rate Ge  | enerator Reg | gister Low E | Byte  |        |        |        | 51                         |

**REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTION** 

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.

**TABLE 18-6**:

### 23.5.1 PROGRAM MEMORY CODE PROTECTION

The program memory may be read to, or written from, any location using the table read and table write instructions. The Device ID may be read with table reads. The Configuration registers may be read and written with the table read and table write instructions.

In normal execution mode, the CPn bits have no direct effect. CPn bits inhibit external reads and writes. A block of user memory may be protected from table writes if the WRTn Configuration bit is '0'. The EBTRn bits control table reads. For a block of user memory with the EBTRn bit set to '0', a table read instruction that executes from within that block is allowed to read. A table read instruction that executes from a location outside of that block is not allowed to read and will result in reading '0's. Figures 23-6 through 23-8 illustrate table write and table read protection.

Note: Code protection bits may only be written to a '0' from a '1' state. It is not possible to write a '1' to a bit in the '0' state. Code protection bits are only set to '1' by a full chip erase or block erase function. The full chip erase and block erase functions can only be initiated via ICSP or an external programmer.

### FIGURE 23-6: TABLE WRITE (WRTn) DISALLOWED



### TABLE 24-1: OPCODE FIELD DESCRIPTIONS

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

| BNC          | ;                                                                   | Branch if                                                                                                                | Not Carry                                                                                                                  |                                                                                      | BNN                          |                                                                             | Branch if                                                                                                           | Not Negat                                                                                                                       | tive                                                           |                                                 |  |
|--------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------|--|
| Synt         | ax:                                                                 | BNC n                                                                                                                    |                                                                                                                            |                                                                                      | Synta:                       | Syntax:                                                                     |                                                                                                                     | BNN n                                                                                                                           |                                                                |                                                 |  |
| Oper         | ands:                                                               | -128 ≤ n ≤ 1                                                                                                             | 127                                                                                                                        |                                                                                      | Opera                        | Operands:                                                                   |                                                                                                                     | $-128 \le n \le 127$                                                                                                            |                                                                |                                                 |  |
| Oper         | ation:                                                              | tion: if Carry bit is '0',<br>(PC) + 2 + 2n $\rightarrow$ PC                                                             |                                                                                                                            | Opera                                                                                | Operation:                   |                                                                             | if Negative bit is '0',<br>(PC) + 2 + 2n $\rightarrow$ PC                                                           |                                                                                                                                 |                                                                |                                                 |  |
| Statu        | is Affected:                                                        | None                                                                                                                     |                                                                                                                            |                                                                                      | Status                       | Affected:                                                                   | None                                                                                                                |                                                                                                                                 |                                                                |                                                 |  |
| Enco         | oding:                                                              | 1110                                                                                                                     | 0011 nni                                                                                                                   | nn nnnn                                                                              | Encod                        | ling:                                                                       | 1110                                                                                                                | 0111 n                                                                                                                          | nnn                                                            | nnnn                                            |  |
| Desc         | pription:                                                           | If the Carry<br>will branch.<br>The 2's con<br>added to the<br>incremente<br>instruction,<br>PC + 2 + 2r<br>two-cycle in | bit is '0', then<br>nplement num<br>e PC. Since th<br>d to fetch the r<br>the new addre<br>n. This instruct<br>nstruction. | the program<br>ber '2n' is<br>e PC will have<br>next<br>ess will be<br>ion is then a | Descr                        | iption:                                                                     | If the Nega<br>program wi<br>The 2's cor<br>added to th<br>incremente<br>instruction,<br>PC + 2 + 2<br>two-cycle ir | tive bit is 'o',<br>Ill branch.<br>mplement nu<br>e PC. Since<br>d to fetch the<br>the new ado<br>n. This instru<br>nstruction. | then th<br>mber '2<br>the PC<br>e next<br>dress w<br>iction is | ne<br>2n' is<br>will have<br>ill be<br>s then a |  |
| Word         | ds:                                                                 | 1                                                                                                                        |                                                                                                                            |                                                                                      | Words                        | 3:                                                                          | 1                                                                                                                   |                                                                                                                                 |                                                                |                                                 |  |
| Cycle        | es:                                                                 | 1(2)                                                                                                                     |                                                                                                                            |                                                                                      | Cycles                       | S:                                                                          | 1(2)                                                                                                                |                                                                                                                                 |                                                                |                                                 |  |
| Q C<br>If Ju | ycle Activity:<br>imp:                                              |                                                                                                                          |                                                                                                                            |                                                                                      | Q Cy<br>If Jur               | cle Activity:<br>np:                                                        |                                                                                                                     |                                                                                                                                 |                                                                |                                                 |  |
|              | Q1                                                                  | Q2                                                                                                                       | Q3                                                                                                                         | Q4                                                                                   | -                            | Q1                                                                          | Q2                                                                                                                  | Q3                                                                                                                              |                                                                | Q4                                              |  |
|              | Decode                                                              | Read literal<br>'n'                                                                                                      | Process<br>Data                                                                                                            | Write to PC                                                                          |                              | Decode                                                                      | Read literal<br>'n'                                                                                                 | Process<br>Data                                                                                                                 | Wri                                                            | te to PC                                        |  |
|              | No<br>operation                                                     | No<br>operation                                                                                                          | No<br>operation                                                                                                            | No<br>operation                                                                      |                              | No<br>operation                                                             | No<br>operation                                                                                                     | No<br>operation                                                                                                                 | ор                                                             | No<br>eration                                   |  |
| lf No        | o Jump:                                                             |                                                                                                                          |                                                                                                                            |                                                                                      | lf No                        | Jump:                                                                       |                                                                                                                     |                                                                                                                                 |                                                                |                                                 |  |
|              | Q1                                                                  | Q2                                                                                                                       | Q3                                                                                                                         | Q4                                                                                   | F                            | Q1                                                                          | Q2                                                                                                                  | Q3                                                                                                                              |                                                                | Q4                                              |  |
|              | Decode                                                              | Read literal<br>'n'                                                                                                      | Process<br>Data                                                                                                            | No<br>operation                                                                      |                              | Decode                                                                      | Read literal<br>'n'                                                                                                 | Process<br>Data                                                                                                                 | ор                                                             | No<br>eration                                   |  |
| <u>Exar</u>  | nple:<br>PC<br>After Instructio<br>If Carry<br>PC<br>If Carry<br>PC | HERE<br>stion = add<br>on = 0;<br>= add<br>= 1;<br>= add                                                                 | BNC Jump<br>dress (HERE<br>dress (Jump<br>dress (HERE                                                                      | )<br>)<br>+ 2)                                                                       | <u>Exam</u><br>E<br><i>P</i> | <u>ple:</u><br>PC<br>After Instructio<br>If Negati<br>PC<br>If Negati<br>PC | HERE<br>tion = ad<br>ve = 0;<br>= ad<br>ve = 1;<br>= ad                                                             | BNN Jun<br>dress (HER<br>dress (Jum<br>dress (HER                                                                               | np<br>E)<br>np)<br>E + 2                                       | )                                               |  |

| CLRF     |                                                                                                                                 | Clear f                                                               |             |                        |                   | CLR    | NDT                           | Clear W                                                                                 | atchdog      | Time                | r            |
|----------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------|------------------------|-------------------|--------|-------------------------------|-----------------------------------------------------------------------------------------|--------------|---------------------|--------------|
| Syntax:  |                                                                                                                                 | CLRF f{,;                                                             | a}          |                        |                   | Synta  | x:                            | CLRWD                                                                                   | -            |                     |              |
| Operan   | ds:                                                                                                                             | $0 \leq f \leq 255$                                                   |             |                        |                   | Opera  | ands:                         | None                                                                                    |              |                     |              |
|          |                                                                                                                                 | a ∈ [0,1]                                                             |             |                        |                   | Opera  | ation:                        | $000h \rightarrow V$                                                                    | NDT,         |                     |              |
| Operatio | on:                                                                                                                             | $\begin{array}{l} 000h \rightarrow f, \\ 1 \rightarrow Z \end{array}$ |             |                        |                   |        |                               | $\begin{array}{c} 000h \rightarrow V\\ 1 \rightarrow \overline{\text{TO}}, \end{array}$ | WDT posts    | caler,              |              |
| Status A | Affected:                                                                                                                       | Z                                                                     |             |                        |                   | _      |                               | $1 \rightarrow PD$                                                                      |              |                     |              |
| Encodin  | ig:                                                                                                                             | 0110                                                                  | 101a        | ffff                   | ffff              | Status | Affected:                     | TO, PD                                                                                  | 1            |                     |              |
| Descrip  | tion:                                                                                                                           | Clears the                                                            | contents o  | of the spe             | cified            | Encod  | ling:                         | 0000                                                                                    | 0000         | 000                 | 0 0100       |
|          |                                                                                                                                 | register.                                                             | h           | - Deels is             |                   | Descr  | iption:                       | CLRWDT                                                                                  | instruction  | resets              | s the        |
|          |                                                                                                                                 | lf a is 0,t                                                           | he BSR is   | s Bank is<br>used to s | selected.         |        |                               | scaler of                                                                               | the WDT. S   | aiso re<br>Status I | bits. TO and |
|          |                                                                                                                                 | GPR bank                                                              | (default).  |                        |                   |        |                               | PD, are s                                                                               | et.          |                     |              |
|          | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing |                                                                       | Words       | S:                     | 1                 |        |                               |                                                                                         |              |                     |              |
|          |                                                                                                                                 |                                                                       | Cycle       | S:                     | 1                 |        |                               |                                                                                         |              |                     |              |
|          |                                                                                                                                 | mode when                                                             | never f ≤ 9 | 5 (5Fh). S             | See               | Q Cy   | cle Activity:                 |                                                                                         |              |                     |              |
|          |                                                                                                                                 | Section 24                                                            | .2.3 "Byte  | e-Oriente              | ed and<br>Indexed |        | Q1                            | Q2                                                                                      | Q3           | 3                   | Q4           |
|          |                                                                                                                                 | Literal Offs                                                          | set Mode'   | " for detai            | ils.              |        | Decode                        | No                                                                                      | Proce        | ess                 | No           |
| Words:   |                                                                                                                                 | 1                                                                     |             |                        |                   | L      |                               | operation                                                                               | Dat          | a                   | operation    |
| Cycles:  |                                                                                                                                 | 1                                                                     |             |                        |                   | Exam   | nle <sup>.</sup>              | CLEWDT                                                                                  |              |                     |              |
| Q Cycl   | e Activity:                                                                                                                     |                                                                       |             |                        |                   | Exam   | <u>pio.</u><br>Refore Instruc | tion                                                                                    |              |                     |              |
|          | Q1                                                                                                                              | Q2                                                                    | Q3          |                        | Q4                | L      | WDT Co                        | unter                                                                                   | = ?          |                     |              |
|          | Decode                                                                                                                          | Read                                                                  | Proces      | SS                     | Write             | ŀ      | After Instruction             | on                                                                                      |              |                     |              |
|          |                                                                                                                                 | register 'f'                                                          | Data        | re                     | gister 'f'        |        | WDT Co<br>WDT Po              | unter<br>stscaler                                                                       | = 00h<br>= 0 |                     |              |
| Example  | <u>e:</u>                                                                                                                       | CLRF                                                                  | FLAG_R      | EG, 1                  |                   |        | TO<br>PD                      |                                                                                         | = 1<br>= 1   |                     |              |
| Be       | fore Instruc                                                                                                                    | tion                                                                  |             |                        |                   |        |                               |                                                                                         |              |                     |              |
|          | FLAG_R                                                                                                                          | EG = 5A                                                               | 'n          |                        |                   |        |                               |                                                                                         |              |                     |              |
| Aft      | er Instructio                                                                                                                   | n<br>FG = 00                                                          | h           |                        |                   |        |                               |                                                                                         |              |                     |              |
|          | FLAG_R                                                                                                                          | _0 _ 00                                                               |             |                        |                   |        |                               |                                                                                         |              |                     |              |

| RCALL Relative Call |                       |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                          |          |        |          |            | ESET                                                                |
|---------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|----------|------------|---------------------------------------------------------------------|
| Synta               | ax:                   | RCALL n                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                          | Sy       | /ntax: |          |            |                                                                     |
| Oper                | ands:                 | -1024 ≤ n ≤                                                                                                                         | 1023                                                                                                                                                                                                                                                                                                                                                     |          |        |          | O          | perands:                                                            |
| Oper                | ation:                | $(PC) + 2 \rightarrow (PC) + 2 + 2$                                                                                                 | TOS,<br>2n $\rightarrow$ PC                                                                                                                                                                                                                                                                                                                              | ;        |        |          | O          | peration:                                                           |
| Statu               | s Affected:           | None                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                          |          |        |          | St         | atus Affected:                                                      |
| Enco                | ding:                 | 1101                                                                                                                                | 1nnn                                                                                                                                                                                                                                                                                                                                                     | nnr      | ın     | nnnn     | Er         | ncoding:                                                            |
| Desc                | ription:              | Subroutine<br>from the cu<br>address (PC<br>stack. Then<br>number '2n<br>have increm<br>instruction,<br>PC + 2 + 2r<br>two-cycle in | Subroutine call with a jump up to 1K<br>from the current location. First, return<br>address (PC + 2) is pushed onto the<br>stack. Then, add the 2's complement<br>number '2n' to the PC. Since the PC will<br>have incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is a<br>two-cycle instruction. |          |        |          |            | escription:<br>ords:<br>ycles:<br>Q Cycle Activity:<br>Q1<br>Decode |
| Word                | s:                    | 1                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                          |          |        |          |            |                                                                     |
| Cycle<br>Q C        | es:<br>ycle Activity: | 2                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                          |          |        |          | <u>E</u> > | <u>cample:</u>                                                      |
|                     | Q1                    | Q2                                                                                                                                  | Q3                                                                                                                                                                                                                                                                                                                                                       | 3        |        | Q4       |            | Registers                                                           |
|                     | Decode                | Read literal<br>'n'<br>PUSH PC to<br>stack                                                                                          | Proce<br>Dat                                                                                                                                                                                                                                                                                                                                             | ess<br>a | Wri    | te to PC |            | Flags*                                                              |
|                     | No                    | No                                                                                                                                  | No                                                                                                                                                                                                                                                                                                                                                       | )        |        | No       |            |                                                                     |

operation operation

Example: HERE RCALL Jump

operation

Before Instruction

operation

PC = Address (HERE) After Instruction PC = TOS = Address (Jump) Address (HERE + 2) affected by a MCLR Reset. All 0000 0000 1111 1111 This instruction provides a way to execute a MCLR Reset in software. 1 1 Q2 Q3 Q4 Start No No Reset operation operation

Reset

RESET

Reset all registers and flags that are

None

n

| Registers = | Reset Value |
|-------------|-------------|
| Flags* =    | Reset Value |

RESET

26.2

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

| PIC18LF2<br>(Indus | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |                                                                                                                                                                                         |     |       |            |            |                                  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|------------|------------|----------------------------------|--|--|
| PIC18F24<br>(Indus | <b>Standa</b><br>Operat                                                                                                            | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |     |       |            |            |                                  |  |  |
| Param<br>No.       | Device                                                                                                                             | Тур                                                                                                                                                                                     | Max | Units | Conditions |            |                                  |  |  |
|                    | Supply Current (IDD) <sup>(2)</sup>                                                                                                |                                                                                                                                                                                         |     |       |            |            |                                  |  |  |
|                    | All devices                                                                                                                        | 7.5                                                                                                                                                                                     | 10  | mA    | -40°C      |            |                                  |  |  |
|                    |                                                                                                                                    | 7.4                                                                                                                                                                                     | 10  | mA    | +25°C      |            | FOSC = 4 MHZ,<br>16 MHz internal |  |  |
|                    |                                                                                                                                    | 7.3                                                                                                                                                                                     | 10  | mA    | +85°C      | VDD - 4.2V | (PRI RUN HS+PLL)                 |  |  |
|                    | Extended devices only                                                                                                              | 8.0                                                                                                                                                                                     | 12  | mA    | +125°C     |            | (                                |  |  |
|                    | All devices                                                                                                                        | 10                                                                                                                                                                                      | 12  | mA    | -40°C      |            |                                  |  |  |
|                    |                                                                                                                                    | 10                                                                                                                                                                                      | 12  | mA    | +25°C      |            | FOSC = 4 MHZ,                    |  |  |
|                    |                                                                                                                                    | 9.7                                                                                                                                                                                     | 12  | mA    | +85°C      | VDD - 5.0V | (PRI RUN HS+PLL)                 |  |  |
|                    | Extended devices only                                                                                                              | 10                                                                                                                                                                                      | 14  | mA    | +125°C     |            | ()                               |  |  |
|                    | All devices                                                                                                                        | 15                                                                                                                                                                                      | 20  | mA    | -40°C      |            | Fosc = 10 MHz,                   |  |  |
|                    |                                                                                                                                    | 15                                                                                                                                                                                      | 20  | mA    | +25°C      | VDD = 4.2V | 40 MHz internal                  |  |  |
|                    |                                                                                                                                    | 15                                                                                                                                                                                      | 20  | mA    | +85°C      |            | (PRI_RUN HS+PLL)                 |  |  |
|                    | All devices                                                                                                                        | 20                                                                                                                                                                                      | 25  | mA    | -40°C      |            | Fosc = 10 MHz,                   |  |  |
|                    |                                                                                                                                    |                                                                                                                                                                                         | 25  | mA    | +25°C      | VDD = 5.0V | 40 MHz internal                  |  |  |
|                    |                                                                                                                                    | 20                                                                                                                                                                                      | 25  | mA    | +85°C      | ]          | (PRI_RUN HS+PLL)                 |  |  |

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.







© 2008 Microchip Technology Inc.

### W

| Watchdog Timer (WDT)       | 249 258            |
|----------------------------|--------------------|
| Associated Registers       |                    |
| Control Register           |                    |
| During Oscillator Failure  |                    |
| Programming Considerations |                    |
| WCOL                       | 189, 190, 191, 194 |
| WCOL Status Flag           | 189, 190, 191, 194 |
| WWW Address                |                    |
| WWW, On-Line Support       | 6                  |

### Х

| XORLW | . 307 |
|-------|-------|
| XORWF | . 308 |