



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              | 54                                                                         |
| Program Memory Size        | 128KB (64K x 16)                                                           |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 1K x 8                                                                     |
| RAM Size                   | 3.8K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                  |
| Data Converters            | A/D 12x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 64-TQFP                                                                    |
| Supplier Device Package    | 64-TQFP (10x10)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf6722-i-pt |

Email: info@E-XFL.COM

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

## 6.5 Writing to Flash Program Memory

The minimum programming block is 32 words or 64 bytes. Word or byte programming is not supported.

Table writes are used internally to load the holding registers needed to program the Flash memory. There are 64 holding registers used by the table writes for programming.

Since the Table Latch (TABLAT) is only a single byte, the TBLWT instruction may need to be executed 64 times for each programming operation. All of the table write operations will essentially be short writes because only the holding registers are written. At the end of updating the 64 holding registers, the EECON1 register must be written to in order to start the programming operation with a long write.

The long write is necessary for programming the internal Flash. Instruction execution is halted while in a long write cycle. The long write will be terminated by the internal programming timer.

The EEPROM on-chip timer controls the write time. The write/erase voltages are generated by an on-chip charge pump, rated to operate over the voltage range of the device.

Note: The default value of the holding registers on device Resets and after write operations is FFh. A write of FFh to a holding register does not modify that byte. This means that individual bytes of program memory may be modified, provided that the change does not attempt to change any bit from a '0' to a '1'. When modifying individual bytes, it is not necessary to load all 64 holding registers before executing a write operation.

### FIGURE 6-5: TABLE WRITES TO FLASH PROGRAM MEMORY



# 6.5.1 FLASH PROGRAM MEMORY WRITE SEQUENCE

The sequence of events for programming an internal program memory location should be:

- 1. Read 64 bytes into RAM.
- 2. Update data values in RAM as necessary.
- 3. Load Table Pointer register with address being erased.
- 4. Execute the row erase procedure.
- 5. Load Table Pointer register with address of first byte being written.
- 6. Write the 64 bytes into the holding registers with auto-increment.
- 7. Set the EECON1 register for the write operation:
  - set EEPGD bit to point to program memory;
  - clear the CFGS bit to access program memory;
  - set WREN to enable byte writes.

- 8. Disable interrupts.
- 9. Write 55h to EECON2.
- 10. Write 0AAh to EECON2.
- 11. Set the WR bit. This will begin the write cycle.
- 12. The CPU will stall for duration of the write for TIW (see parameter D133A).
- 13. Re-enable interrupts.
- 14. Verify the memory (table read).

An example of the required code is shown in Example 6-3 on the following page.

Note: Before setting the WR bit, the Table Pointer address needs to be within the intended address range of the 64 bytes in the holding register.

## 7.5.2 16-BIT WORD WRITE MODE

Figure 7-2 shows an example of 16-bit Word Write mode for PIC18F8527/8622/8627/8722 devices. This mode is used for word-wide memories which includes some of the EPROM and Flash-type memories. This mode allows opcode fetches and table reads from all forms of 16-bit memory and table writes to any type of word-wide external memories. This method makes a distinction between TBLWT cycles to even or odd addresses.

During a TBLWT cycle to an even address (TBLPTR<0> = 0), the TABLAT data is transferred to a holding latch and the external address data bus is tri-stated for the data portion of the bus cycle. No write signals are activated.

During a TBLWT cycle to an odd address (TBLPTR<0> = 1), the TABLAT data is presented on the upper byte of the AD15:AD0 bus. The contents of the holding latch are presented on the lower byte of the AD<15:0> bus.

The WRH signal is strobed for each write cycle; the WRL pin is unused. The signal on the BA0 pin indicates the Least Significant bit of TBLPTR but it is left unconnected. Instead, the UB and LB signals are active to select both bytes. The obvious limitation to this method is that the table write must be done in pairs on a specific word boundary to correctly write a word location.



#### FIGURE 7-2: 16-BIT WORD WRITE MODE EXAMPLE

## 11.0 I/O PORTS

Depending on the device selected and features enabled, there are up to nine ports available. Some pins of the I/O ports are multiplexed with an alternate function from the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Each port has three registers for its operation. These registers are:

- TRIS register (Data Direction register)
- Port register (reads the levels on the pins of the device)
- LAT register (output latch)

The Data Latch (LAT register) is useful for read-modify-write operations on the value that the I/O pins are driving.

A simplified model of a generic I/O port, without the interfaces to other peripherals, is shown in Figure 11-1.

FIGURE 11-1: GENERIC I/O PORT OPERATION



# 11.1 PORTA, TRISA and LATA Registers

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

Reading the PORTA register reads the status of the pins, whereas writing to it, will write to the port latch.

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

The RA4 pin is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. Pins RA6 and RA7 are multiplexed with the main oscillator pins; they are enabled as oscillator or I/O pins by the selection of the main oscillator in the Configuration register (see **Section 25.1 "Configuration Bits"** for details). When they are not used as port pins, RA6 and RA7 and their associated TRIS and LAT bits are read as '0'.

The other PORTA pins are multiplexed with the analog VREF+ and VREF- inputs. The operation of pins RA5:RA0 as A/D converter inputs is selected by clearing or setting the PCFG<3:0> control bits in the ADCON1 register.

| Note: | On a Power-on Reset, RA5 and RA<3:0>          |
|-------|-----------------------------------------------|
|       | are configured as analog inputs and read      |
|       | as '0'. RA4 is configured as a digital input. |

The RA4/T0CKI pin is a Schmitt Trigger input and an open-drain output. All other PORTA pins have TTL input levels and full CMOS output drivers.

The TRISA register controls the direction of the PORTA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs.

| EXAMPLE 11-1: | INITIALIZING PORTA |
|---------------|--------------------|
|               |                    |

| CLRF  | PORTA  | ; Initialize PORTA by   |
|-------|--------|-------------------------|
|       |        | ; clearing output       |
|       |        | ; data latches          |
| CLRF  | LATA   | ; Alternate method      |
|       |        | ; to clear output       |
|       |        | ; data latches          |
| MOVLW | 0Fh    | ; Configure A/D         |
| MOVWF | ADCON1 | ; for digital inputs    |
| MOVLW | 0CFh   | ; Value used to         |
|       |        | ; initialize data       |
|       |        | ; direction             |
| MOVWF | TRISA  | ; Set RA<3:0> as inputs |
|       |        | ; RA<5:4> as outputs    |
|       |        |                         |

| Name  | Bit 7 | Bit 6 | Bit 5                | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values on<br>page |
|-------|-------|-------|----------------------|--------|--------|--------|--------|--------|----------------------------|
| PORTG |       |       | RG5 <sup>(1)</sup>   | RG4    | RG3    | RG2    | RG1    | RG0    | 60                         |
| LATG  | —     | —     | LATG5 <sup>(1)</sup> | LATG4  | LATG3  | LATG2  | LATG1  | LATG0  | 60                         |
| TRISG | _     | _     | _                    | TRISG4 | TRISG3 | TRISG2 | TRISG1 | TRISG0 | 60                         |

TABLE 11-14: SUMMARY OF REGISTERS ASSOCIATED WITH PORTG

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

**Note 1:** RG5 and LATG5 are only available when MCLR is disabled (MCLRE Configuration bit = 0; otherwise, RG5 and LATG5 read as '0'.

## 11.10 Parallel Slave Port

PORTD can also function as an 8-bit wide Parallel Slave Port, or microprocessor port, when control bit PSPMODE (PSPCON<4>) is set. It is asynchronously readable and writable by the external world through the RD and  $\overline{WR}$  control input pins.

| Note: | For PIC18F8527/8622/8627/8722 devices,       |
|-------|----------------------------------------------|
|       | the Parallel Slave Port is available only in |
|       | Microcontroller mode.                        |

The PSP can directly interface to an 8-bit microprocessor data bus. The external microprocessor can read or write the PORTD latch as an 8-bit latch. Setting bit PSPMODE enables port pin RE0/RD to be the RD input, RE1/WR to be the WR input and RE2/CS to be the CS (Chip Select) input. For this functionality, the corresponding data direction bits of the TRISE register (TRISE<2:0>) must be configured as inputs (set).

A write to the PSP occurs when both the  $\overline{\text{CS}}$  and  $\overline{\text{WR}}$  lines are first detected low and ends when either are detected high. The PSPIF and IBF flag bits are both set when the write ends.

A read from the PSP occurs when both the  $\overline{CS}$  and  $\overline{RD}$  lines are first detected low. The data in PORTD is read out and the OBF bit is set. If the user writes new data to PORTD to set OBF, the data is immediately read out; however, the OBF bit is not set.

When either the  $\overline{CS}$  or  $\overline{RD}$  lines are detected high, the PORTD pins return to the input state and the PSPIF bit is set. User applications should wait for PSPIF to be set before servicing the PSP; when this happens, the IBF and OBF bits can be polled and the appropriate action taken.

The timing for the control signals in Write and Read modes is shown in Figure 11-3 and Figure 11-4, respectively.



## 12.1 Timer0 Operation

Timer0 can operate as either a timer or a counter; the mode is selected with the TOCS bit (T0CON<5>). In Timer mode (T0CS = 0), the module increments on every clock by default unless a different prescaler value is selected (see **Section 12.3 "Prescaler"**). If the TMR0 register is written to, the increment is inhibited for the following two instruction cycles. The user can work around this by writing an adjusted value to the TMR0 register.

The Counter mode is selected by setting the TOCS bit (= 1). In this mode, Timer0 increments either on every rising or falling edge of pin RA4/T0CKI. The incrementing edge is determined by the Timer0 Source Edge Select bit, T0SE (T0CON<4>); clearing this bit selects the rising edge. Restrictions on the external clock input are discussed below.

An external clock source can be used to drive Timer0; however, it must meet certain requirements to ensure that the external clock can be synchronized with the internal phase clock (Tosc). There is a delay between synchronization and the onset of incrementing the timer/counter.

# 12.2 Timer0 Reads and Writes in 16-bit Mode

TMR0H is not the actual high byte of Timer0 in 16-bit mode; it is actually a buffered version of the real high byte of Timer0 which is not directly readable nor writable (refer to Figure 12-2). TMR0H is updated with the contents of the high byte of Timer0 during a read of TMR0L. This provides the ability to read all 16 bits of Timer0 without having to verify that the read of the high and low byte were valid, due to a rollover between successive reads of the high and low byte.

Similarly, a write to the high byte of Timer0 must also take place through the TMR0H Buffer register. The high byte is updated with the contents of TMR0H when a write occurs to TMR0L. This allows all 16 bits of Timer0 to be updated at once.

### FIGURE 12-1: TIMER0 BLOCK DIAGRAM (8-BIT MODE)



### FIGURE 12-2: TIMER0 BLOCK DIAGRAM (16-BIT MODE)



## 15.1 Timer3 Operation

Timer3 can operate in one of three modes:

- Timer
- Synchronous Counter
- Asynchronous Counter

The operating mode is determined by the clock select bit, TMR3CS (T3CON<1>). When TMR3CS is cleared (= 0), Timer3 increments on every internal instruction cycle (Fosc/4). When the bit is set, Timer3 increments on every rising edge of the Timer1 external clock input or the Timer1 oscillator, if enabled.

As with Timer1, the RC1/T1OSI and RC0/T1OSO/ T13CKI pins become inputs when the Timer1 oscillator is enabled. This means the values of TRISC<1:0> are ignored and the pins are read as '0'.



### FIGURE 15-2: TIMER3 BLOCK DIAGRAM (16-BIT READ/WRITE MODE)



## REGISTER 18-3: ECCPxAS: ENHANCED CCP AUTO-SHUTDOWN CONFIGURATION REGISTER

| R/W-0    | R/W-0    | R/W-0    | R/W-0    | R/W-0   | R/W-0   | R/W-0   | R/W-0   |
|----------|----------|----------|----------|---------|---------|---------|---------|
| ECCPxASE | ECCPxAS2 | ECCPxAS1 | ECCPxAS0 | PSSxAC1 | PSSxAC0 | PSSxBD1 | PSSxBD0 |
| bit 7    |          |          |          |         |         |         | bit 0   |
|          |          |          |          |         |         |         |         |

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

| bit 7   | ECCPxASE: ECCP Auto-Shutdown Event Status bit                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------|
|         | <ul><li>0 = ECCP outputs are operating</li><li>1 = A shutdown event has occurred; ECCP outputs are in shutdown state</li></ul> |
| bit 6-4 | ECCPxAS<2:0>: ECCP Auto-Shutdown Source Select bits                                                                            |
|         | 000 = Auto-shutdown is disabled                                                                                                |
|         | 001 = Comparator 1 output                                                                                                      |
|         | 010 = Comparator 2 output                                                                                                      |
|         | 011 = Either Comparator 1 or 2                                                                                                 |
|         | 100 = FLI0                                                                                                                     |
|         | 101 = FLI0 or Comparator 1                                                                                                     |
|         | 110 = FLI0  or Comparator 2                                                                                                    |
|         |                                                                                                                                |
| bit 3-2 | <b>PSSxAC&lt;1:0&gt;:</b> Pins A and C Shutdown State Control bits                                                             |
|         | 00 = Drive pins A and C to '0'                                                                                                 |
|         | 01 = Drive pins A and C to '1'                                                                                                 |
|         | 1x = Pins A and C tri-state                                                                                                    |
| bit 1-0 | PSSxBD<1:0>: Pins B and D Shutdown State Control bits                                                                          |
|         | 00 = Drive pins B and D to '0'                                                                                                 |
|         | 01 = Drive pins B and D to '1'                                                                                                 |
|         | 1x = Pins B and D tri-state                                                                                                    |
|         |                                                                                                                                |

| Name     | Bit 7                                             | Bit 6        | Bit 5        | Bit 4        | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|----------|---------------------------------------------------|--------------|--------------|--------------|--------|--------|--------|--------|----------------------------|
| INTCON   | GIE/GIEH                                          | PEIE/GIEL    | TMR0IE       | INT0IE       | RBIE   | TMR0IF | INT0IF | RBIF   | 57                         |
| PIR1     | PSPIF                                             | ADIF         | RC1IF        | TX1IF        | SSP1IF | CCP1IF | TMR2IF | TMR1IF | 60                         |
| PIE1     | PSPIE                                             | ADIE         | RC1IE        | TX1IE        | SSP1IE | CCP1IE | TMR2IE | TMR1IE | 60                         |
| IPR1     | PSPIP                                             | ADIP         | RC1IP        | TX1IP        | SSP1IP | CCP1IP | TMR2IP | TMR1IP | 60                         |
| TRISC    | TRISC7                                            | TRISC6       | TRISC5       | TRISC4       | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 60                         |
| TRISG    | —                                                 | —            | _            | TRISG4       | TRISG3 | TRISG2 | TRISG1 | TRISG0 | 60                         |
| RCSTAx   | SPEN                                              | RX9          | SREN         | CREN         | ADDEN  | FERR   | OERR   | RX9D   | 59                         |
| RCREGx   | EUSARTx F                                         | Receive Regi | ster         |              |        |        |        |        | 59                         |
| TXSTAx   | CSRC                                              | TX9          | TXEN         | SYNC         | SENDB  | BRGH   | TRMT   | TX9D   | 59                         |
| BAUDCONx | ABDOVF                                            | RCIDL        | _            | SCKP         | BRG16  | —      | WUE    | ABDEN  | 61                         |
| SPBRGHx  | Ix EUSARTx Baud Rate Generator Register High Byte |              |              |              |        |        |        |        | 61                         |
| SPBRGx   | EUSARTx E                                         | Baud Rate Ge | enerator Reg | ister Low By | te     |        |        |        | 59                         |

#### TABLE 20-8: REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER RECEPTION

Legend: — = unimplemented, read as '0'. Shaded cells are not used for synchronous master reception.

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

The Analog-to-Digital (A/D) converter module has 12 inputs for the 64-pin devices and 16 for the 80-pin devices. This module allows conversion of an analog input signal to a corresponding 10-bit digital number.

The module has five registers:

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

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

## REGISTER 21-1: ADCON0: A/D CONTROL REGISTER

| U-0   | U-0 | R/W-0               | R/W-0               | R/W-0               | R/W-0               | R/W-0   | R/W-0 |
|-------|-----|---------------------|---------------------|---------------------|---------------------|---------|-------|
| —     | _   | CHS3 <sup>(1)</sup> | CHS2 <sup>(1)</sup> | CHS1 <sup>(1)</sup> | CHS0 <sup>(1)</sup> | GO/DONE | ADON  |
| bit 7 |     |                     |                     |                     |                     |         | bit 0 |

| Legend:                       |             |                                         |                                    |                    |  |  |  |  |
|-------------------------------|-------------|-----------------------------------------|------------------------------------|--------------------|--|--|--|--|
| R = Readable b                | pit         | W = Writable bit                        | U = Unimplemented bit, read as '0' |                    |  |  |  |  |
| -n = Value at POR '1' = Bit i |             | '1' = Bit is set                        | '0' = Bit is cleared               | x = Bit is unknown |  |  |  |  |
|                               |             |                                         |                                    |                    |  |  |  |  |
| bit 7-6                       | Unimplement | ted: Read as '0'                        |                                    |                    |  |  |  |  |
| bit 5-2                       | CHS<3:0> An | alog Channel Select bits <sup>(1)</sup> |                                    |                    |  |  |  |  |

|       | 0000 = Channel 0 (AN0)                                                      |
|-------|-----------------------------------------------------------------------------|
|       | 0001 = Channel 1 (AN1)                                                      |
|       | 0010 = Channel 2 (AN2)                                                      |
|       | 0011 = Channel 3 (AN3)                                                      |
|       | 0100 = Channel 4 (AN4)                                                      |
|       | 0101 = Channel 5 (AN5)                                                      |
|       | 0110 = Channel 6 (AN6)                                                      |
|       | 0111 = Channel 7 (AN7)                                                      |
|       | 1000 = Channel 8 (AN8)                                                      |
|       | 1001 = Channel 9 (AN9)                                                      |
|       | 1010 = Channel 10 (AN10)                                                    |
|       | 1011 = Channel 11 (AN11)                                                    |
|       | 1100 = Channel 12 (AN12) <sup>(1)</sup>                                     |
|       | 1101 = Channel 13 (AN13) <sup>(1)</sup>                                     |
|       | 1110 = Channel 14 (AN14) <sup>(1)</sup>                                     |
|       | 1111 = Channel 15 (AN15) <sup>(1)</sup>                                     |
| bit 1 | GO/DONE: A/D Conversion Status bit                                          |
|       | <u>When ADON = 1:</u>                                                       |
|       | 1 = A/D conversion in progress                                              |
|       | 0 = A/D Idle                                                                |
| bit 0 | ADON: A/D On bit                                                            |
|       | 1 = A/D converter module is enabled<br>0 = A/D converter module is disabled |

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

## 24.6 Operation During Sleep

When enabled, the HLVD circuitry continues to operate during Sleep. If the device voltage crosses the trip point, the HLVDIF bit will be set and the device will wake-up from Sleep. Device execution will continue from the interrupt vector address if interrupts have been globally enabled.

### 24.7 Effects of a Reset

A device Reset forces all registers to their Reset state. This forces the HLVD module to be turned off.

| Name    | Bit 7                 | Bit 6                 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on page |
|---------|-----------------------|-----------------------|--------|--------|--------|--------|--------|--------|----------------------------|
| HLVDCON | VDIRMAG               |                       | IRVST  | HLVDEN | HLVDL3 | HLVDL2 | HLVDL1 | HLVDL0 | 58                         |
| INTCON  | GIE/GIEH              | PEIE/GIEL             | TMR0IE | INT0IE | RBIE   | TMR0IF | INT0IF | RBIF   | 57                         |
| PIR2    | OSCFIF                | CMIF                  | —      | EEIF   | BCL1IF | HLVDIF | TMR3IF | CCP2IF | 60                         |
| PIE2    | OSCFIE                | CMIE                  |        | EEIE   | BCL1IE | HLVDIE | TMR3IE | CCP2IE | 60                         |
| IPR2    | OSCFIP                | CMIP                  | _      | EEIP   | BCL1IP | HLVDIP | TMR3IP | CCP2IP | 60                         |
| TRISA   | TRISA7 <sup>(1)</sup> | TRISA6 <sup>(1)</sup> | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 60                         |

#### TABLE 24-1: REGISTERS ASSOCIATED WITH HIGH/LOW-VOLTAGE DETECT MODULE

Legend: — = unimplemented, read as '0'. Shaded cells are unused by the HLVD module.

**Note 1:** PORTA<7:6> and their direction bits are individually configured as port pins based on various primary oscillator modes. When disabled, these bits read as '0'.

## REGISTER 25-12: CONFIG7H: CONFIGURATION REGISTER 7 HIGH (BYTE ADDRESS 30000Dh)

| U-0             | R/C-1 | U-0              | U-0                               | U-0          | U-0              | U-0      | U-0   |  |  |
|-----------------|-------|------------------|-----------------------------------|--------------|------------------|----------|-------|--|--|
| —               | EBTRB | —                | —                                 | —            | _                | —        | —     |  |  |
| bit 7           |       |                  |                                   |              |                  |          | bit 0 |  |  |
|                 |       |                  |                                   |              |                  |          |       |  |  |
| Legend:         |       |                  |                                   |              |                  |          |       |  |  |
| R = Readable b  | bit   | W = Writable     | bit                               | U = Unimpler | nented bit, read | 1 as '0' |       |  |  |
| -n = Value at P | OR    | '1' = Bit is set | 0' = Bit is cleared x = Bit is up |              | x = Bit is unkr  | nown     |       |  |  |

bit 7 Unimplemented: Read as '0'

bit 6 **EBTRB:** Boot Block Table Read Protection bit

1 = Boot block (000000-007FFF, 000FFF or 001FFFh<sup>(1)</sup>) not protected from table reads executed in other blocks

Boot block (000000-007FFF, 000FFF or 001FFFh<sup>(1)</sup>) protected from table reads executed in other blocks

bit 5-0 Unimplemented: Read as '0'

**Note 1:** Boot block size is determined by the BBSIZ<1:0> bits in CONFIG4L.

| ADDWFC ADD W and Carry bit                |                                                                                                                                                                                                                                                                            |                                                      |                                             |                                                     |  |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------------|-----------------------------------------------------|--|
| Syntax:                                   | ADDWFC                                                                                                                                                                                                                                                                     | f {,d {,                                             | a}}                                         |                                                     |  |
| Operands:                                 | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                                                                                        |                                                      |                                             |                                                     |  |
| Operation:                                | (W) + (f) +                                                                                                                                                                                                                                                                | $(C) \rightarrow de$                                 | st                                          |                                                     |  |
| Status Affected:                          | N,OV, C, D                                                                                                                                                                                                                                                                 | C, Z                                                 |                                             |                                                     |  |
| Encoding:                                 | 0010                                                                                                                                                                                                                                                                       | 00da                                                 | fff                                         | f ffff                                              |  |
| Description:                              | Add W, the<br>location 'f'.<br>placed in V<br>placed in d                                                                                                                                                                                                                  | Carry fla<br>If 'd' is '0<br>V. If 'd' is<br>ata mem | g and o<br>)', the r<br>'1', the<br>ory loc | data memory<br>result is<br>result is<br>ation 'f'. |  |
|                                           | If 'a' is '0', t<br>If 'a' is '1', t<br>GPR bank                                                                                                                                                                                                                           | he Acces<br>he BSR i<br>(default).                   | s Banl<br>s used                            | k is selected.<br>to select the                     |  |
|                                           | If 'a' is '0' and the extended instruct<br>set is enabled, this instruction opera<br>in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See<br>Section 26.2.3 "Byte-Oriented an<br>Bit-Oriented Instructions in Index<br>Literal Offset Mode" for details |                                                      |                                             |                                                     |  |
| Words:                                    | 1                                                                                                                                                                                                                                                                          |                                                      |                                             |                                                     |  |
| Cycles:                                   | 1                                                                                                                                                                                                                                                                          |                                                      |                                             |                                                     |  |
| Q Cycle Activity:                         |                                                                                                                                                                                                                                                                            |                                                      |                                             |                                                     |  |
| Q1                                        | Q2                                                                                                                                                                                                                                                                         | Q3                                                   |                                             | Q4                                                  |  |
| Decode                                    | Read<br>register 'f'                                                                                                                                                                                                                                                       | Proce<br>Data                                        | SS<br>1                                     | Write to destination                                |  |
| Example:                                  | ADDWFC                                                                                                                                                                                                                                                                     | REG,                                                 | 0, 1                                        |                                                     |  |
| Before Instruc<br>Carry bit<br>REG<br>W   | tion<br>= 1<br>= 02h<br>= 4Dh                                                                                                                                                                                                                                              |                                                      |                                             |                                                     |  |
| After Instructio<br>Carry bit<br>REG<br>W | on<br>= 0<br>= 02h<br>= 50h                                                                                                                                                                                                                                                |                                                      |                                             |                                                     |  |

| AND         | olw                    | AND Litera                                                                        | al with W         | ,   |    |          |
|-------------|------------------------|-----------------------------------------------------------------------------------|-------------------|-----|----|----------|
| Synt        | ax:                    | ANDLW                                                                             | k                 |     |    |          |
| Oper        | rands:                 | $0 \le k \le 255$                                                                 | 5                 |     |    |          |
| Oper        | ration:                | (W) .AND.                                                                         | $k \rightarrow W$ |     |    |          |
| Statu       | us Affected:           | N, Z                                                                              |                   |     |    |          |
| Enco        | oding:                 | 0000                                                                              | 1011              | kkk | ck | kkkk     |
| Desc        | cription:              | The contents of W are ANDed with the 8-bit literal 'k'. The result is placed in V |                   |     |    |          |
| Word        | ds:                    | 1                                                                                 |                   |     |    |          |
| Cycle       | es:                    | 1                                                                                 |                   |     |    |          |
| QC          | cycle Activity:        |                                                                                   |                   |     |    |          |
|             | Q1                     | Q2                                                                                | Q                 | 3   |    | Q4       |
|             | Decode                 | Read literal                                                                      | Proce             | SS  | V  | /rite to |
|             |                        | ·Κ                                                                                | Data              | a   |    | VV       |
| <u>Exar</u> | <u>mple:</u>           | ANDLW                                                                             | 05Fh              |     |    |          |
|             | Before Instruc         | tion                                                                              |                   |     |    |          |
|             | W<br>After Instruction | = A3h                                                                             |                   |     |    |          |
|             | W                      | = 03h                                                                             |                   |     |    |          |
|             |                        |                                                                                   |                   |     |    |          |
|             |                        |                                                                                   |                   |     |    |          |

Table Read (Continued)

34h 01A358h

=

| TBL   | RD            | Table Read                                                                                                                                                                                                                                                                                                                                                                           |                        |                           |                             |                       |                                           |
|-------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------------|-----------------------------|-----------------------|-------------------------------------------|
| Synta | ax:           | TBLRD ( *;                                                                                                                                                                                                                                                                                                                                                                           | *+; *                  | -; +*)                    |                             |                       |                                           |
| Oper  | ands:         | None                                                                                                                                                                                                                                                                                                                                                                                 |                        |                           |                             |                       |                                           |
| Oper  | ation:        | if TBLRD *,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>TBLPTR – No Change<br>if TBLRD *+,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR<br>if TBLRD *-,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>(TBLPTR) – 1 $\rightarrow$ TBLPTR<br>if TBLRD +*,<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR;<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT |                        |                           |                             |                       |                                           |
| Statu | s Affected:   | None                                                                                                                                                                                                                                                                                                                                                                                 |                        |                           |                             |                       |                                           |
| Enco  | oding:        | 0000                                                                                                                                                                                                                                                                                                                                                                                 | 0(                     | 000                       | 000                         | 00                    | 10nn<br>nn=0 *<br>=1 *+<br>=2 *-<br>=3 +* |
| Desc  | ription:      | This instruction is used to read the contents<br>of Program Memory (P.M.). To address the<br>program memory, a pointer called Table<br>Pointer (TBLPTR) is used.                                                                                                                                                                                                                     |                        |                           |                             |                       |                                           |
|       |               | The TBLPT<br>each byte in<br>has a 2-Mby                                                                                                                                                                                                                                                                                                                                             | R (a<br>i the<br>/te a | 21-bit<br>progra<br>ddres | : pointe<br>am me<br>s rang | er) po<br>emory<br>e. | oints to<br>v. TBLPTR                     |
|       |               | TBLPTR<                                                                                                                                                                                                                                                                                                                                                                              | 0> =                   | 0:Lea<br>Pro              | st Sigr<br>gram I           | nificai<br>Memo       | nt Byte of<br>ory Word                    |
|       |               | TBLPTR<                                                                                                                                                                                                                                                                                                                                                                              | 0> =                   | 1:Mo<br>Pro               | st Sign<br>gram I           | ifican<br>Nemo        | t Byte of<br>bry Word                     |
|       |               | The TBLRD<br>of TBLPTR                                                                                                                                                                                                                                                                                                                                                               | instr<br>as fo         | uction<br>ollows          | can m                       | nodify                | the value                                 |
|       |               | <ul> <li>no change</li> <li>post-increment</li> <li>post-decrement</li> <li>pre-increment</li> </ul>                                                                                                                                                                                                                                                                                 |                        |                           |                             |                       |                                           |
| Word  | ls:           | 1                                                                                                                                                                                                                                                                                                                                                                                    |                        |                           |                             |                       |                                           |
| Cycle | es:           | 2                                                                                                                                                                                                                                                                                                                                                                                    |                        |                           |                             |                       |                                           |
| QC    | ycle Activity | :                                                                                                                                                                                                                                                                                                                                                                                    |                        |                           |                             |                       |                                           |
|       | Q1            | Q2                                                                                                                                                                                                                                                                                                                                                                                   |                        | C                         | 13                          |                       | Q4                                        |
|       | Decode        | No<br>operation                                                                                                                                                                                                                                                                                                                                                                      |                        | N<br>opera                | o<br>ation                  | op                    | No<br>peration                            |

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

After Instruction TABLAT TBLPTR

TBLRD

 $\ensuremath{\textcircled{}^{\odot}}$  2008 Microchip Technology Inc.

No operation (Read Program Memory)

No

operation

No operation (Write TABLAT)

No

operation

## 26.2.2 EXTENDED INSTRUCTION SET

| ADD                   | FSR            | Add Literal to FSR |                                       |       |       |           |  |  |
|-----------------------|----------------|--------------------|---------------------------------------|-------|-------|-----------|--|--|
| Synta                 | ax:            | ADDFSR             | f, k                                  |       |       |           |  |  |
| Oper                  | ands:          | $0 \le k \le 63$   | $0 \le k \le 63$                      |       |       |           |  |  |
|                       |                | f ∈ [ 0, 1,        | 2]                                    |       |       |           |  |  |
| Oper                  | ation:         | FSR(f) + I         | $FSR(f) + k \rightarrow FSR(f)$       |       |       |           |  |  |
| Status Affected: None |                |                    |                                       |       |       |           |  |  |
| Enco                  | ding:          | 1110               | 1000                                  | ffk   | k     | kkkk      |  |  |
| Desc                  | ription:       | The 6-bit          | The 6-bit literal 'k' is added to the |       |       |           |  |  |
|                       |                | contents of        | of the FSF                            | R spe | cifie | d by 'f'. |  |  |
| Word                  | ls:            | 1                  | 1                                     |       |       |           |  |  |
| Cycle                 | es:            | 1                  |                                       |       |       |           |  |  |
| QC                    | ycle Activity: |                    |                                       |       |       |           |  |  |
|                       | Q1             | Q2                 | Q3                                    |       |       | Q4        |  |  |
|                       | Decode         | Read               | Proces                                | SS    | W     | /rite to  |  |  |
|                       |                | literal 'k'        | Data                                  | l     |       | FSR       |  |  |

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

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

| ADD         | ULNK           | Add Liter                                              | al to FSF                                                                                                         | R2 and R                                | eturn                       |  |  |  |
|-------------|----------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------|--|--|--|
| Synta       | ax:            | ADDULNK                                                | ADDULNK k                                                                                                         |                                         |                             |  |  |  |
| Oper        | ands:          | $0 \le k \le 63$                                       |                                                                                                                   |                                         |                             |  |  |  |
| Oper        | ation:         | FSR2 + k                                               | $\rightarrow$ FSR2                                                                                                |                                         |                             |  |  |  |
|             |                | $(TOS) \rightarrow F$                                  | С                                                                                                                 |                                         |                             |  |  |  |
| Statu       | s Affected:    | None                                                   |                                                                                                                   |                                         |                             |  |  |  |
| Enco        | ding:          | 1110                                                   | 1000                                                                                                              | 11kk                                    | kkkk                        |  |  |  |
| Desc        | ription:       | The 6-bit I<br>contents o<br>executed I<br>TOS.        | The 6-bit literal 'k' is added to the contents of FSR2. A RETURN is then executed by loading the PC with the TOS. |                                         |                             |  |  |  |
|             |                | The instru<br>execute; a<br>the second                 | ction take<br>NOP is p<br>d cycle.                                                                                | es two cy<br>erformed                   | cles to<br>d during         |  |  |  |
|             |                | This may I<br>case of the<br>where f = 3<br>only on FS | be though<br>ADDFSF<br>3 (binary<br>SR2.                                                                          | nt of as a<br>R instruct<br>'11'); it c | special<br>ion,<br>operates |  |  |  |
| Word        | ls:            | 1                                                      | 1                                                                                                                 |                                         |                             |  |  |  |
| Cycle       | es:            | 2                                                      |                                                                                                                   |                                         |                             |  |  |  |
| QC          | ycle Activity: |                                                        |                                                                                                                   |                                         |                             |  |  |  |
|             | Q1             | Q2                                                     | Q3                                                                                                                |                                         | Q4                          |  |  |  |
|             | Decode         | Read<br>literal 'k'                                    | Proces<br>Data                                                                                                    | ss \                                    | Write to<br>FSR             |  |  |  |
|             | No             | No                                                     | No                                                                                                                |                                         | No                          |  |  |  |
|             | Operation      | Operation                                              | Operati                                                                                                           | ion O                                   | peration                    |  |  |  |
| <u>Exan</u> | <u>nple:</u>   | ADDULNK 2                                              | 23h                                                                                                               |                                         |                             |  |  |  |

| ample: ADDULNK |        |       | 2 |
|----------------|--------|-------|---|
| Before Instr   | uction |       |   |
| FSR2           | =      | 03FFh |   |
| PC             | =      | 0100h |   |
| After Instruc  | ction  |       |   |
| FSR2           | =      | 0422h |   |
| PC             | =      | (TOS) |   |
|                |        |       |   |

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

## 27.2 MPASM Assembler

The MPASM Assembler is a full-featured, universal macro assembler for all PIC MCUs.

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging.

The MPASM Assembler features include:

- Integration into MPLAB IDE projects
- User-defined macros to streamline assembly code
- Conditional assembly for multi-purpose source files
- Directives that allow complete control over the assembly process

### 27.3 MPLAB C18 and MPLAB C30 C Compilers

The MPLAB C18 and MPLAB C30 Code Development Systems are complete ANSI C compilers for Microchip's PIC18 and PIC24 families of microcontrollers and the dsPIC30 and dsPIC33 family of digital signal controllers. These compilers provide powerful integration capabilities, superior code optimization and ease of use not found with other compilers.

For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger.

## 27.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler and the MPLAB C18 C Compiler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

# 27.5 MPLAB ASM30 Assembler, Linker and Librarian

MPLAB ASM30 Assembler produces relocatable machine code from symbolic assembly language for dsPIC30F devices. MPLAB C30 C Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- Support for the entire dsPIC30F instruction set
- Support for fixed-point and floating-point data
- · Command line interface
- Rich directive set
- Flexible macro language
- MPLAB IDE compatibility

## 27.6 MPLAB SIM Software Simulator

The MPLAB SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC<sup>®</sup> DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The MPLAB SIM Software Simulator fully supports symbolic debugging using the MPLAB C18 and MPLAB C30 C Compilers, and the MPASM and MPLAB ASM30 Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

## 27.11 PICSTART<sup>®</sup> Plus Development Programmer

The PICSTART<sup>®</sup> Plus Development Programmer is an easy-to-use, low-cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. The PICSTART Plus Development Programmer supports most PIC devices in DIP packages up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus Development Programmer is CE compliant.

## 27.12 PICkit<sup>™</sup> 2 Development Programmer

The PICkit<sup>™</sup> 2 Development Programmer is a low-cost programmer and selected Flash device debugger with an easy-to-use interface for programming many of Microchip's baseline, mid-range and PIC18F families of Flash memory microcontrollers. The PICkit 2 Starter Kit includes a prototyping development board, twelve sequential lessons, software and HI-TECH's PICC<sup>™</sup> Lite C compiler, and is designed to help get up to speed quickly using PIC<sup>®</sup> microcontrollers. The kit provides everything needed to program, evaluate and develop applications using Microchip's powerful, mid-range Flash memory family of microcontrollers.

## 27.13 Demonstration, Development and Evaluation Boards

A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM<sup>™</sup> and dsPICDEM<sup>™</sup> demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELOQ<sup>®</sup> security ICs, CAN, IrDA<sup>®</sup>, PowerSmart battery management, SEEVAL<sup>®</sup> evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more.

Check the Microchip web page (www.microchip.com) for the complete list of demonstration, development and evaluation kits.

## 28.2 DC Characteristics: Power-Down and Supply Current PIC18F6X27/6X22/8X27/8X22 (Industrial, Extended) PIC18LF6X27/6X22/8X27/8X22 (Industrial)

| PIC18LF<br>(Indus                                   | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |                          |                                                                                                                                                                                         |                      |            |                                    |  |  |
|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------|------------------------------------|--|--|
| PIC18F6X27/6X22/8X27/8X22<br>(Industrial, Extended) |                                                                                                                                    | <b>Standa</b><br>Operati | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |                      |            |                                    |  |  |
| Param<br>No.                                        | am Device                                                                                                                          |                          | Max                                                                                                                                                                                     | Units                | Conditions |                                    |  |  |
|                                                     | Power-Down Current (IPD) <sup>(1)</sup>                                                                                            |                          |                                                                                                                                                                                         |                      |            |                                    |  |  |
|                                                     | PIC18LF6X27/6X22/8X27/8X22                                                                                                         | 120                      | 700                                                                                                                                                                                     | nA                   | -40°C      |                                    |  |  |
|                                                     |                                                                                                                                    | 120                      | 700                                                                                                                                                                                     | nA                   | +25°C      | VDD = 2.0V<br>( <b>Sleen</b> mode) |  |  |
|                                                     |                                                                                                                                    | 0.24                     | 3.0                                                                                                                                                                                     | μΑ                   | +85°C      |                                    |  |  |
|                                                     | PIC18LF6X27/6X22/8X27/8X22                                                                                                         | 120                      | 900                                                                                                                                                                                     | nA                   | -40°C      |                                    |  |  |
|                                                     |                                                                                                                                    | 120                      | 900                                                                                                                                                                                     | nA                   | +25°C      | VDD = 3.0V<br>( <b>Sleen</b> mode) |  |  |
|                                                     |                                                                                                                                    | 0.36                     | 6                                                                                                                                                                                       | μA                   | +85°C      |                                    |  |  |
|                                                     | All devices                                                                                                                        | 0.12                     | 2                                                                                                                                                                                       | μA                   | -40°C      |                                    |  |  |
|                                                     |                                                                                                                                    |                          | 2                                                                                                                                                                                       | μΑ                   | +25°C      | VDD = 5.0V                         |  |  |
|                                                     |                                                                                                                                    | 0.48 9 μA +85°C          |                                                                                                                                                                                         | ( <b>Sleep</b> mode) |            |                                    |  |  |
|                                                     | Extended devices only                                                                                                              | 12                       | 100                                                                                                                                                                                     | μA                   | +125°C     |                                    |  |  |

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

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

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

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

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

MCLR = VDD; WDT enabled/disabled as specified.

- **3:** When operation below -10°C is expected, use T1OSC High-Power mode, where LPT1OSC (CONFIG3H<2>) = 0. When operation will always be above -10°C, then the low-power Timer1 oscillator may be selected.
- 4: BOR and HLVD enable internal band gap reference. With both modules enabled, current consumption will be less than the sum of both specifications.



| TABLE 28-11: P | <b>PROGRAM MEMORY WRITE TIMING REQUIREMENTS</b> |
|----------------|-------------------------------------------------|
|----------------|-------------------------------------------------|

| Param.<br>No | Symbol   | Characteristics                                                                   | Min           | Тур      | Мах | Units |
|--------------|----------|-----------------------------------------------------------------------------------|---------------|----------|-----|-------|
| 150          | TadV2alL | Address Out Valid to ALE $\downarrow$ (address setup time)                        | 0.25 Tcy - 10 | —        | —   | ns    |
| 151          | TalL2adl | ALE $\downarrow$ to Address Out Invalid (address hold time)                       | 5             | —        | —   | ns    |
| 153          | TwrH2adl | $\overline{WRn}$ $\uparrow$ to Data Out Invalid (data hold time)                  | 5             | _        |     | ns    |
| 154          | TwrL     | WRn Pulse Width                                                                   | 0.5 Tcy – 5   | 0.5 TCY  | _   | ns    |
| 156          | TadV2wrH | Data Valid before $\overline{WRn}$ $\uparrow$ (data setup time)                   | 0.5 Tcy – 10  | _        | _   | ns    |
| 157          | TbsV2wrL | Byte Select Valid before $\overline{WRn}\downarrow$ (byte select setup time)      | 0.25 TCY      | _        | —   | ns    |
| 157A         | TwrH2bsl | $\overline{\text{WRn}}$ $\uparrow$ to Byte Select Invalid (byte select hold time) | 0.125 Tcy – 5 | _        | _   | ns    |
| 166          | TalH2alH | ALE $\uparrow$ to ALE $\uparrow$ (cycle time)                                     | —             | 0.25 TCY |     | ns    |
| 171          | TalH2csL | Chip Enable Active to ALE $\downarrow$                                            | 0.25 Tcy – 20 | —        | —   | ns    |
| 171A         | TubL2oeH | AD Valid to Chip Enable Active                                                    | _             |          | 10  | ns    |



#### TABLE 28-24: EUSART SYNCHRONOUS TRANSMISSION REQUIREMENTS

| Param<br>No. | Symbol   | Characteristic                    |             |   | Мах | Units | Conditions |
|--------------|----------|-----------------------------------|-------------|---|-----|-------|------------|
| 120          | TCKH2DTV | SYNC XMIT (MASTER and SLAVE)      |             |   |     |       |            |
|              |          | Clock High to Data Out Valid      | PIC18FXXXX  |   | 40  | ns    |            |
|              |          |                                   | PIC18LFXXXX |   | 100 | ns    | VDD = 2.0V |
| 121          | TCKRF    | Clock Out Rise Time and Fall Time | PIC18FXXXX  |   | 20  | ns    |            |
|              |          | (Master mode)                     | PIC18LFXXXX | - | 50  | ns    | VDD = 2.0V |
| 122          | Tdtrf    | Data Out Rise Time and Fall Time  | PIC18FXXXX  | - | 20  | ns    |            |
|              |          |                                   | PIC18LFXXXX |   | 50  | ns    | VDD = 2.0V |

#### FIGURE 28-24: EUSART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING



#### TABLE 28-25: EUSART SYNCHRONOUS RECEIVE REQUIREMENTS

| Param.<br>No. | Symbol   | Characteristic                                                                   | Min | Мах | Units | Conditions |
|---------------|----------|----------------------------------------------------------------------------------|-----|-----|-------|------------|
| 125           | TDTV2CKL | SYNC RCV (MASTER and SLAVE)<br>Data Hold before CKx $\downarrow$ (DTx hold time) | 10  |     | ns    |            |
| 126           | TCKL2DTL | Data Hold after $CKx \downarrow (DTx hold time)$                                 | 15  | _   | ns    |            |