



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 40MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, HLVD, POR, PWM, WDT                                |
| Number of I/O              | 36                                                                         |
| Program Memory Size        | 8KB (4K x 16)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 512 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                  |
| Data Converters            | A/D 13x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 44-VQFN Exposed Pad                                                        |
| Supplier Device Package    | 44-QFN (8x8)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf4321-i-ml |
|                            |                                                                            |

Email: info@E-XFL.COM

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

# 2.0 GUIDELINES FOR GETTING STARTED WITH PIC18F MICROCONTROLLERS

# 2.1 Basic Connection Requirements

Getting started with the PIC18F2221/2321/4221/4321 family family of 8-bit microcontrollers requires attention to a minimal set of device pin connections before proceeding with development.

The following pins must always be connected:

- All VDD and Vss pins (see Section 2.2 "Power Supply Pins")
- All AVDD and AVss pins, regardless of whether or not the analog device features are used (see Section 2.2 "Power Supply Pins")
- MCLR pin
   (see Section 2.3 "Master Clear (MCLR) Pin")

These pins must also be connected if they are being used in the end application:

- PGC/PGD pins used for In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) and debugging purposes (see Section 2.4 "ICSP Pins")
- OSCI and OSCO pins when an external oscillator source is used

(see Section 2.5 "External Oscillator Pins")

Additionally, the following pins may be required:

• VREF+/VREF- pins used when external voltage reference for analog modules is implemented

| Note: | The AVDD and AVSS pins must always be   |
|-------|-----------------------------------------|
|       | connected, regardless of whether any of |
|       | the analog modules are being used.      |

The minimum mandatory connections are shown in Figure 2-1.

## FIGURE 2-1: RECOMMENDED MINIMUM CONNECTIONS



# 3.4 RC Oscillator

For timing insensitive applications, the RC and RCIO Oscillator modes offer additional cost savings. The actual oscillator frequency is a function of several factors:

- supply voltage
- values of the external resistor (REXT) and capacitor (CEXT)
- · operating temperature

Given the same device, operating voltage, temperature and component values, there will also be unit-to-unit frequency variations. These are due to factors such as:

- normal manufacturing variation
- difference in lead frame capacitance between package types (especially for low CEXT values)
- variations within the tolerance of limits of  $\ensuremath{\mathsf{REXT}}$  and  $\ensuremath{\mathsf{CEXT}}$

In the RC Oscillator mode, the oscillator frequency divided by 4 is available on the OSC2 pin. This signal may be used for test purposes or to synchronize other logic. Figure 3-5 shows how the R/C combination is connected.





The RCIO Oscillator mode (Figure 3-6) functions like the RC mode, except that the OSC2 pin becomes an additional general purpose I/O pin. The I/O pin becomes bit 6 of PORTA (RA6).





# 3.5 PLL Frequency Multiplier

A Phase Locked Loop (PLL) circuit is provided as an option for users who wish to use a lower frequency oscillator circuit or to clock the device up to its highest rated frequency from a crystal oscillator. This may be useful for customers who are concerned with EMI due to high-frequency crystals or users who require higher clock speeds from an internal oscillator.

### 3.5.1 HSPLL OSCILLATOR MODE

The HSPLL mode makes use of the HS mode oscillator for frequencies up to 10 MHz. A PLL then multiplies the oscillator output frequency by 4 to produce an internal clock frequency up to 40 MHz. The PLLEN bit is not available when this mode is configured as the primary clock source.

The PLL is only available to the crystal oscillator when the FOSC<3:0> Configuration bits are programmed for HSPLL mode (= 0110).





## 3.5.2 PLL AND INTOSC

The PLL is also available to the internal oscillator block when the internal oscillator block is configured as the primary clock source. In this configuration, the PLL is enabled in software and generates a clock output of up to 32 MHz. The operation of INTOSC with the PLL is described in **Section 3.6.4 "PLL in INTOSC Modes"**.

# 6.4.3.1 FSR Registers and the INDF Operand

At the core of indirect addressing are three sets of registers: FSR0, FSR1 and FSR2. Each represents a pair of 8-bit registers, FSRnH and FSRnL. The four upper bits of the FSRnH register are not used so each FSR pair holds a 12-bit value. This represents a value that can address the entire range of the data memory in a linear fashion. The FSR register pairs, then, serve as pointers to data memory locations.

Indirect addressing is accomplished with a set of Indirect File Operands, INDF0 through INDF2. These can be thought of as "virtual" registers: they are mapped in the SFR space but are not physically implemented. Reading or writing to a particular INDF register actually accesses its corresponding FSR register pair. A read from INDF1, for example, reads the data at the address indicated by FSR1H:FSR1L. Instructions that use the INDF registers as operands actually use the contents of their corresponding FSR as a pointer to the instruction's target. The INDF operand is just a convenient way of using the pointer.

Because indirect addressing uses a full 12-bit address, data RAM banking is not necessary. Thus, the current contents of the BSR and the Access RAM bit have no effect on determining the target address.

### 6.4.3.2 FSR Registers and POSTINC, POSTDEC, PREINC and PLUSW

In addition to the INDF operand, each FSR register pair also has four additional indirect operands. Like INDF, these are "virtual" registers that cannot be indirectly read or written to. Accessing these registers actually accesses the associated FSR register pair, but also performs a specific action on its stored value. They are:

- POSTDEC: accesses the FSR value, then automatically decrements it by 1 afterwards
- POSTINC: accesses the FSR value, then automatically increments it by 1 afterwards
- PREINC: increments the FSR value by 1, then uses it in the operation
- PLUSW: adds the signed value of the W register (range of -127 to 128) to that of the FSR and uses the new value in the operation.

In this context, accessing an INDF register uses the value in the FSR registers without changing them. Similarly, accessing a PLUSW register gives the FSR value offset by that in the W register; neither value is actually changed in the operation. Accessing the other virtual registers changes the value of the FSR registers.

Operations on the FSRs with POSTDEC, POSTINC and PREINC affect the entire register pair; that is, rollovers of the FSRnL register from FFh to 00h carry over to the FSRnH register. On the other hand, results of these operations do not change the value of any flags in the STATUS register (e.g., Z, N, OV, etc.).



## FIGURE 6-7: INDIRECT ADDRESSING

# 7.0 FLASH PROGRAM MEMORY

The Flash program memory is readable, writable and erasable during normal operation over the entire VDD range.

A read from program memory is executed on one byte at a time. A write to program memory is executed on blocks of 8 bytes at a time. Program memory is erased in blocks of 64 bytes at a time. A bulk erase operation may not be issued from user code.

Writing or erasing program memory will cease instruction fetches until the operation is complete. The program memory cannot be accessed during the write or erase, therefore, code cannot execute. An internal programming timer terminates program memory writes and erases.

A value written to program memory does not need to be a valid instruction. Executing a program memory location that forms an invalid instruction results in a NOP.

## 7.1 Table Reads and Table Writes

In order to read and write program memory, there are two operations that allow the processor to move bytes between the program memory space and the data RAM:

- Table Read (TBLRD)
- Table Write (TBLWT)

The program memory space is 16 bits wide, while the data RAM space is 8 bits wide. Table reads and table writes move data between these two memory spaces through an 8-bit register (TABLAT).

Table read operations retrieve data from program memory and place it into the data RAM space. Figure 7-1 shows the operation of a table read with program memory and data RAM.

Table write operations store data from the data memory space into holding registers in program memory. The procedure to write the contents of the holding registers into program memory is detailed in **Section 7.5 "Writing to Flash Program Memory"**. Figure 7-2 shows the operation of a table write with program memory and data RAM.

Table operations work with byte entities. A table block containing data, rather than program instructions, is not required to be word-aligned. Therefore, a table block can start and end at any byte address. If a table write is being used to write executable code into program memory, program instructions will need to be word-aligned.

FIGURE 7-1: TABLE READ OPERATION



NOTES:

## 11.2 PORTB, TRISB and LATB Registers

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

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

| CLRF  | PORTB  | ; Initialize PORTB by     |
|-------|--------|---------------------------|
|       |        | ; clearing output         |
|       |        | ; data latches            |
| CLRF  | LATB   | ; Alternate method        |
|       |        | ; to clear output         |
|       |        | ; data latches            |
| MOVLW | OFh    | ; Set RB<4:0> as          |
| MOVWF | ADCON1 | ; digital I/O pins        |
|       |        | ; (required if config bit |
|       |        | ; PBADEN is set)          |
| MOVLW | OCFh   | ; Value used to           |
|       |        | ; initialize data         |
|       |        | ; direction               |
| MOVWF | TRISB  | ; Set RB<3:0> as inputs   |
|       |        | ; RB<5:4> as outputs      |
|       |        | ; RB<7:6> as inputs       |
|       |        |                           |

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn <u>on all</u> the pull-ups. This is performed by clearing bit, RBPU (INTCON2<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.

| Note: | On a Power-on Reset, RB<4:0> are<br>configured as analog inputs by default and<br>read as '0'; RB<7:5> are configured as<br>digital inputs. |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
|       | By clearing the Configuration bit,<br>PBADEN, RB<4:0> will alternatively be<br>configured as digital inputs on POR.                         |

Four of the PORTB pins (RB<7:4>) have an interrupton-change feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB<7:4> pin configured as an output is excluded from the interrupton-change comparison). The input pins (of RB<7:4>) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB<7:4> are ORed together to generate the RB Port Change Interrupt with Flag bit, RBIF (INTCON<0>).

This interrupt can wake the device from Sleep mode or any of the Idle modes. The user, in the Interrupt Service Routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB (except with the MOVFF (ANY), PORTB instruction).
- b) 1 Tcy.
- c) Clear flag bit, RBIF.

A mismatch condition will continue to set flag bit, RBIF. Reading PORTB and waiting 1 Tcy will end the mismatch condition and allow flag bit, RBIF, to be cleared. Also, if the port pin returns to its original state, the mismatch condition will be cleared.

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt-on-change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.

RB3 can be configured by the Configuration bit, CCP2MX, as the alternate peripheral pin for the CCP2 module (CCP2MX = 0).

NOTES:

# 13.0 TIMER1 MODULE

The Timer1 timer/counter module incorporates these features:

- Software selectable operation as a 16-bit timer or counter
- Readable and writable 8-bit registers (TMR1H and TMR1L)
- Selectable clock source (internal or external) with device clock or Timer1 oscillator internal options
- Interrupt-on-overflow
- Reset on CCP Special Event Trigger
- Device clock status flag (T1RUN)

A simplified block diagram of the Timer1 module is shown in Figure 13-1. A block diagram of the module's operation in Read/Write mode is shown in Figure 13-2.

The module incorporates its own low-power oscillator to provide an additional clocking option. The Timer1 oscillator can also be used as a low-power clock source for the microcontroller in power-managed operation.

Timer1 can also be used to provide Real-Time Clock (RTC) functionality to applications with only a minimal addition of external components and code overhead.

Timer1 is controlled through the T1CON Control register (Register 13-1). It also contains the Timer1 Oscillator Enable bit (T1OSCEN). Timer1 can be enabled or disabled by setting or clearing control bit, TMR1ON (T1CON<0>).

| STER 13-1: | T1CON: TIMER1 CONTROL REGISTER |                                                                                                                                                                  |                |                                |                 |                 |                |        |  |  |  |  |  |
|------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------|-----------------|-----------------|----------------|--------|--|--|--|--|--|
|            | R/W-0                          | R-0                                                                                                                                                              | R/W-0          | R/W-0                          | R/W-0           | R/W-0           | R/W-0          | R/W-0  |  |  |  |  |  |
|            | RD16                           | T1RUN                                                                                                                                                            | T1CKPS1        | T1CKPS0                        | T1OSCEN         | T1SYNC          | TMR1CS         | TMR10N |  |  |  |  |  |
|            | bit 7                          |                                                                                                                                                                  |                |                                |                 |                 |                | bit 0  |  |  |  |  |  |
| bit 7      | <b>RD16:</b> 16                | -Bit Read/V                                                                                                                                                      | Vrite Mode E   | nable bit                      |                 |                 |                |        |  |  |  |  |  |
|            |                                | <ul> <li>1 = Enables register read/write of TImer1 in one 16-bit operation</li> <li>0 = Enables register read/write of Timer1 in two 8-bit operations</li> </ul> |                |                                |                 |                 |                |        |  |  |  |  |  |
| bit 6      | T1RUN: T                       | imer1 Syst                                                                                                                                                       | em Clock Sta   | atus bit                       |                 |                 |                |        |  |  |  |  |  |
|            |                                |                                                                                                                                                                  |                | Timer1 oscilla<br>another sour |                 |                 |                |        |  |  |  |  |  |
| bit 5-4    | T1CKPS<                        | : <b>1:0&gt;:</b> Time                                                                                                                                           | er1 Input Cloc | k Prescale S                   | elect bits      |                 |                |        |  |  |  |  |  |
|            |                                | Prescale va                                                                                                                                                      |                |                                |                 |                 |                |        |  |  |  |  |  |
|            |                                | Prescale va<br>Prescale va                                                                                                                                       |                |                                |                 |                 |                |        |  |  |  |  |  |
|            |                                | Prescale va                                                                                                                                                      |                |                                |                 |                 |                |        |  |  |  |  |  |
| bit 3      | T1OSCE                         | <b>1:</b> Timer1 C                                                                                                                                               | Scillator Ena  | ble bit                        |                 |                 |                |        |  |  |  |  |  |
|            | -                              | 1 oscillator                                                                                                                                                     |                |                                |                 |                 |                |        |  |  |  |  |  |
|            | • • • • • • •                  | 1 oscillator                                                                                                                                                     |                | ck resistor ar                 | e turned off to | o eliminate     | nower drain    |        |  |  |  |  |  |
| bit 2      |                                |                                                                                                                                                                  |                |                                | onization Sele  |                 |                |        |  |  |  |  |  |
|            |                                | R1CS = 1:                                                                                                                                                        |                |                                |                 |                 |                |        |  |  |  |  |  |
|            |                                | •                                                                                                                                                                | ze external c  | •                              |                 |                 |                |        |  |  |  |  |  |
|            | •                              |                                                                                                                                                                  | ernal clock in | put                            |                 |                 |                |        |  |  |  |  |  |
|            |                                | <u>R1CS = 0:</u><br>ianored Ti                                                                                                                                   | mer1 uses th   | e internal clo                 | ck when TMF     | <b>R1CS =</b> 0 |                |        |  |  |  |  |  |
| bit 1      |                                | 0                                                                                                                                                                | ock Source S   |                                |                 |                 |                |        |  |  |  |  |  |
|            |                                |                                                                                                                                                                  |                |                                | KI (on the ris  | sing edge)      |                |        |  |  |  |  |  |
|            |                                | nal clock (F                                                                                                                                                     |                |                                |                 |                 |                |        |  |  |  |  |  |
| bit 0      | TMR1ON: Timer1 On bit          |                                                                                                                                                                  |                |                                |                 |                 |                |        |  |  |  |  |  |
|            | 1 = Enab<br>0 = Stops          | les Timer1<br>Timer1                                                                                                                                             |                |                                |                 |                 |                |        |  |  |  |  |  |
|            | Legend:                        |                                                                                                                                                                  |                |                                |                 |                 |                |        |  |  |  |  |  |
|            | R = Read                       | able bit                                                                                                                                                         | VV = V         | Vritable bit                   | U = Unim        | plemented b     | oit, read as ' | 0'     |  |  |  |  |  |
|            | -n = Value                     | e at POR                                                                                                                                                         | '1' = E        | Bit is set                     | '0' = Bit is    | cleared         | x = Bit is u   | nknown |  |  |  |  |  |
|            |                                |                                                                                                                                                                  |                |                                |                 |                 |                |        |  |  |  |  |  |

## REGISTER 13-1: T1CON: TIMER1 CONTROL REGISTER

# 18.4 I<sup>2</sup>C Mode

The MSSP module in  $I^2C$  mode fully implements all master and slave functions (including general call support) and provides interrupts on Start and Stop bits in hardware to determine a free bus (multi-master function). The MSSP module implements the standard mode specifications, as well as 7-bit and 10-bit addressing.

Two pins are used for data transfer:

- Serial clock (SCL) RC3/SCK/SCL
- Serial data (SDA) RC4/SDI/SDA

The user must configure these pins as inputs or outputs through the TRISC<4:3> bits.

#### FIGURE 18-7: MSSP BLOCK DIAGRAM (I<sup>2</sup>C™ MODE)



# 18.4.1 REGISTERS

The MSSP module has six registers for  $\mathsf{I}^2\mathsf{C}$  operation. These are:

- MSSP Control Register 1 (SSPCON1)
- MSSP Control Register 2 (SSPCON2)
- MSSP Status Register (SSPSTAT)
- Serial Receive/Transmit Buffer Register (SSPBUF)
- MSSP Shift Register (SSPSR) Not directly accessible
- MSSP Address Register (SSPADD)

SSPCON1, SSPCON2 and SSPSTAT are the control and status registers in  $I^2C$  mode operation. The SSPCON1 and SSPCON2 registers are readable and writable. The lower 6 bits of the SSPSTAT are read-only. The upper two bits of the SSPSTAT are read/write.

SSPSR is the shift register used for shifting data in or out. SSPBUF is the buffer register to which data bytes are written to or read from.

SSPADD register holds the slave device address when the MSSP is configured in I<sup>2</sup>C Slave mode. When the MSSP is configured in Master mode, the lower seven bits of SSPADD act as the Baud Rate Generator reload value.

In receive operations, SSPSR and SSPBUF together create a double-buffered receiver. When SSPSR receives a complete byte, it is transferred to SSPBUF and the SSPIF interrupt is set.

During transmission, the SSPBUF is not doublebuffered. A write to SSPBUF will write to both SSPBUF and SSPSR.

### **REGISTER 18-4:** SSPCON1: MSSP CONTROL REGISTER 1 ( $I^2C^{TM}$ MODE)

| R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| WCOL  | SSPOV | SSPEN | CKP   | SSPM3 | SSPM2 | SSPM1 | SSPM0 |
| bit 7 |       |       |       |       |       |       | bit 0 |

#### bit 7 WCOL: Write Collision Detect bit

In Master Transmit mode:

- 1 = A write to the SSPBUF register was attempted while the I<sup>2</sup>C<sup>™</sup> conditions were not valid for a transmission to be started (must be cleared in software)
- 0 = No collision

In Slave Transmit mode:

- 1 = The SSPBUF register is written while it is still transmitting the previous word (must be cleared in software)
- 0 = No collision

In Receive mode (Master or Slave modes):

This is a "don't care" bit.

#### bit 6 SSPOV: Receive Overflow Indicator bit

#### In Receive mode:

- 1 = A byte is received while the SSPBUF register is still holding the previous byte (must be cleared in software)
- 0 = No overflow

#### In Transmit mode:

This is a "don't care" bit in Transmit mode.

#### bit 5 SSPEN: Master Synchronous Serial Port Enable bit

- 1 = Enables the serial port and configures the SDA and SCL pins as the serial port pins
- 0 = Disables serial port and configures these pins as I/O port pins

Note: When enabled, the SDA and SCL pins must be properly configured as inputs.

bit 4 **CKP:** SCK Release Control bit

In Slave mode:

- 1 = Release clock
- 0 = Holds clock low (clock stretch), used to ensure data setup time

In Master mode:

Unused in this mode.

#### bit 3-0 SSPM<3:0>: Master Synchronous Serial Port Mode Select bits

1111 =  $I^2C$  Slave mode, 10-bit address with Start and Stop bit interrupts enabled

- $1110 = I^2C$  Slave mode, 7-bit address with Start and Stop bit interrupts enabled
- $1011 = I^2C$  Firmware Controlled Master mode (slave Idle)
- $1000 = I^2C$  Master mode, clock = Fosc/(4 \* (SSPADD + 1))
- 0111 =  $I^2C$  Slave mode, 10-bit address
- 0110 =  $I^2C$  Slave mode, 7-bit address

Bit combinations not specifically listed here are either reserved or implemented in SPI mode only.

# Legend:

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

# 18.4.10 I<sup>2</sup>C MASTER MODE TRANSMISSION

Transmission of a data byte, a 7-bit address or the other half of a 10-bit address is accomplished by simply writing a value to the SSPBUF register. This action will set the Buffer Full flag bit, BF and allow the Baud Rate Generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDA pin after the falling edge of SCL is asserted (see data hold time specification parameter 106). SCL is held low for one Baud Rate Generator rollover count (TBRG). Data should be valid before SCL is released high (see data setup time specification parameter 107). When the SCL pin is released high, it is held that way for TBRG. The data on the SDA pin must remain stable for that duration and some hold time after the next falling edge of SCL. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the master releases SDA. This allows the slave device being addressed to respond with an  $\overline{ACK}$  bit during the ninth bit time if an address match occurred, or if data was received properly. The status of ACK is written into the ACKDT bit on the falling edge of the ninth clock. If the master receives an Acknowledge, the Acknowledge Status bit, ACKSTAT, is cleared. If not, the bit is set. After the ninth clock, the SSPIF bit is set and the master clock (Baud Rate Generator) is suspended until the next data byte is loaded into the SSPBUF, leaving SCL low and SDA unchanged (Figure 18-23).

After the write to the SSPBUF, each bit of the address will be shifted out on the falling edge of SCL until all seven address bits and the R/W bit are completed. On the falling edge of the eighth clock, the master will deassert the SDA pin, allowing the slave to respond with an Acknowledge. On the falling edge of the ninth clock, the master will sample the SDA pin to see if the address was recognized by a slave. The status of the ACK bit is loaded into the ACKSTAT status bit (SSPCON2<6>). Following the falling edge of the ninth clock transmission of the address, the SSPIF is set, the BF flag is cleared and the Baud Rate Generator is turned off until another write to the SSPBUF takes place, holding SCL low and allowing SDA to float.

### 18.4.10.1 BF Status Flag

In Transmit mode, the BF bit (SSPSTAT<0>) is set when the CPU writes to SSPBUF and is cleared when all 8 bits are shifted out.

### 18.4.10.2 WCOL Status Flag

If the user writes the SSPBUF when a transmit is already in progress (i.e., SSPSR is still shifting out a data byte), the WCOL flag is set and the contents of the buffer are unchanged (the write doesn't occur) after 2 TcY after the SSPBUF write. If SSPBUF is rewritten within 2 TcY, the WCOL bit is set and SSPBUF is updated. This may result in a corrupted transfer. The user should verify that the WCOL flag is clear after each write to SSPBUF to ensure the transfer is correct.

### 18.4.10.3 ACKSTAT Status Flag

In Transmit mode, the ACKSTAT bit (SSPCON2<6>) is cleared when the slave has sent an Acknowledge  $(\overline{ACK} = 0)$  and is set when the slave does not Acknowledge  $(\overline{ACK} = 1)$ . A slave sends an Acknowledge when it has recognized its address (including a general call), or when the slave has properly received its data.

## 18.4.11 I<sup>2</sup>C MASTER MODE RECEPTION

Master mode reception is enabled by programming the Receive Enable bit, RCEN (SSPCON2<3>).

Note: The MSSP module must be in an Idle state before the RCEN bit is set or the RCEN bit will be disregarded.

The Baud Rate Generator begins counting and on each rollover, the state of the SCL pin changes (high-to-low/ low-to-high) and data is shifted into the SSPSR. After the falling edge of the eighth clock, the receive enable flag is automatically cleared, the contents of the SSPSR are loaded into the SSPBUF, the BF flag bit is set, the SSPIF flag bit is set and the Baud Rate Generator is suspended from counting, holding SCL low. The MSSP is now in Idle state awaiting the next command. When the buffer is read by the CPU, the BF flag bit is automatically cleared. The user can then send an Acknowledge bit at the end of reception by setting the Acknowledge Sequence Enable bit, ACKEN (SSPCON2<4>).

#### 18.4.11.1 BF Status Flag

In receive operation, the BF bit is set when an address or data byte is loaded into SSPBUF from SSPSR. It is cleared when the SSPBUF register is read.

#### 18.4.11.2 SSPOV Status Flag

In receive operation, the SSPOV bit is set when 8 bits are received into the SSPSR and the BF flag bit is already set from a previous reception.

#### 18.4.11.3 WCOL Status Flag

If the user writes the SSPBUF when a receive is already in progress (i.e., SSPSR is still shifting in a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write doesn't occur).

<sup>© 2009</sup> Microchip Technology Inc.

|             |                       |            |                             |                       | SYNC       | = 0, BRGH                   | I = 0, BRG            | <b>316 =</b> 0 |                             |                       |            |                             |
|-------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|----------------|-----------------------------|-----------------------|------------|-----------------------------|
| BAUD        | Fosc = 40.000 MHz     |            |                             | Fosc = 20.000 MHz     |            |                             | Fosc = 10.000 MHz     |                |                             | Fosc = 8.000 MHz      |            |                             |
| RATE<br>(K) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error     | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |
| 0.3         | _                     |            |                             |                       |            |                             | _                     |                | _                           |                       |            |                             |
| 1.2         | —                     | —          | —                           | 1.221                 | 1.73       | 255                         | 1.202                 | 0.16           | 129                         | 1.201                 | -0.16      | 103                         |
| 2.4         | 2.441                 | 1.73       | 255                         | 2.404                 | 0.16       | 129                         | 2.404                 | 0.16           | 64                          | 2.403                 | -0.16      | 51                          |
| 9.6         | 9.615                 | 0.16       | 64                          | 9.766                 | 1.73       | 31                          | 9.766                 | 1.73           | 15                          | 9.615                 | -0.16      | 12                          |
| 19.2        | 19.531                | 1.73       | 31                          | 19.531                | 1.73       | 15                          | 19.531                | 1.73           | 7                           | _                     | _          | _                           |
| 57.6        | 56.818                | -1.36      | 10                          | 62.500                | 8.51       | 4                           | 52.083                | -9.58          | 2                           | _                     | _          | _                           |
| 115.2       | 125.000               | 8.51       | 4                           | 104.167               | -9.58      | 2                           | 78.125                | -32.18         | 1                           | _                     | _          | _                           |

#### TABLE 19-3: BAUD RATES FOR ASYNCHRONOUS MODES

|              |                       | SYNC = 0, BRGH = 0, BRG16 = 0 |                             |                       |            |                             |                       |            |                             |  |  |  |  |  |
|--------------|-----------------------|-------------------------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|--|--|--|--|--|
| BAUD<br>RATE | Fos                   | c = 4.000                     | MHz                         | Fos                   | c = 2.000  | MHz                         | Fosc = 1.000 MHz      |            |                             |  |  |  |  |  |
| (K)          | Actual<br>Rate<br>(K) | %<br>Error                    | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |  |  |  |  |  |
| 0.3          | 0.300                 | 0.16                          | 207                         | 0.300                 | -0.16      | 103                         | 0.300                 | -0.16      | 51                          |  |  |  |  |  |
| 1.2          | 1.202                 | 0.16                          | 51                          | 1.201                 | -0.16      | 25                          | 1.201                 | -0.16      | 12                          |  |  |  |  |  |
| 2.4          | 2.404                 | 0.16                          | 25                          | 2.403                 | -0.16      | 12                          | _                     | _          | _                           |  |  |  |  |  |
| 9.6          | 8.929                 | -6.99                         | 6                           | —                     | _          | _                           | _                     | _          | _                           |  |  |  |  |  |
| 19.2         | 20.833                | 8.51                          | 2                           | —                     | _          | _                           | _                     | _          | _                           |  |  |  |  |  |
| 57.6         | 62.500                | 8.51                          | 0                           | —                     | _          | _                           | —                     | _          | _                           |  |  |  |  |  |
| 115.2        | 62.500                | -45.75                        | 0                           | _                     | —          | —                           | _                     | _          |                             |  |  |  |  |  |

|             | SYNC = 0, BRGH = 1, BRG16 = 0 |                                                                           |     |                       |            |                             |                       |            |                             |                  |       |     |  |
|-------------|-------------------------------|---------------------------------------------------------------------------|-----|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|------------------|-------|-----|--|
| BAUD        | Fosc = 40.000 MHz             |                                                                           |     | Fosc = 20.000 MHz     |            |                             | Fosc = 10.000 MHz     |            |                             | Fosc = 8.000 MHz |       |     |  |
| RATE<br>(K) | Actual<br>Rate<br>(K)         | SPBRG Actual SPBRG<br>value Rate % value<br>(decimal) (K) Error (decimal) |     | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |                  |       |     |  |
| 0.3         | _                             |                                                                           | _   | —                     | _          | _                           |                       |            | _                           |                  | _     | _   |  |
| 1.2         | —                             | _                                                                         | _   | —                     | _          | _                           | —                     | _          | _                           | —                | _     | —   |  |
| 2.4         | —                             | _                                                                         | _   | —                     | _          | _                           | 2.441                 | 1.73       | 255                         | 2.403            | -0.16 | 207 |  |
| 9.6         | 9.766                         | 1.73                                                                      | 255 | 9.615                 | 0.16       | 129                         | 9.615                 | 0.16       | 64                          | 9.615            | -0.16 | 51  |  |
| 19.2        | 19.231                        | 0.16                                                                      | 129 | 19.231                | 0.16       | 64                          | 19.531                | 1.73       | 31                          | 19.230           | -0.16 | 25  |  |
| 57.6        | 58.140                        | 0.94                                                                      | 42  | 56.818                | -1.36      | 21                          | 56.818                | -1.36      | 10                          | 55.555           | 3.55  | 8   |  |
| 115.2       | 113.636                       | -1.36                                                                     | 21  | 113.636               | -1.36      | 10                          | 125.000               | 8.51       | 4                           | —                | _     | _   |  |

|              |                       | SYNC = 0, BRGH = 1, BRG16 = 0 |                             |                       |            |                             |                       |            |                             |  |  |  |  |
|--------------|-----------------------|-------------------------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|--|--|--|--|
| BAUD<br>RATE | Foso                  | = 4.000                       | MHz                         | Fos                   | c = 2.000  | MHz                         | Fosc = 1.000 MHz      |            |                             |  |  |  |  |
| (K)          | Actual<br>Rate<br>(K) | %<br>Error                    | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |  |  |  |  |
| 0.3          | _                     |                               | _                           |                       |            | _                           | 0.300                 | -0.16      | 207                         |  |  |  |  |
| 1.2          | 1.202                 | 0.16                          | 207                         | 1.201                 | -0.16      | 103                         | 1.201                 | -0.16      | 51                          |  |  |  |  |
| 2.4          | 2.404                 | 0.16                          | 103                         | 2.403                 | -0.16      | 51                          | 2.403                 | -0.16      | 25                          |  |  |  |  |
| 9.6          | 9.615                 | 0.16                          | 25                          | 9.615                 | -0.16      | 12                          | _                     | _          | _                           |  |  |  |  |
| 19.2         | 19.231                | 0.16                          | 12                          | _                     | _          | _                           | _                     | _          | _                           |  |  |  |  |
| 57.6         | 62.500                | 8.51                          | 3                           | —                     | _          | _                           | —                     | _          | _                           |  |  |  |  |
| 115.2        | 125.000               | 8.51                          | 1                           |                       | _          | —                           | _                     | _          | _                           |  |  |  |  |

© 2009 Microchip Technology Inc.

| RLN         | ICF                                              | Rotate Le                                                                                                                                                                                     | eft f (No Car                                                                                                                                                                              | ry)                                                                                                                                                                                  |
|-------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synt        | ax:                                              | RLNCF                                                                                                                                                                                         | f {,d {,a}}                                                                                                                                                                                |                                                                                                                                                                                      |
| Oper        | rands:                                           | $0 \le f \le 255$<br>$d \in [0, 1]$<br>$a \in [0, 1]$                                                                                                                                         |                                                                                                                                                                                            |                                                                                                                                                                                      |
| Oper        | ration:                                          | $(f \le n >) \rightarrow de$<br>$(f \le 7 >) \rightarrow de$                                                                                                                                  | est <n +="" 1="">,<br/>est&lt;0&gt;</n>                                                                                                                                                    |                                                                                                                                                                                      |
| Statu       | is Affected:                                     | N, Z                                                                                                                                                                                          |                                                                                                                                                                                            |                                                                                                                                                                                      |
| Enco        | oding:                                           | 0100                                                                                                                                                                                          | 01da ff                                                                                                                                                                                    | ff ffff                                                                                                                                                                              |
|             | pription:                                        | one bit to th<br>is placed in<br>stored back<br>If 'a' is '0', th<br>If 'a' is '1', th<br>GPR bank<br>If 'a' is '0' a<br>set is enabl<br>in Indexed<br>mode wher<br>Section 25<br>Bit-Oriente | W. If 'd' is '1'<br>is in register 'f'<br>he Access Ba<br>he BSR is use<br>(default).<br>Ind the extend<br>ed, this instru<br>Literal Offset<br>hever $f \le 95$ (5<br><b>.2.3 "Byte-O</b> | '0', the result is<br>(default).<br>nk is selected.<br>d to select the<br>led instruction<br>ction operates<br>Addressing<br>JFh). See<br>riented and<br>ns in Indexed<br>d details. |
| Word        | ds:                                              | 1                                                                                                                                                                                             |                                                                                                                                                                                            |                                                                                                                                                                                      |
| Cycle       | es:                                              | 1                                                                                                                                                                                             |                                                                                                                                                                                            |                                                                                                                                                                                      |
| QC          | ycle Activity:                                   |                                                                                                                                                                                               |                                                                                                                                                                                            |                                                                                                                                                                                      |
|             | Q1                                               | Q2                                                                                                                                                                                            | Q3                                                                                                                                                                                         | Q4                                                                                                                                                                                   |
|             | Decode                                           | Read<br>register 'f'                                                                                                                                                                          | Process<br>Data                                                                                                                                                                            | Write to destination                                                                                                                                                                 |
| <u>Exar</u> | nple:                                            | RLNCF                                                                                                                                                                                         | REG, 1,                                                                                                                                                                                    | 0                                                                                                                                                                                    |
|             | Before Instruc<br>REG<br>After Instructio<br>REG | = 1010 1                                                                                                                                                                                      | 011                                                                                                                                                                                        |                                                                                                                                                                                      |
|             | REG                                              | - 0101 0                                                                                                                                                                                      | 111                                                                                                                                                                                        |                                                                                                                                                                                      |

| RRC   | F                 | R                                                             | otate R                                                                                                                                                                                       | ight f th                                                                                                                                                                           | nroug                                                                                                                          | h Carry                                                                                                                                                                                    |
|-------|-------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synta | ax:               | R                                                             | RCF f                                                                                                                                                                                         | {,d {,a}}                                                                                                                                                                           |                                                                                                                                |                                                                                                                                                                                            |
| Oper  | ands:             | 0                                                             | ≤ f ≤ 255                                                                                                                                                                                     | 5                                                                                                                                                                                   |                                                                                                                                |                                                                                                                                                                                            |
|       |                   |                                                               | ∈ [0,1]                                                                                                                                                                                       |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
|       |                   | а                                                             | ∈[0,1]                                                                                                                                                                                        |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
| Oper  | ation:            | (f                                                            | $<$ n>) $\rightarrow$ (<br>$<$ 0>) $\rightarrow$ (<br>C) $\rightarrow$ des                                                                                                                    |                                                                                                                                                                                     | 1>,                                                                                                                            |                                                                                                                                                                                            |
| Statu | s Affected:       | С                                                             | , N, Z                                                                                                                                                                                        |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
| Enco  | dina:             | Г                                                             | 0011                                                                                                                                                                                          | 00da                                                                                                                                                                                | fft                                                                                                                            | f ffff                                                                                                                                                                                     |
|       | ription:          |                                                               |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                | ' are rotated                                                                                                                                                                              |
|       |                   | or<br>fla<br>If<br>If<br>If<br>G<br>If<br>So<br>If<br>So<br>B | he bit to f<br>ag. If 'd' is<br>'d' is '1',<br>agister 'f'<br>'a' is '0',<br>'a' is '0',<br>'a' is '1',<br>PR bank<br>'a' is '0'<br>et is enal<br>Indexed<br>ode whe<br>ection 2<br>it-Orient | the right<br>s '0', the<br>the resu<br>(default)<br>the Acce<br>the BSR<br>c (default)<br>and the e<br>oled, this<br>L Literal C<br>never f ≤<br>5.2.3 "B<br>ted Instri<br>fset Mod | through<br>result is<br>lt is pla<br>ess Bar<br>is use<br>).<br>extende<br>instruc<br>Offset A<br>595 (5F<br>yte-Ori<br>uction | n the Carry<br>s placed in W.<br>iced back in<br>hk is selected.<br>d to select the<br>ed instruction<br>ction operates<br>iddressing<br>Th). See<br>ented and<br>s in Indexed<br>details. |
| Word  | ls:               | 1                                                             |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
| Cycle | es:               | 1                                                             |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
| QC    | ycle Activity:    |                                                               |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
|       | Q1                |                                                               | Q2                                                                                                                                                                                            | Q                                                                                                                                                                                   | 3                                                                                                                              | Q4                                                                                                                                                                                         |
|       | Decode            |                                                               | Read<br>gister 'f'                                                                                                                                                                            | Proc<br>Da                                                                                                                                                                          |                                                                                                                                | Write to destination                                                                                                                                                                       |
|       |                   |                                                               | 0                                                                                                                                                                                             |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
| Exan  | nple:             | R                                                             | RCF                                                                                                                                                                                           | REG,                                                                                                                                                                                | 0, (                                                                                                                           | )                                                                                                                                                                                          |
|       | Before Instruc    | tion                                                          |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
|       | REG<br>C          | =<br>=                                                        | 1110<br><b>0</b>                                                                                                                                                                              | 0110                                                                                                                                                                                |                                                                                                                                |                                                                                                                                                                                            |
|       | After Instruction | n                                                             |                                                                                                                                                                                               |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |
|       | REG               | =                                                             | 1110                                                                                                                                                                                          | 0110                                                                                                                                                                                |                                                                                                                                |                                                                                                                                                                                            |
|       | W                 | =                                                             | 0111                                                                                                                                                                                          | 0011                                                                                                                                                                                |                                                                                                                                |                                                                                                                                                                                            |
|       | С                 | =                                                             | 0                                                                                                                                                                                             |                                                                                                                                                                                     |                                                                                                                                |                                                                                                                                                                                            |

| SUBLW                                                        | 5           | Subtract                     | W from                   | n Lite  | ral |           |  |  |
|--------------------------------------------------------------|-------------|------------------------------|--------------------------|---------|-----|-----------|--|--|
| Syntax:                                                      | 9           | SUBLW k                      |                          |         |     |           |  |  |
| Operands:                                                    | C           | $0 \le k \le 255$            |                          |         |     |           |  |  |
| Operation:                                                   | k           | $i - (W) \rightarrow$        | W                        |         |     |           |  |  |
| Status Affected:                                             | ١           | I, OV, C,                    | DC, Z                    |         |     |           |  |  |
| Encoding:                                                    | Γ           | 0000                         | 1000                     | kkk     | k   | kkkk      |  |  |
| Description                                                  |             |                              | acted from               |         |     |           |  |  |
| Words:                                                       | 1           |                              |                          |         |     |           |  |  |
| Cycles:                                                      | 1           |                              |                          |         |     |           |  |  |
| Q Cycle Activity:                                            |             |                              |                          |         |     |           |  |  |
| Q1                                                           |             | Q2                           | Q3                       |         |     | Q4        |  |  |
| Decode                                                       |             | Read<br>eral 'k'             | Proce<br>Data            |         | W   | rite to W |  |  |
| Example 1:                                                   | S           | UBLW (                       | )2h                      |         |     |           |  |  |
| Before Instru<br>W<br>C<br>After Instruc<br>W<br>C<br>Z<br>N | =           | 01h<br>?<br>01h<br>1 ;r<br>0 | esult is p               | ositive | 9   |           |  |  |
| Example 2:                                                   | S           | UBLW (                       | )2h                      |         |     |           |  |  |
| Before Instru<br>W<br>C<br>After Instruc<br>W                | =           | 02h<br>?<br>00h              |                          |         |     |           |  |  |
| C<br>Z<br>N                                                  | =<br>=<br>= | 1;r<br>1<br>0                | esult is z               | ero     |     |           |  |  |
| Example 3:                                                   | S           | SUBLW (                      | )2h                      |         |     |           |  |  |
| Before Instru<br>W<br>C<br>After Instruc<br>W<br>C<br>Z<br>N | =           |                              | (2's comp<br>result is r |         |     |           |  |  |

| SUBWF                                                                                                                                                                                                                                                                                                                                                      |                            | 5                     | Subtra                            | ct   | W from f                                                                                                                                                       |                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------|-----------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| Syntax:                                                                                                                                                                                                                                                                                                                                                    |                            | S                     | SUBWF                             |      | f {,d {,a}}                                                                                                                                                    |                      |
| Operands:                                                                                                                                                                                                                                                                                                                                                  |                            | d                     | ) ≤ f ≤ 2<br>l ∈ [0,1<br>l ∈ [0,1 | L]   |                                                                                                                                                                |                      |
| Operation:                                                                                                                                                                                                                                                                                                                                                 |                            | (1                    | f) – (W)                          | -    | → dest                                                                                                                                                         |                      |
| Status Affe                                                                                                                                                                                                                                                                                                                                                | cted:                      | Ν                     | 1, OV, C                          | C, I | DC, Z                                                                                                                                                          |                      |
| Encoding:                                                                                                                                                                                                                                                                                                                                                  |                            |                       | 0101                              |      | 11da fff                                                                                                                                                       | f ffff               |
| Description:Subtract W from register 'f' (2's<br>complement method). If 'd' is '0', the<br>result is stored in W. If 'd' is '1', the<br>result is stored back in register 'f'<br>(default).If 'a' is '0', the Access Bank is<br>selected. If 'a' is '1', the BSR is use<br>to select the GPR bank (default).If 'a' is '0' and the extended instruction<br> |                            |                       |                                   |      | d' is '0', the<br>' is '1', the<br>egister 'f'<br>ank is<br>3SR is used<br>default).<br>ed instruction<br>iction<br>ral Offset<br>ever<br>1 25.2.3<br>Oriented |                      |
| Words:                                                                                                                                                                                                                                                                                                                                                     |                            | 1                     |                                   |      |                                                                                                                                                                |                      |
| Cycles:                                                                                                                                                                                                                                                                                                                                                    |                            | 1                     |                                   |      |                                                                                                                                                                |                      |
| Q Cycle A                                                                                                                                                                                                                                                                                                                                                  | ctivity:                   |                       |                                   |      |                                                                                                                                                                |                      |
|                                                                                                                                                                                                                                                                                                                                                            | Q1                         |                       | Q2                                |      | Q3                                                                                                                                                             | Q4                   |
| De                                                                                                                                                                                                                                                                                                                                                         | code                       |                       | Read<br>gister 'f'                | 1    | Process<br>Data                                                                                                                                                | Write to destination |
| Example 1                                                                                                                                                                                                                                                                                                                                                  | <u>:</u>                   | S                     | UBWF                              |      | REG, 1, 0                                                                                                                                                      |                      |
| F                                                                                                                                                                                                                                                                                                                                                          | e Instruc<br>REG<br>V<br>C | tion<br>=<br>=<br>=   | 3<br>2<br>?                       |      |                                                                                                                                                                |                      |
| F                                                                                                                                                                                                                                                                                                                                                          | 2                          | n<br>=<br>=<br>=<br>= | 1<br>2<br>1<br>0                  | ;।   | result is positiv                                                                                                                                              | /e                   |
| Example 2                                                                                                                                                                                                                                                                                                                                                  | <u>.</u>                   | S                     | SUBWF                             |      | REG, 0, 0                                                                                                                                                      |                      |
| F<br>V<br>C                                                                                                                                                                                                                                                                                                                                                | e Instruc<br>REG<br>V<br>C | =<br>=<br>=           | 2<br>2<br>?                       |      |                                                                                                                                                                |                      |
| F                                                                                                                                                                                                                                                                                                                                                          | REG<br>W<br>Z              | "<br>=<br>=<br>=<br>= | 2<br>0<br>1<br>1<br>0             | ;।   | result is zero                                                                                                                                                 |                      |
| Example 3                                                                                                                                                                                                                                                                                                                                                  | •                          | S                     | SUBWF                             |      | REG, 1, 0                                                                                                                                                      |                      |
| F                                                                                                                                                                                                                                                                                                                                                          | e Instruc<br>REG<br>V<br>C | tion<br>=<br>=<br>=   | 1<br>2<br>?                       |      |                                                                                                                                                                |                      |
| F                                                                                                                                                                                                                                                                                                                                                          | 2                          | n<br>=<br>=<br>=<br>= | FFh<br>2<br>0<br>0<br>1           |      | 2's complemer<br>result is negati                                                                                                                              |                      |
| ľ                                                                                                                                                                                                                                                                                                                                                          | •                          | -                     | 1                                 |      |                                                                                                                                                                |                      |

| CALLW                                        | Subroutir                                                                     | ne Call Using                                                                                                          | J VV                                |                                |  |  |
|----------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------|--|--|
| Syntax:                                      | CALLW                                                                         |                                                                                                                        |                                     |                                |  |  |
| Operands:                                    | None                                                                          |                                                                                                                        |                                     |                                |  |  |
| Operation:                                   | $(W) \rightarrow PCL$<br>(PCLATH) -                                           | $(PC + 2) \rightarrow TOS,$<br>$(W) \rightarrow PCL,$<br>$(PCLATH) \rightarrow PCH,$<br>$(PCLATU) \rightarrow PCU$     |                                     |                                |  |  |
| Status Affected:                             | None                                                                          |                                                                                                                        |                                     |                                |  |  |
| Encoding:                                    | 0000                                                                          | 0000 000                                                                                                               | )1                                  | 0100                           |  |  |
|                                              | contents of<br>existing values<br>contents of<br>latched into<br>respectively | o the return sta<br>W are written<br>ue is discarded<br>PCLATH and<br>PCH and PCU<br>/. The second<br>s a NOP instruct | to P<br>d. Th<br>PCL<br>U,<br>cycle | CL; the<br>nen, the<br>ATU are |  |  |
|                                              | Unlike CALI                                                                   | L, there is no c                                                                                                       | optio                               |                                |  |  |
| Words:                                       | Unlike CALI                                                                   | L, there is no c                                                                                                       | optio                               |                                |  |  |
| Words:<br>Cycles:                            | Unlike CALL<br>update W, S                                                    | L, there is no c                                                                                                       | optio                               |                                |  |  |
| Cycles:                                      | Unlike CALL<br>update W, S<br>1                                               | L, there is no c                                                                                                       | optio                               |                                |  |  |
|                                              | Unlike CALL<br>update W, S<br>1                                               | L, there is no c                                                                                                       | optio                               |                                |  |  |
| Cycles:<br>Q Cycle Activity:                 | Unlike CALL<br>update W, S<br>1<br>2<br>Q2<br>Read                            | L, there is no c<br>STATUS or BS<br>Q3<br>PUSH PC to                                                                   | R.                                  | Q4<br>No                       |  |  |
| Cycles:<br>Q Cycle Activity:<br>Q1<br>Decode | Unlike CALI<br>update W, S<br>1<br>2<br>Q2<br>Read<br>WREG                    | Q3<br>PUSH PC to<br>stack                                                                                              | R.                                  | Q4<br>No<br>peration           |  |  |
| Cycles:<br>Q Cycle Activity:<br>Q1           | Unlike CALL<br>update W, S<br>1<br>2<br>Q2<br>Read                            | L, there is no c<br>STATUS or BS<br>Q3<br>PUSH PC to                                                                   | option<br>R.                        | Q4<br>No                       |  |  |

| MO          | /SF                                                                      | f                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                 |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------|--|--|--|--|--|
| Synta       | ax:                                                                      | MOVSF [                                                                                                                                                                                                                                   | z <sub>s</sub> ], f <sub>d</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                                 |  |  |  |  |  |
| Oper        | ands:                                                                    |                                                                                                                                                                                                                                           | $\begin{array}{l} 0 \leq z_s \leq 127 \\ 0 \leq f_d \leq 4095 \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |              |                                 |  |  |  |  |  |
| Oper        | ation:                                                                   | ((FSR2) +                                                                                                                                                                                                                                 | $((FSR2) + z_s) \rightarrow f_d$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                                 |  |  |  |  |  |
| Statu       | s Affected:                                                              | None                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                 |  |  |  |  |  |
| 1st w       | oding:<br>/ord (source)<br>word (destin.)                                | 1110<br>1111                                                                                                                                                                                                                              | 1011<br>ffff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Ozzz<br>ffff | 3                               |  |  |  |  |  |
|             |                                                                          | moved to a<br>actual add<br>determined<br>offset ' $z_s$ ' in<br>FSR2. The<br>register is<br>'f <sub>d</sub> ' in the s<br>can be any<br>space (000<br>The MOVSI<br>PCL, TOS<br>destination<br>If the resul<br>an indirect<br>value retur | The contents of the source register are<br>moved to destination register 'f <sub>d</sub> '. The<br>actual address of the source register is<br>determined by adding the 7-bit literal<br>offset 'z <sub>s</sub> ' in the first word to the value of<br>FSR2. The address of the destination<br>register is specified by the 12-bit literal<br>'f <sub>d</sub> ' in the second word. Both addresses<br>can be anywhere in the 4096-byte data<br>space (000h to FFFh).<br>The MOVSF instruction cannot use the<br>PCL, TOSU, TOSH or TOSL as the<br>destination register.<br>If the resultant source address points to<br>an indirect addressing register, the<br>value returned will be 00h. |              |                                 |  |  |  |  |  |
| Word        | ls:                                                                      | 2                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                 |  |  |  |  |  |
| Cycle       | es:                                                                      | 2                                                                                                                                                                                                                                         | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |                                 |  |  |  |  |  |
| QC          | ycle Activity:                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |                                 |  |  |  |  |  |
|             | Q1                                                                       | Q2                                                                                                                                                                                                                                        | Q3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              | Q4                              |  |  |  |  |  |
|             | Decode                                                                   | Determine<br>source addr                                                                                                                                                                                                                  | Determ source a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              | Read<br>source reg              |  |  |  |  |  |
|             | Decode                                                                   | No<br>operation<br>No dummy<br>read                                                                                                                                                                                                       | No<br>operati                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |              | Write<br>register 'f'<br>(dest) |  |  |  |  |  |
| <u>Exan</u> | •                                                                        | MOVSF                                                                                                                                                                                                                                     | [05h], 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | REG2         |                                 |  |  |  |  |  |
|             | Before Instruc<br>FSR2<br>Contents<br>of 85h<br>REG2<br>After Instructio | = 80<br>= 33<br>= 11                                                                                                                                                                                                                      | )h<br>}h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |              |                                 |  |  |  |  |  |

FSR2 Contents

of 85h REG2

=

= = 80h

33h 33h

# 27.0 ELECTRICAL CHARACTERISTICS

# Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                               | 40°C to +125°C       |
|--------------------------------------------------------------|----------------------|
| Storage temperature                                          | 65°C to +150°C       |
| Voltage on any pin with respect to Vss (except VDD and MCLR) | 0.3V to (VDD + 0.3V) |
| Voltage on VDD with respect to Vss                           | -0.3V to +7.5V       |
| Voltage on MCLR with respect to Vss (Note 2)                 | 0V to +13.25V        |
| Total power dissipation (Note 1)                             | 1.0W                 |
| Maximum current out of Vss pin                               |                      |
| Maximum current into VDD pin                                 | 250 mA               |
| Input clamp current, Iικ (Vι < 0 or Vι > VDD)                | ±20 mA               |
| Output clamp current, loк (Vo < 0 or Vo > VDD)               | ±20 mA               |
| Maximum output current sunk by any I/O pin                   | 25 mA                |
| Maximum output current sourced by any I/O pin                | 25 mA                |
| Maximum current sunk by all ports                            | 200 mA               |
| Maximum current sourced by all ports                         | 200 mA               |

- **Note 1:** Power dissipation is calculated as follows: Pdis = VDD x {IDD  $- \sum$  IOH} +  $\sum$  {(VDD - VOH) x IOH} +  $\sum$ (VOL x IOL)
  - **2:** Voltage spikes below Vss at the MCLR/VPP/RE3 pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the MCLR/VPP/ RE3 pin, rather than pulling this pin directly to Vss.

**† NOTICE:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

## 27.2 DC Characteristics: Power-Down and Supply Current PIC18F2221/2321/4221/4321 (Industrial) PIC18LF2221/2321/4221/4321 (Industrial) (Continued)

| PIC18LF2<br>(Indus | 221/2321/4221/4321<br>trial)          |                                                                                                                                                                                                                                                                |     | rating C<br>perature |            | ess otherwise state $A \le +85^{\circ}C$ for indust |                                           |  |
|--------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------|------------|-----------------------------------------------------|-------------------------------------------|--|
|                    | 21/2321/4221/4321<br>trial, Extended) | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for industrial} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for extended} \end{array}$ |     |                      |            |                                                     |                                           |  |
| Param<br>No.       | Device                                | Тур                                                                                                                                                                                                                                                            | Max | Units                | Conditions |                                                     |                                           |  |
|                    | Supply Current (IDD) <sup>(2)</sup>   |                                                                                                                                                                                                                                                                |     |                      |            |                                                     |                                           |  |
|                    | PIC18LF2X21/4X21                      | 51                                                                                                                                                                                                                                                             | 75  | μA                   | -40°C      |                                                     |                                           |  |
|                    |                                       | 54                                                                                                                                                                                                                                                             | 75  | μA                   | +25°C      | VDD = 2.0V                                          |                                           |  |
|                    |                                       | 60                                                                                                                                                                                                                                                             | 75  | μA                   | +85°C      | ]                                                   |                                           |  |
|                    | PIC18LF2X21/4X21                      | 83                                                                                                                                                                                                                                                             | 123 | μA                   | -40°C      |                                                     |                                           |  |
|                    |                                       | 88                                                                                                                                                                                                                                                             | 123 | μA                   | +25°C      | VDD = 3.0V                                          | Fosc = 1 MHz                              |  |
|                    |                                       | 93                                                                                                                                                                                                                                                             | 123 | μA                   | +85°C      |                                                     | ( <b>PRI_IDLE</b> mode,<br>EC oscillator) |  |
|                    | All Devices                           | 180                                                                                                                                                                                                                                                            | 260 | μA                   | -40°C      |                                                     |                                           |  |
|                    |                                       | 180                                                                                                                                                                                                                                                            | 260 | μA                   | +25°C      | VDD = 5.0V                                          | 1                                         |  |
|                    |                                       | 180                                                                                                                                                                                                                                                            | 260 | μA                   | +85°C      | VDD - 5.0V                                          |                                           |  |
|                    | Extended Devices Only                 | 190                                                                                                                                                                                                                                                            | 260 | μA                   | +125°C     |                                                     |                                           |  |
|                    | PIC18LF2X21/4X21                      | 210                                                                                                                                                                                                                                                            | 290 | μA                   | -40°C      |                                                     |                                           |  |
|                    |                                       | 220                                                                                                                                                                                                                                                            | 290 | μA                   | +25°C      | VDD = 2.0V                                          |                                           |  |
|                    |                                       | 230                                                                                                                                                                                                                                                            | 290 | μA                   | +85°C      |                                                     |                                           |  |
|                    | PIC18LF2X21/4X21                      | 350                                                                                                                                                                                                                                                            | 480 | μA                   | -40°C      |                                                     |                                           |  |
|                    |                                       | 360                                                                                                                                                                                                                                                            | 480 | μA                   | +25°C      | VDD = 3.0V                                          | Fosc = 4 MHz<br>( <b>PRI IDLE</b> mode,   |  |
|                    |                                       | 370                                                                                                                                                                                                                                                            | 480 | μA                   | +85°C      |                                                     | EC oscillator)                            |  |
|                    | All Devices                           | 0.69                                                                                                                                                                                                                                                           | 1   | mA                   | -40°C      |                                                     | ,                                         |  |
|                    |                                       | 0.70                                                                                                                                                                                                                                                           | 1   | mA                   | +25°C      | VDD = 5.0V                                          |                                           |  |
|                    |                                       | 0.72                                                                                                                                                                                                                                                           | 1   | mA                   | +85°C      | VDD - 3.0V                                          |                                           |  |
|                    | Extended Devices Only                 | 0.74                                                                                                                                                                                                                                                           | 1   | mA                   | +125°C     |                                                     |                                           |  |
|                    | Extended Devices Only                 | 3.7                                                                                                                                                                                                                                                            | 4.0 | mA                   | +125°C     | VDD = 4.2V                                          | Fosc = 25 MHz                             |  |
|                    |                                       | 4.6                                                                                                                                                                                                                                                            | 5.0 | mA                   | +125°C     | VDD = 5.0V                                          | ( <b>PRI_IDLE</b> mode,<br>EC oscillator) |  |
|                    | All Devices                           | 6.0                                                                                                                                                                                                                                                            | 7.3 | mA                   | -40°C      |                                                     | Fosc = 40 MHz<br>( <b>PRI_IDLE</b> mode.  |  |
|                    |                                       | 6.2                                                                                                                                                                                                                                                            | 7.3 | mA                   | +25°C      | VDD = 4.2V                                          |                                           |  |
|                    |                                       | 6.6                                                                                                                                                                                                                                                            | 7.3 | mA                   | +85°C      |                                                     |                                           |  |
|                    | All Devices                           | 6.8                                                                                                                                                                                                                                                            | 9.2 | mA                   | -40°C      |                                                     | EC oscillator)                            |  |
|                    |                                       | 7.0                                                                                                                                                                                                                                                            | 9.2 | mA                   | +25°C      | VDD = 5.0V                                          |                                           |  |
|                    |                                       | 7.1                                                                                                                                                                                                                                                            | 9.2 | mA                   | +85°C      |                                                     |                                           |  |

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

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

- 2: The supply current is mainly a function of operating voltage, frequency and mode. Other factors, such as I/O pin loading and switching rate, oscillator type and circuit, internal code execution pattern and temperature, also have an impact on the current consumption.
  - The test conditions for all IDD measurements in active operation mode are:
    - OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD or VSS;
      - MCLR = VDD; WDT enabled/disabled as specified.
- **3:** Low-power, Timer1 oscillator is selected unless otherwise indicated, where LPT1OSC (CONFIG3H<2>) = 1.
- **4:** BOR and HLVD enable internal band gap reference. With both modules enabled, current consumption will be less than the sum of both specifications.
- 5: When operation below -10°C is expected, use T1OSC High-Power mode, where LPT1OSC (CONFIG3H<2>) = 0.



| Param<br>No. | Symbol                | Characteristic                                                         |                                   | Min           | Max | Units | Conditions |
|--------------|-----------------------|------------------------------------------------------------------------|-----------------------------------|---------------|-----|-------|------------|
| 70           | TssL2scH,<br>TssL2scL | $\overline{SS} \downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ Input |                                   | 3 Тсү         | —   | ns    |            |
| 71           | TscH                  | SCK Input High Time                                                    | Continuous                        | 1.25 Tcy + 30 | _   | ns    |            |
| 71A          |                       |                                                                        | Single Byte                       | 40            | _   | ns    | (Note 1)   |
| 72           | TscL                  | SCK Input Low Time                                                     | Continuous                        | 1.25 Tcy + 30 | _   | ns    |            |
| 72A          |                       |                                                                        | Single Byte                       | 40            |     | ns    | (Note 1)   |
| 73           | TdiV2scH,<br>TdiV2scL | Setup Time of SDI Data Input to SCK Edge                               |                                   | 20            | _   | ns    |            |
| 73A          | Tb2b                  | Last Clock Edge of Byte 1 to the First Clock Edge of Byte 2            |                                   | 1.5 Tcy + 40  |     | ns    | (Note 2)   |
| 74           | TscH2diL,<br>TscL2diL | Hold Time of SDI Data Input to SCK Edge                                |                                   | 40            |     | ns    |            |
| 75           | TdoR                  | SDO Data Output Rise Time                                              | PIC18FXXXX                        | —             | 25  | ns    |            |
|              |                       |                                                                        | PIC18LFXXXX                       |               | 45  | ns    | VDD = 2.0V |
| 76           | TdoF                  | SDO Data Output Fall Time                                              |                                   | —             | 25  | ns    |            |
| 77           | TssH2doZ              | SS ↑ to SDO Output High-Impedance                                      | SS ↑ to SDO Output High-Impedance |               | 50  | ns    |            |
| 80           | TscH2doV,             | SDO Data Output Valid after SCK Edge                                   | PIC18FXXXX                        | _             | 50  | ns    |            |
|              | TscL2doV              |                                                                        | PIC18LFXXXX                       |               | 100 | ns    | VDD = 2.0V |
| 83           | TscH2ssH,<br>TscL2ssH | SS ↑ after SCK edge                                                    | •                                 | 1.5 Tcy + 40  | _   | ns    |            |

## TABLE 27-16: EXAMPLE SPI MODE REQUIREMENTS (SLAVE MODE TIMING, CKE = 0)

**Note 1:** Requires the use of Parameter #73A.

2: Only if Parameter #71A and #72A are used.

# С

| C Compilers                                                     |     |
|-----------------------------------------------------------------|-----|
| MPLAB C18                                                       | 330 |
| MPLAB C30                                                       | 330 |
| CALL                                                            | 294 |
| CALLW                                                           |     |
| Capture (CCP Module)                                            |     |
| Associated Registers                                            |     |
| CCP Pin Configuration                                           |     |
| CCPRxH:CCPRxL Registers                                         |     |
| Prescaler                                                       |     |
| Software Interrupt                                              |     |
| Timer1/Timer3 Mode Selection                                    |     |
| Capture (ECCP Module)                                           |     |
| Capture/Compare/PWM (CCP)                                       | 145 |
| Capture Mode. See Capture.<br>CCPRxH Register                   | 146 |
| CCPRxL Register                                                 |     |
| Compare Mode. See Compare.                                      | 140 |
| Interaction of Two CCP Modules                                  | 146 |
| Module Configuration                                            |     |
| Pin Assignment                                                  |     |
| Timer Resources                                                 |     |
| Clock Sources                                                   |     |
| Selecting the 31 kHz Source                                     |     |
| Selection Using OSCCON Register                                 |     |
| CLRF                                                            |     |
| CLRWDT                                                          | 295 |
| Code Examples                                                   |     |
| 16 x 16 Signed Multiply Routine                                 |     |
| 16 x 16 Unsigned Multiply Routine                               |     |
| 8 x 8 Signed Multiply Routine                                   |     |
| 8 x 8 Unsigned Multiply Routine                                 |     |
| Address Masking                                                 |     |
| Changing Between Capture Prescalers                             |     |
| Computed GOTO Using an Offset Value                             |     |
| Data EEPROM Read                                                |     |
| Data EEPROM Refresh Routine                                     |     |
| Data EEPROM Write                                               |     |
| Erasing a Flash Program Memory Row                              |     |
| Fast Register Stack<br>How to Clear RAM (Bank 1) Using Indirect | 02  |
| Addressing                                                      | 73  |
| Implementing a Real-Time Clock Using a                          |     |
| Timer1 Interrupt Service                                        | 137 |
| Initializing PORTA                                              |     |
| Initializing PORTB                                              |     |
| Initializing PORTC                                              |     |
| Initializing PORTD                                              |     |
| Initializing PORTE                                              | 123 |
| Loading the SSPBUF (SSPSR) Register                             | 170 |
| Reading a Flash Program Memory Word                             |     |
| Saving STATUS, WREG and BSR                                     |     |
| Registers in RAM                                                |     |
| Writing to Flash Program Memory                                 |     |
| Code Protection                                                 |     |
| Associated Registers                                            | 275 |
| Configuration Register Protection                               |     |
| Data EEPROM                                                     |     |
| Program Memory                                                  |     |
| COMF                                                            |     |
| Comparator                                                      |     |
| Analog Input Connection Considerations                          |     |
| Associated Registers<br>Configuration                           |     |
|                                                                 |     |

| Effects of a Reset                   |     |
|--------------------------------------|-----|
| Interrupts                           |     |
| Operation                            |     |
| Operation During Sleep               |     |
| Outputs                              | 245 |
| Reference                            |     |
| External Signal                      |     |
| Internal Signal                      |     |
| Response Time                        | 245 |
| Comparator Specifications            | 350 |
| Comparator Voltage Reference         | 249 |
| Accuracy and Error                   |     |
| Associated Registers                 | 251 |
| Configuring                          |     |
| Connection Considerations            |     |
| Effects of a Reset                   | 250 |
| Operation During Sleep               | 250 |
| Compare (CCP Module)                 |     |
| CCPRx Register                       |     |
| Pin Configuration                    |     |
| Software Interrupt                   |     |
| Special Event Trigger                |     |
| Timer1/Timer3 Mode Selection         |     |
| Compare (ECCP Module)                |     |
| Special Event Trigger                |     |
| Computed GOTO                        |     |
| Configuration Bits                   |     |
| Context Saving During Interrupts     |     |
| Conversion Considerations            |     |
| CPFSEQ                               |     |
| CPFSGT                               |     |
| CPFSLT                               |     |
| Crystal Oscillator/Ceramic Resonator |     |
| Customer Change Notification Service |     |
| Customer Notification Service        |     |
| Customer Support                     |     |
| successes support                    |     |

## D

| Data Addressing Modes                    | 73 |
|------------------------------------------|----|
| Comparing Options with the Extended      |    |
| Instruction Set Enabled                  | 76 |
| Direct                                   | 73 |
| Indexed Literal Offset                   | 75 |
| Instructions Affected                    | 75 |
| Indirect                                 | 73 |
| Inherent and Literal                     | 73 |
| Data EEPROM Memory                       | 89 |
| Associated Registers                     | 93 |
| EEADR Register                           | 89 |
| EECON1 Register                          | 89 |
| EECON2 Register                          | 89 |
| EEDATA Register                          | 89 |
| Operation During Code-Protect            | 92 |
| Protection Against Spurious Write        | 92 |
| Reading                                  | 91 |
| Using                                    | 92 |
| Write Verify                             | 91 |
| Writing                                  | 91 |
| Data Memory                              | 65 |
| Access Bank                              | 67 |
| and the Extended Instruction Set         | 75 |
| Bank Select Register (BSR)               | 65 |
| General Purpose Registers                | 67 |
| Map for PIC18F2221/2321/4221/4321 Family | 66 |
| Special Function Registers               | 68 |
|                                          |    |

| DAW                                  | 298  |
|--------------------------------------|------|
| DC Characteristics                   | 347  |
| Power-Down and Supply Current        | 337  |
| Supply Voltage                       | 336  |
| DCFSNZ                               | 299  |
| DECF                                 | 298  |
| DECFSZ                               | 299  |
| Development Support                  | 329  |
| Device Differences                   |      |
| Device Overview                      | 9    |
| Details on Individual Family Members | . 10 |
| Features (table)                     | . 11 |
| New Core Features                    | 9    |
| Other Special Features               | . 10 |
| Device Reset Timers                  | .51  |
| Oscillator Start-up Timer (OST)      | .51  |
| PLL Lock Time-out                    | 51   |
| Power-up Timer (PWRT)                | .51  |
| Time-out Sequence                    | 51   |
| Direct Addressing                    | .74  |

# Е

| Effect on Standard PIC MCU Instructions          | 326   |
|--------------------------------------------------|-------|
| Effects of Power-Managed Modes on Various        |       |
| Clock Sources                                    | 38    |
| Electrical Characteristics                       | 333   |
| Enhanced Capture/Compare/PWM (ECCP)              | 153   |
| Associated Registers                             | 166   |
| Capture and Compare Modes                        |       |
| Capture Mode. See Capture (ECCP Module).         |       |
| Outputs and Configuration                        | 154   |
| Pin Configurations for ECCP1                     |       |
| PWM Mode. See PWM (ECCP Module).                 |       |
| Standard PWM Mode                                | 154   |
| Timer Resources                                  | 154   |
| Enhanced PWM Mode. See PWM (ECCP Module)         | 155   |
| Enhanced Universal Synchronous Asynchronous Rece | eiver |
| Transmitter (EUSART). See EUSART.                |       |
| Equations                                        |       |
| A/D Acquisition Time                             | 238   |
| A/D Minimum Charging Time                        |       |
| Calculating the Minimum Required                 |       |
| Acquisition Time                                 | 238   |
| Errata                                           | 8     |
| EUSART                                           |       |
| Asynchronous Mode                                | 221   |
| 12-Bit Break Transmit and Receive                | 227   |
| Associated Registers, Receive                    | 225   |
| Associated Registers, Transmit                   | 223   |
| Auto-Wake-up on Sync Break                       | 226   |
| Receiver                                         | 224   |
| Setting up 9-Bit Mode with Address Detect        | 224   |
| Transmitter                                      | 221   |
| Baud Rate Generator                              |       |
| Operation in Power-Managed Mode                  | 215   |
| Baud Rate Generator (BRG)                        | 215   |
| Associated Registers                             | 216   |
| Auto-Baud Rate Detect                            | 219   |
| Baud Rate Error, Calculating                     |       |
| Baud Rates, Asynchronous Modes                   |       |
| High Baud Rate Select (BRGH Bit)                 | 215   |
| Sampling                                         | 215   |
|                                                  |       |

| Synchronous Master Mode        | 228 |
|--------------------------------|-----|
| Associated Registers, Receive  | 230 |
| Associated Registers, Transmit | 229 |
| Reception                      | 230 |
| Transmission                   | 228 |
| Synchronous Slave Mode         | 231 |
| Associated Registers, Receive  | 232 |
| Associated Registers, Transmit | 231 |
| Reception                      | 232 |
| Transmission                   | 231 |
| Extended Instruction Set       |     |
| ADDFSR                         | 322 |
| ADDULNK                        | 322 |
| and Using MPLAB Tools          | 328 |
| CALLW                          | 323 |
| Considerations for Use         | 326 |
| MOVSF                          | 323 |
| MOVSS                          | 324 |
| PUSHL                          | 324 |
| SUBFSR                         | 325 |
| SUBULNK                        | 325 |
| Syntax                         | 321 |
| External Clock Input           | 30  |
|                                |     |

# F

| •                                      |          |
|----------------------------------------|----------|
| Fail-Safe Clock Monitor                | 259, 272 |
| Exiting Operation                      | 272      |
| Interrupts in Power-Managed Modes      |          |
| POR or Wake From Sleep                 | 273      |
| WDT During Oscillator Failure          |          |
| Fast Register Stack                    |          |
| Firmware Instructions                  | 279      |
| Flash Program Memory                   |          |
| Associated Registers                   | 87       |
| Control Registers                      |          |
| EECON1 and EECON2                      | 80       |
| TABLAT (Table Latch) Register          | 82       |
| TBLPTR (Table Pointer) Register        |          |
| Erase Sequence                         | 84       |
| Erasing                                |          |
| Operation During Code-Protect          | 87       |
| Reading                                |          |
| Table Pointer                          |          |
| Boundaries                             | 82       |
| Boundaries Based on Operation          | 82       |
| Operations with TBLRD and TBLWT (table | e) 82    |
| Table Reads and Table Writes           |          |
| Write Sequence                         | 85       |
| Writing                                |          |
| Protection Against Spurious Writes     | 87       |
| Unexpected Termination                 | 87       |
| Write Verify                           | 87       |
| FSCM. See Fail-Safe Clock Monitor.     |          |
| G                                      |          |
| 6                                      |          |
| GOTO                                   | 300      |

## Н

| Hardware Multiplier    | 95 |
|------------------------|----|
| Introduction           | 95 |
| Operation              | 95 |
| Performance Comparison |    |
|                        |    |