



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

| Details                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 48MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 17                                                                         |
| Program Memory Size        | 16KB (8K x 16)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 512 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 12x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Through Hole                                                               |
| Package / Case             | 20-DIP (0.300", 7.62mm)                                                    |
| Supplier Device Package    | 20-PDIP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf14k22-e-p |
|                            |                                                                            |

Email: info@E-XFL.COM

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

#### 1.2 Other Special Features

- **Memory Endurance:** The Flash cells for both program memory and data EEPROM are rated to last for many thousands of erase/write cycles up to 10K for program memory and 100K for EEPROM. Data retention without refresh is conservatively estimated to be greater than 40 years.
- Self-programmability: These devices can write to their own program memory spaces under internal software control. Using a bootloader routine located in the code protected Boot Block, it is possible to create an application that can update itself in the field.
- Extended Instruction Set: The PIC18(L)F1XK22 family introduces an optional extension to the PIC18 instruction set, which adds eight new instructions and an Indexed Addressing mode. This extension has been specifically designed to optimize re-entrant application code originally developed in high-level languages, such as C.
- Enhanced CCP module: In PWM mode, this module provides one, two or four modulated outputs for controlling half-bridge and full-bridge drivers. Other features include:
  - Auto-Shutdown, for disabling PWM outputs on interrupt or other select conditions
  - Auto-Restart, to reactivate outputs once the condition has cleared
  - Output steering to selectively enable one or more of four outputs to provide the PWM signal.
- Enhanced Addressable USART: This serial communication module is capable of standard RS-232 operation and provides support for the LIN bus protocol. Other enhancements include automatic baud rate detection and a 16-bit Baud Rate Generator for improved resolution.
- **10-bit A/D Converter:** This module incorporates programmable acquisition time, allowing for a channel to be selected and a conversion to be initiated without waiting for a sampling period and thus, reduce code overhead.
- Extended Watchdog Timer (WDT): This enhanced version incorporates a 16-bit postscaler, allowing an extended time-out range that is stable across operating voltage and temperature. See Section 26.0 "Electrical Specifications" for time-out periods.

#### 1.3 Details on Individual Family Members

Devices in the PIC18(L)F1XK22 family are available in 20-pin packages. Block diagrams for the two groups are shown in Figure 1-1.

The devices are differentiated from each other in the following ways:

- 1. Flash program memory:
  - 8 Kbytes for PIC18(L)F13K22
  - 16 Kbytes for PIC18(L)F14K22

All other features for devices in this family are identical. These are summarized in Table 1-1.

The pinouts for all devices are listed in Table 1 and I/O description are in Table 1-2.

#### **TABLE 1-2:** PIC18(L)F1XK22 PIN SUMMARY

|                                                                                                    | Pir<br>Num         |     |                                |                                                         |                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------------------------------|--------------------|-----|--------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name                                                                                           | PDIP/SSOP/<br>SOIC | QFN | Pin<br>Type                    | Buffer<br>Type                                          | Description                                                                                                                                                                                                                                      |
| RA0/AN0/CVREF/VREF-/C1IN+/INT0/PGD<br>RA0<br>AN0<br>CVREF/DAC1OUT<br>VREF-<br>C1IN+<br>INT0<br>PGD | 19                 | 16  | I/O<br>I<br>0<br>I<br>I<br>I/O | TTL<br>Analog<br>Analog<br>Analog<br>Analog<br>ST<br>ST | Digital I/O<br>ADC channel 0<br>DAC reference voltage output<br>ADC and DAC reference voltage (low) input<br>Comparator C1 noninverting input<br>External interrupt 0<br>ICSP™ programming data pin                                              |
| RA1/AN1/C12IN0-/VREF+/INT1/PGC<br>RA1<br>AN1<br>C12IN0-<br>VREF+<br>INT1<br>PGC                    | 18                 | 15  | I/O<br>I<br>1<br>I<br>I/O      | TTL<br>Analog<br>Analog<br>Analog<br>ST<br>ST           | Digital I/O<br>ADC channel 1<br>Comparator C1 and C2 inverting input<br>ADC and DAC reference voltage (high) input<br>External interrupt 1<br>ICSP programming clock pin                                                                         |
| RA2/AN2/C1OUT/T0CKI/INT2/SRQ<br>RA2<br>AN2<br>C1OUT<br>T0CKI<br>INT2<br>SRQ                        | 17                 | 14  | I/O<br> <br> <br> <br>0        | ST<br>Analog<br>CMOS<br>ST<br>ST<br>CMOS                | Digital I/O<br>ADC channel 2<br>Comparator C1 output<br>Timer0 external clock input<br>External interrupt 2<br>SR latch output                                                                                                                   |
| RA3/MCLR/VPP<br>RA3<br>MCLR<br>VPP                                                                 | 4                  | 1   | I<br>I<br>P                    | ST<br>ST                                                | Digital input<br>Active-low Master Clear with internal pull-up<br>High voltage programming input                                                                                                                                                 |
| RA4/AN3/OSC2/CLKOUT<br>RA4<br>AN3<br>OSC2<br>CLKOUT                                                | 3                  | 20  | I/O<br>I<br>O                  | TTL<br>Analog<br>XTAL<br>CMOS                           | Digital I/O<br>ADC channel 3<br>Oscillator crystal output. Connect to crystal or resonator<br>in Crystal Oscillator mode<br>In RC mode, OSC2 pin outputs CLKOUT which<br>has 1/4 the frequency of OSC1 and denotes<br>the instruction cycle rate |
| RA5/OSC1/CLKIN/T13CKI<br>RA5<br>OSC1                                                               | 2                  | 19  | I/O<br>I                       | TTL<br>XTAL                                             | Digital I/O<br>Oscillator crystal input or external clock input<br>ST buffer when configured in RC mode; analog other<br>wise                                                                                                                    |
| CLKIN<br>T13CKI                                                                                    |                    |     |                                | CMOS<br>ST                                              | External clock source input. Always associated with the<br>pin function OSC1 (See related OSC1/CLKIN, OSC2,<br>CLKOUT pins<br>Timer0 and Timer3 external clock input                                                                             |
| RB4/AN10/SDI/SDA<br>RB4<br>AN10<br>SDI<br>SDA                                                      | 13                 | 10  | I/O<br>I<br>I/O                | TTL<br>Analog<br>ST<br>ST                               | Digital I/O<br>ADC channel 10<br>SPI data in<br>I <sup>2</sup> C data I/O                                                                                                                                                                        |
| Legend: TTL = TTL compatible input<br>ST = Schmitt Trigger input<br>O = Output                     | I                  | 1   |                                | CM <sup>i</sup><br>I<br>P                               |                                                                                                                                                                                                                                                  |

XTAL= Crystal Oscillator

#### 2.12 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the device to continue operating should the external oscillator fail. The FSCM can detect oscillator failure any time after the Oscillator Start-up Timer (OST) has expired. The FSCM is enabled by setting the FCMEN bit in the CONFIG1H Configuration register. The FSCM is applicable to all external oscillator modes (LP, XT, HS, EC and RC).

FIGURE 2-6: FSCM BLOCK DIAGRAM



#### 2.12.1 FAIL-SAFE DETECTION

The FSCM module detects a failed oscillator by comparing the external oscillator to the FSCM sample clock. The sample clock is generated by dividing the LFINTOSC by 64. See Figure 2-6. Inside the fail detector block is a latch. The external clock sets the latch on each falling edge of the external clock. The sample clock clears the latch on each rising edge of the sample clock. A failure is detected when an entire half-cycle of the sample clock elapses before the primary clock goes low.

#### 2.12.2 FAIL-SAFE OPERATION

When the external clock fails, the FSCM switches the device clock to an internal clock source and sets the bit flag OSCFIF of the PIR2 register. The OSCFIF flag will generate an interrupt if the OSCFIE bit of the PIE2 register is also set. The device firmware can then take steps to mitigate the problems that may arise from a failed clock. The system clock will continue to be sourced from the internal clock source until the device firmware successfully restarts the external oscillator and switches back to external operation. An automatic transition back to the failed clock source will not occur.

The internal clock source chosen by the FSCM is determined by the IRCF<2:0> bits of the OSCCON register. This allows the internal oscillator to be configured before a failure occurs.

#### 2.12.3 FAIL-SAFE CONDITION CLEARING

The Fail-Safe condition is cleared by either one of the following:

- Any Reset
- · By toggling the SCS1 bit of the OSCCON register

Both of these conditions restart the OST. While the OST is running, the device continues to operate from the INTOSC selected in OSCCON. When the OST times out, the Fail-Safe condition is cleared and the device automatically switches over to the external clock source. The Fail-Safe condition need not be cleared before the OSCFIF flag is cleared.

#### 2.12.4 RESET OR WAKE-UP FROM SLEEP

The FSCM is designed to detect an oscillator failure after the Oscillator Start-up Timer (OST) has expired. The OST is used after waking up from Sleep and after any type of Reset. The OST is not used with the EC or RC Clock modes so that the FSCM will be active as soon as the Reset or wake-up has completed. When the FSCM is enabled, the Two-Speed Start-up is also enabled. Therefore, the device will always be executing code while the OST is operating.

Note: Due to the wide range of oscillator start-up times, the Fail-Safe circuit is not active during oscillator start-up (i.e., after exiting Reset or Sleep). After an appropriate amount of time, the user should check the OSTS bit of the OSCCON register to verify the oscillator start-up and that the system clock switchover has successfully completed.

## PIC18(L)F1XK22





### 4.2 Control Registers

Several control registers are used in conjunction with the TBLRD and TBLWT instructions. These include the:

- · EECON1 register
- EECON2 register
- TABLAT register
- TBLPTR registers

#### 4.2.1 EECON1 AND EECON2 REGISTERS

The EECON1 register (Register 4-1) is the control register for memory accesses. The EECON2 register is not a physical register; it is used exclusively in the memory write and erase sequences. Reading EECON2 will read all '0's.

The EEPGD control bit determines if the access will be a program or data EEPROM memory access. When EEPGD is clear, any subsequent operations will operate on the data EEPROM memory. When EEPGD is set, any subsequent operations will operate on the program memory.

The CFGS control bit determines if the access will be to the Configuration/Calibration registers or to program memory/data EEPROM memory. When CFGS is set, subsequent operations will operate on Configuration registers regardless of EEPGD (see **Section 23.0 "Special Features of the CPU"**). When CFGS is clear, memory selection access is determined by EEPGD. The FREE bit allows the program memory erase operation. When FREE is set, an erase operation is initiated on the next WR command. When FREE is clear, only writes are enabled.

The WREN bit, when set, will allow a write operation. The WREN bit is clear on power-up.

The WRERR bit is set by hardware when the WR bit is set and cleared when the internal programming timer expires and the write operation is complete.

| Note: | During normal operation, the WRERR is       |  |  |  |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|--|--|--|
|       | read as '1'. This can indicate that a write |  |  |  |  |  |  |  |  |
|       | operation was prematurely terminated by     |  |  |  |  |  |  |  |  |
|       | a Reset, or a write operation was           |  |  |  |  |  |  |  |  |
|       | attempted improperly.                       |  |  |  |  |  |  |  |  |

The WR control bit initiates write operations. The WR bit cannot be cleared, only set, by firmware. Then WR bit is cleared by hardware at the completion of the write operation.

Note: The EEIF interrupt flag bit of the PIR2 register is set when the write is complete. The EEIF flag stays set until cleared by firmware.

#### 8.2 PORTB, TRISB and LATB Registers

PORTB is an 4-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., disable the output driver). Clearing a TRISB bit (= 0) will make the corresponding PORTB pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin).

The PORTB 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.

EXAMPLE 8-2: INITIALIZING PORTB

| CLRF  | PORTB | ; | Initialize PORTB by    |
|-------|-------|---|------------------------|
|       |       | ; | clearing output        |
|       |       | ; | data latches           |
| CLRF  | LATB  | ; | Alternate method       |
|       |       | ; | to clear output        |
|       |       | ; | data latches           |
| MOVLW | 0F0h  | ; | Value used to          |
|       |       | ; | initialize data        |
|       |       | ; | direction              |
| MOVWF | TRISB | ; | Set RB<7:4> as outputs |
|       |       |   |                        |

All PORTB pins are individually configurable as interrupt-on-change pins. Control bits in the IOCB register enable (when set) or disable (when clear) the interrupt function for each pin.

When set, the RABIE bit of the INTCON register enables interrupts on all pins which also have their corresponding IOCB bit set. When clear, the RABIE bit disables all interrupt-on-changes.

Only pins configured as inputs can cause this interrupt to occur (i.e., any pin configured as an output is excluded from the interrupt-on-change comparison).

For enabled interrupt-on-change pins, the values are compared with the old value latched on the last read of PORTB. The 'mismatch' outputs of the last read are OR'd together to set the PORTB Change Interrupt flag bit (RABIF) in the INTCON register.

This interrupt can wake the device from the 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 to clear the mismatch condition (except when PORTB is the source or destination of a MOVFF instruction).
- b) Clear the flag bit, RABIF.

A mismatch condition will continue to set the RABIF flag bit. Reading or writing PORTB will end the mismatch condition and allow the RABIF bit to be cleared. The latch holding the last read value is not affected by a MCLR nor Brown-out Reset. After either one of these Resets, the RABIF flag will continue to be set if a mismatch is present.

Note: If a change on the I/O pin should occur when the read operation is being executed (start of the Q2 cycle), then the RABIF interrupt flag may not get set. Furthermore, since a read or write on a port affects all bits of that port, care must be taken when using multiple pins in Interrupt-on-Change mode. Changes on one pin may not be seen while servicing changes on another pin.

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.

All PORTB pins have individually controlled weak internal pull-up. When set, each bit of the WPUB register enables the corresponding pin pull-up. When cleared, the RABPU bit of the INTCON2 register enables pull-ups on all pins which also have their corresponding WPUB bit set. When set, the RABPU bit disables all weak pull-ups. 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<5:4> are configured as analog inputs by default and read as '0'.

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



#### 9.3 Prescaler

An 8-bit counter is available as a prescaler for the Timer0 module. The prescaler is not directly readable or writable; its value is set by the PSA and T0PS<2:0> bits of the T0CON register which determine the prescaler assignment and prescale ratio.

Clearing the PSA bit assigns the prescaler to the Timer0 module. When the prescaler is assigned, prescale values from 1:2 through 1:256 in integer power-of-2 increments are selectable.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g., CLRF TMR0, MOVWF TMR0, BSF TMR0, etc.) clear the prescaler count.

**Note:** Writing to TMR0 when the prescaler is assigned to Timer0 will clear the prescaler count but will not change the prescaler assignment.

#### 9.3.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control and can be changed "on-the-fly" during program execution.

#### 9.4 Timer0 Interrupt

The TMR0 interrupt is generated when the TMR0 register overflows from FFh to 00h in 8-bit mode, or from FFFFh to 0000h in 16-bit mode. This overflow sets the TMR0IF flag bit. The interrupt can be masked by clearing the TMR0IE bit of the INTCON register. Before re-enabling the interrupt, the TMR0IF bit must be cleared by software in the Interrupt Service Routine.

Since Timer0 is shut down in Sleep mode, the TMR0 interrupt cannot awaken the processor from Sleep.

|                                 |                                        | Bit 5                                                                            | Bit 4                                                          | Bit 3                                                                                        | Bit 2                                                                                                  | Bit 1                                                                                                                | Bit 0                                                                                                                              | Values<br>on page                                                                                                                                |
|---------------------------------|----------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| IE/GIEH                         | PEIE/GIEL                              | TMR0IE                                                                           | INT0IE                                                         | RABIE                                                                                        | TMR0IF                                                                                                 | <b>INT0IF</b>                                                                                                        | RABIF                                                                                                                              | 245                                                                                                                                              |
| RA7                             | RA6                                    | RA5                                                                              | RA4                                                            | RA3                                                                                          | RA2                                                                                                    | RA1                                                                                                                  | RA0                                                                                                                                | 248                                                                                                                                              |
| Timer0 Register, High Byte      |                                        |                                                                                  |                                                                |                                                                                              |                                                                                                        |                                                                                                                      | 246                                                                                                                                |                                                                                                                                                  |
| TMR0L Timer0 Register, Low Byte |                                        |                                                                                  |                                                                |                                                                                              |                                                                                                        |                                                                                                                      | 246                                                                                                                                |                                                                                                                                                  |
|                                 | _                                      | TRISA5                                                                           | TRISA4                                                         | _(1)                                                                                         | TRISA2                                                                                                 | TRISA1                                                                                                               | TRISA0                                                                                                                             | 248                                                                                                                                              |
| MR0ON                           | T08BIT                                 | TOCS                                                                             | TOSE                                                           | PSA                                                                                          | T0PS2                                                                                                  | T0PS1                                                                                                                | T0PS0                                                                                                                              | 246                                                                                                                                              |
| n<br>n                          | RA7<br>ner0 Regi<br>ner0 Regi<br>MR0ON | RA7 RA6<br>her0 Register, High B<br>her0 Register, Low By<br>— —<br>MR00N T08BIT | RA7RA6RA5her0 Register, High Byteher0 Register, Low ByteTRISA5 | RA7RA6RA5RA4ner0 Register, High Bytener0 Register, Low Byte——TRISA5TRISA4MR0ONT08BITT0CST0SE | RA7RA6RA5RA4RA3ner0 Register, High Bytener0 Register, Low Byte——TRISA5TRISA4_(1)MR0ONT08BITT0CST0SEPSA | RA7RA6RA5RA4RA3RA2ner0 Register, High Bytener0 Register, Low Byte——TRISA5TRISA4—(1)TRISA2MR0ONT08BITT0CST0SEPSAT0PS2 | RA7RA6RA5RA4RA3RA2RA1ner0 Register, High Bytener0 Register, Low Byte——TRISA5TRISA4—(1)TRISA2TRISA1MR0ONT08BITT0CST0SEPSAT0PS2T0PS1 | RA7RA6RA5RA4RA3RA2RA1RA0ner0 Register, High Bytener0 Register, Low Byte——TRISA5TRISA4—(1)TRISA2TRISA1TRISA0MR0ONT08BITT0CST0SEPSAT0PS2T0PS1T0PS0 |

Legend: Shaded cells are not used by Timer0.

Note: Unimplemented, read as'1'.

#### 10.2 Timer1 16-Bit Read/Write Mode

Timer1 can be configured for 16-bit reads and writes (see Figure 10-2). When the RD16 control bit of the T1CON register is set, the address for TMR1H is mapped to a buffer register for the high byte of Timer1. A read from TMR1L will load the contents of the high byte of Timer1 into the Timer1 high byte buffer. This provides the user with the ability to accurately read all 16 bits of Timer1 without the need to determine whether a read of the high byte, followed by a read of the low byte, has become invalid due to a rollover or carry between reads.

Writing to TMR1H does not directly affect Timer1. Instead, the high byte of Timer1 is updated with the contents of TMR1H when a write occurs to TMR1L. This allows all 16 bits of Timer1 to be updated at once.

The high byte of Timer1 is not directly readable or writable in this mode. All reads and writes must take place through the Timer1 High Byte Buffer register. Writes to TMR1H do not clear the Timer1 prescaler. The prescaler is only cleared on writes to TMR1L.

#### **10.3 Clock Source Selection**

The TMR1CS bit of the T1CON register is used to select the clock source. When TMR1CS = 0, the clock source is FOSC/4. When TMR1CS = 1, the clock source is supplied externally.

| Clock<br>Source | T1OSCEN | FOSC<br>Mode | TMR1CS |
|-----------------|---------|--------------|--------|
| Fosc/4          | х       | XXX          | 0      |
| T1CKI pin       | 0       | xxx          | 1      |
| T1LPOSC         | 1       | LP or        | 1      |
|                 |         | INTOSCIO     |        |

#### 10.3.1 INTERNAL CLOCK SOURCE

When the internal clock source is selected the TMR1H:TMR1L register pair will increment on multiples of Fosc as determined by the Timer1 prescaler.

#### 10.3.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When counting, Timer1 is incremented on the rising edge of the external clock input T1CKI. In addition, the Counter mode clock can be synchronized to the microcontroller system clock or run asynchronously. If an external clock oscillator is needed (and the microcontroller is using the INTOSC without CLKOUT), Timer1 can use the LP oscillator as a clock source.

| Note:                                                                                                                                                                                  | In Counter mode, a falling edge must be<br>registered by the counter prior to the first<br>incrementing rising edge after any one or<br>more of the following conditions: |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| <ul> <li>Timer1 enabled after POR</li> <li>Write to TMR1H or TMR1L</li> <li>Timer1 is disabled</li> <li>Timer1 is disabled (TMR1ON 0)<br/>when T1CKI is high then Timer1 is</li> </ul> |                                                                                                                                                                           |  |  |  |
| Note:                                                                                                                                                                                  | enabled (TMR1ON= 1) when T1CKI<br>is low.<br>See Figure 9-2.                                                                                                              |  |  |  |

#### 10.4 Timer1 Oscillator

An on-chip crystal oscillator circuit is incorporated between pins OSC1 (input) and OSC2 (amplifier output). It is enabled by setting the Timer1 Oscillator Enable bit, T1OSCEN of the T1CON register. The oscillator is a low-power circuit rated for 32 kHz crystals. It will continue to run during all power-managed modes. The circuit for a typical LP oscillator is shown in Figure 10-3. Table 10-1 shows the capacitor selection for the Timer1 oscillator.

The Timer1 oscillator is shared with the system LP oscillator. Thus, Timer1 can use this mode only when the primary system clock is derived from the internal oscillator or when the oscillator is in the LP mode. The user must provide a software time delay to ensure proper oscillator start-up.

#### FIGURE 10-3: EXTERNAL COMPONENTS FOR THE TIMER1 LP OSCILLATOR



### 11.0 TIMER2 MODULE

The Timer2 module timer incorporates the following features:

- 8-bit timer and period registers (TMR2 and PR2, respectively)
- · Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4 and 1:16)
- Software programmable postscaler (1:1 through 1:16)
- Interrupt on TMR2-to-PR2 match
- Optional use as the shift clock for the MSSP module

The module is controlled through the T2CON register (Register 11-1), which enables or disables the timer and configures the prescaler and postscaler. Timer2 can be shut off by clearing control bit, TMR2ON of the T2CON register, to minimize power consumption.

A simplified block diagram of the module is shown in Figure 11-1.

#### 11.1 Timer2 Operation

In normal operation, TMR2 is incremented from 00h on each clock (FOSC/4). A 4-bit counter/prescaler on the clock input gives direct input, divide-by-4 and divide-by-16 prescale options; these are selected by the prescaler control bits, T2CKPS<1:0> of the T2CON register. The value of TMR2 is compared to that of the period register, PR2, on each clock cycle. When the two values match, the comparator generates a match signal as the timer output. This signal also resets the value of TMR2 to 00h on the next cycle and drives the output counter/postscaler (see **Section 11.2 "Timer2 Interrupt"**).

The TMR2 and PR2 registers are both directly readable and writable. The TMR2 register is cleared on any device Reset, whereas the PR2 register initializes to FFh. Both the prescaler and postscaler counters are cleared on the following events:

- a write to the TMR2 register
- a write to the T2CON register
- any device Reset (Power-on Reset, MCLR Reset, Watchdog Timer Reset or Brown-out Reset)

TMR2 is not cleared when T2CON is written.

| U-0             | R/W-0               | R/W-0            | R/W-0          | R/W-0            | R/W-0            | R/W-0           | R/W-0   |
|-----------------|---------------------|------------------|----------------|------------------|------------------|-----------------|---------|
|                 | T2OUTPS3            | T2OUTPS2         | T2OUTPS1       | T2OUTPS0         | TMR2ON           | T2CKPS1         | T2CKPS0 |
| bit 7           |                     |                  |                |                  |                  |                 | bit 0   |
|                 |                     |                  |                |                  |                  |                 |         |
| Legend:         |                     |                  |                |                  |                  |                 |         |
| R = Readable    | bit                 | W = Writable     | bit            | U = Unimpler     | nented bit, read | l as '0'        |         |
| -n = Value at P | POR                 | '1' = Bit is set |                | '0' = Bit is cle | ared             | x = Bit is unkr | nown    |
|                 |                     |                  |                |                  |                  |                 |         |
| bit 7           | Unimplemen          | ted: Read as '   | כי             |                  |                  |                 |         |
| bit 6-3         | T2OUTPS<3:          | 0>: Timer2 Out   | tput Postscale | Select bits      |                  |                 |         |
|                 | 0000 = 1:1 Po       | ostscale         |                |                  |                  |                 |         |
|                 | 0001 <b>= 1:2 P</b> | ostscale         |                |                  |                  |                 |         |
|                 | •                   |                  |                |                  |                  |                 |         |
|                 | •                   |                  |                |                  |                  |                 |         |
|                 | 1111 = 1:16 F       | Postscale        |                |                  |                  |                 |         |
| bit 2           | TMR2ON: Tin         | ner2 On bit      |                |                  |                  |                 |         |
|                 | 1 = Timer2 is       | on               |                |                  |                  |                 |         |
|                 | 0 = Timer2 is       | off              |                |                  |                  |                 |         |
| bit 1-0         | T2CKPS<1:0          | >: Timer2 Cloc   | k Prescale Se  | lect bits        |                  |                 |         |
|                 | 00 = Prescale       |                  |                |                  |                  |                 |         |
|                 | 01 = Prescale       | -                |                |                  |                  |                 |         |
|                 | 1x = Prescale       | er is 16         |                |                  |                  |                 |         |

#### REGISTER 11-1: T2CON: TIMER2 CONTROL REGISTER

In addition to the expanded range of modes available through the CCP1CON register and ECCP1AS register, the ECCP module has two additional registers associated with Enhanced PWM operation and auto-shutdown features. They are:

- PWM1CON (Dead-band delay)
- PSTRCON (Output steering)

#### **13.1 ECCP Outputs and Configuration**

The enhanced CCP module may have up to four PWM outputs, depending on the selected operating mode. These outputs, designated P1A through P1D, are multiplexed with I/O pins on PORTC. The outputs that are active depend on the CCP operating mode selected. The pin assignments are summarized in Table 13-2.

To configure the I/O pins as PWM outputs, the proper PWM mode must be selected by setting the P1M<1:0> and CCP1M<3:0> bits. The appropriate TRISC direction bits for the port pins must also be set as outputs.

#### 13.1.1 CCP MODULE AND TIMER RESOURCES

The CCP modules utilize Timers 1, 2 or 3, depending on the mode selected. Timer1 and Timer3 are available to modules in Capture or Compare modes, while Timer2 is available for modules in PWM mode.

## TABLE 13-1:CCP MODE – TIMER<br/>RESOURCE

| CCP/ECCP Mode | Timer Resource   |
|---------------|------------------|
| Capture       | Timer1 or Timer3 |
| Compare       | Timer1 or Timer3 |
| PWM           | Timer2           |

The assignment of a particular timer to a module is determined by the Timer-to-CCP enable bits in the T3CON register (Register 12-1). The interactions between the two modules are summarized in Figure 13-1. In Asynchronous Counter mode, the capture operation will not work reliably.

#### 13.2 Capture Mode

In Capture mode, the CCPR1H:CCPR1L register pair captures the 16-bit value of the TMR1 or TMR3 registers when an event occurs on the corresponding CCP1 pin. An event is defined as one of the following:

- Every falling edge
- Every rising edge
- · Every 4th rising edge
- · Every 16th rising edge

The event is selected by the mode select bits, CCP1M<3:0> of the CCP1CON register. When a capture is made, the interrupt request flag bit, CCP1IF, is set; it must be cleared by software. If another capture occurs before the value in register CCPR1 is read, the old captured value is overwritten by the new captured value.

#### 13.2.1 CCP PIN CONFIGURATION

In Capture mode, the appropriate CCP1 pin should be configured as an input by setting the corresponding TRIS direction bit.

**Note:** If the CCP1 pin is configured as an output, a write to the port can cause a capture condition.

#### 13.2.2 TIMER1/TIMER3 MODE SELECTION

The timers that are to be used with the capture feature (Timer1 and/or Timer3) must be running in Timer mode or Synchronized Counter mode. In Asynchronous Counter mode, the capture operation may not work. The timer to be used with each CCP module is selected in the T3CON register (see Section 13.1.1 "CCP Module and Timer Resources").

#### 13.2.3 SOFTWARE INTERRUPT

When the Capture mode is changed, a false capture interrupt may be generated. The user should keep the CCP1IE interrupt enable bit clear to avoid false interrupts. The interrupt flag bit, CCP1IF, should also be cleared following any such change in operating mode.

## FIGURE 13-4: EXAMPLE PWM (ENHANCED MODE) OUTPUT RELATIONSHIPS (ACTIVE-HIGH STATE)

| P1M<  | <1:0>                     | Signal                                                                    | 0 ◀          | Pulse<br>Width |                       | 1                     |
|-------|---------------------------|---------------------------------------------------------------------------|--------------|----------------|-----------------------|-----------------------|
|       |                           |                                                                           | -            |                | Period                |                       |
| 00    | (Single Output)           | P1A Modulated                                                             | <br>Delay    |                | Delay <sup>(1)</sup>  | Į                     |
|       |                           | P1A Modulated                                                             |              |                |                       | ;                     |
| 10    | (Half-Bridge)             | P1B Modulated                                                             |              |                |                       | <u>\</u>              |
|       |                           | P1A Active                                                                | - :          |                |                       | <br>                  |
| 01    | (Full-Bridge,<br>Forward) | P1B Inactive                                                              | - ¦          |                | 1<br>1<br>1           |                       |
| 01    |                           | P1C Inactive                                                              | _ ;<br>;     |                |                       |                       |
|       |                           | P1D Modulated                                                             |              |                |                       |                       |
|       | (Full-Bridge,<br>Reverse) | P1A Inactive                                                              | - :          |                | 1<br>1                |                       |
| 11    |                           | P1B Modulated                                                             |              |                |                       |                       |
|       |                           | P1C Active                                                                | - ;          |                |                       | <br>i<br>i            |
|       |                           | P1D Inactive                                                              | _ '          |                | 1<br>1<br>1           | <u>_</u>              |
| Relat | • Pulse Width = To        | c * (PR2 + 1) * (TMR2 Pre<br>DSC * (CCPR1L<7:0>:CCP<br>2 * (PWM1CON<6:0>) |              | (TMR2 Prescal  | e Value)              | ·                     |
| No    |                           |                                                                           | using the PW | M1CON registe  | er (Section 13.4.6 "P | rogrammable Dead-Band |

#### 13.4.7.1 Steering Synchronization

The STRSYNC bit of the PSTRCON register gives the user two selections of when the steering event will happen. When the STRSYNC bit is '0', the steering event will happen at the end of the instruction that writes to the PSTRCON register. In this case, the output signal at the P1<D:A> pins may be an incomplete PWM waveform. This operation is useful when the user firmware needs to immediately remove a PWM signal from the pin.

When the STRSYNC bit is '1', the effective steering update will happen at the beginning of the next PWM period. In this case, steering on/off the PWM output will always produce a complete PWM waveform.

Figures 13-17 and 13-18 illustrate the timing diagrams of the PWM steering depending on the STRSYNC setting.

#### FIGURE 13-17: EXAMPLE OF STEERING EVENT AT END OF INSTRUCTION (STRSYNC = 0)



#### FIGURE 13-18: EXAMPLE OF STEERING EVENT AT BEGINNING OF INSTRUCTION (STRSYNC = 1)



### 14.2.8 OPERATION IN POWER-MANAGED MODES

In SPI Master mode, module clocks may be operating at a different speed than when in Full Power mode; in the case of the Sleep mode, all clocks are halted.

In all Idle modes, a clock is provided to the peripherals. That clock could be from the primary clock source, the secondary clock (Timer1 oscillator at 32.768 kHz) or the INTOSC source. See **Section 18.0 "Power-Managed Modes"** for additional information.

In most cases, the speed that the master clocks SPI data is not important; however, this should be evaluated for each system.

When MSSP interrupts are enabled, after the master completes sending data, an MSSP interrupt will wake the controller:

- From Sleep, in Slave mode
- From Idle, in Slave or Master mode

If an exit from Sleep or Idle mode is not desired, MSSP interrupts should be disabled.

In SPI Master mode, when the Sleep mode is selected, all module clocks are halted and the transmission/reception will remain in that state until the device wakes. After the device returns to Run mode, the module will resume transmitting and receiving data.

In SPI Slave mode, the SPI Transmit/Receive Shift register operates asynchronously to the device. This allows the device to be placed in any Power-Managed mode and data to be shifted into the SPI Transmit/Receive Shift register. When all eight bits have been received, the MSSP interrupt flag bit will be set and if enabled, will wake the device.

#### 14.2.9 EFFECTS OF A RESET

A Reset disables the MSSP module and terminates the current transfer.

#### 14.2.10 BUS MODE COMPATIBILITY

Table 14-1 shows the compatibility between the standard SPI modes and the states of the CKP and CKE control bits.

| TABLE 14-1: | SPI BUS MODES |
|-------------|---------------|
|-------------|---------------|

| Standard SPI Mode | Control Bits State |     |  |  |  |
|-------------------|--------------------|-----|--|--|--|
| Terminology       | СКР                | CKE |  |  |  |
| 0, 0              | 0                  | 1   |  |  |  |
| 0, 1              | 0                  | 0   |  |  |  |
| 1, 0              | 1                  | 1   |  |  |  |
| 1, 1              | 1                  | 0   |  |  |  |

There is also an SMP bit which controls when the data is sampled.

| TABLE 14-2. REGISTERS ASSOCIATED WITH SPTOPERATION |           |               |             |        |        |        |        |        |                            |
|----------------------------------------------------|-----------|---------------|-------------|--------|--------|--------|--------|--------|----------------------------|
| 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 | RABIE  | TMR0IF | INT0IF | RABIF  | 245                        |
| IPR1                                               | —         | ADIP          | RCIP        | TXIP   | SSPIP  | CCP1IP | TMR2IP | TMR1IP | 248                        |
| PIE1                                               | —         | ADIE          | RCIE        | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 248                        |
| PIR1                                               | —         | ADIF          | RCIF        | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 248                        |
| TRISB                                              | TRISB7    | TRISB6        | TRISB5      | TRISB4 | —      | _      | _      | _      | 248                        |
| TRISC                                              | TRISC7    | TRISC6        | TRISC5      | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 248                        |
| SSPBUF                                             | SSP Recei | ve Buffer/Tra | ansmit Regi | ster   |        |        |        |        | 246                        |
| SSPCON1                                            | WCOL      | SSPOV         | SSPEN       | CKP    | SSPM3  | SSPM2  | SSPM1  | SSPM0  | 246                        |
| SSPSTAT                                            | SMP       | CKE           | D/A         | Р      | S      | R/W    | UA     | BF     | 246                        |

 TABLE 14-2:
 REGISTERS ASSOCIATED WITH SPI OPERATION

Legend: Shaded cells are not used by the MSSP in SPI mode.

#### 14.3.6 MASTER MODE

Master mode is enabled by setting and clearing the appropriate SSPM bits in SSPCON1 and by setting the SSPEN bit. In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.

Master mode of operation is supported by interrupt generation on the detection of the Start and Stop conditions. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the  $I^2C$  bus may be taken when the P bit is set, or the bus is Idle, with both the S and P bits clear.

In Firmware Controlled Master mode, user code conducts all  $I^2C$  bus operations based on Start and Stop bit conditions.

Once Master mode is enabled, the user has six options.

- 1. Assert a Start condition on SDA and SCL.
- 2. Assert a Repeated Start condition on SDA and SCL.
- 3. Write to the SSPBUF register initiating transmission of data/address.
- 4. Configure the I<sup>2</sup>C port to receive data.
- 5. Generate an Acknowledge condition at the end of a received byte of data.
- 6. Generate a Stop condition on SDA and SCL.

Note: The MSSP module, when configured in I<sup>2</sup>C Master mode, does not allow queueing of events. For instance, the user is not allowed to initiate a Start condition and immediately write the SSPBUF register to initiate transmission before the Start condition is complete. In this case, the SSPBUF will not be written to and the WCOL bit will be set, indicating that a write to the SSPBUF did not occur.

The following events will cause the SSP Interrupt Flag bit, SSPIF, to be set (SSP interrupt, if enabled):

- · Start condition
- Stop condition
- · Data transfer byte transmitted/received
- · Acknowledge transmit
- Repeated Start



## PIC18(L)F1XK22



|        |                                     |            |                               | SYNC = 0          | , BRGH     | = 1, BRG16                    | = 1 or SY          | 'NC = 1,   | BRG16 = 1                     |                |            |                               |
|--------|-------------------------------------|------------|-------------------------------|-------------------|------------|-------------------------------|--------------------|------------|-------------------------------|----------------|------------|-------------------------------|
| BAUD   | Fosc = 48.000 MHz Fosc = 18.432 MHz |            | 2 MHz                         | Fosc = 12.000 MHz |            |                               | Fosc = 11.0592 MHz |            |                               |                |            |                               |
| RATE   | Actual<br>Rate                      | %<br>Error | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate     | %<br>Error | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRGH<br>:SPBRG<br>(decimal) |
| 300    | 300                                 | 0.00       | 39999                         | 300.0             | 0.00       | 15359                         | 300                | 0.00       | 9999                          | 300.0          | 0.00       | 9215                          |
| 1200   | 1200                                | 0.00       | 9999                          | 1200              | 0.00       | 3839                          | 1200               | 0.00       | 2499                          | 1200           | 0.00       | 2303                          |
| 2400   | 2400                                | 0.00       | 4999                          | 2400              | 0.00       | 1919                          | 2400               | 0.00       | 1249                          | 2400           | 0.00       | 1151                          |
| 9600   | 9600                                | 0.00       | 1249                          | 9600              | 0.00       | 479                           | 9615               | 0.16       | 311                           | 9600           | 0.00       | 287                           |
| 10417  | 10417                               | 0.00       | 1151                          | 10425             | 0.08       | 441                           | 10417              | 0.00       | 287                           | 10433          | 0.16       | 264                           |
| 19.2k  | 19.20k                              | 0.00       | 624                           | 19.20k            | 0.00       | 239                           | 19.23k             | 0.16       | 155                           | 19.20k         | 0.00       | 143                           |
| 57.6k  | 57.69k                              | 0.16       | 207                           | 57.60k            | 0.00       | 79                            | 57.69k             | 0.16       | 51                            | 57.60k         | 0.00       | 47                            |
| 115.2k | 115.38k                             | 0.16       | 103                           | 115.2k            | 0.00       | 39                            | 115.38k            | 0.16       | 25                            | 115.2k         | 0.00       | 23                            |

### TABLE 15-5: BAUD RATES FOR ASYNCHRONOUS MODES (CONTINUED)

|        |                     |            |                               | SYNC = 0       | , BRGH           | = 1, BRG16                    | = 1 or SY         | <b>NC =</b> 1, | BRG16 = 1                     |                |                  |                               |  |
|--------|---------------------|------------|-------------------------------|----------------|------------------|-------------------------------|-------------------|----------------|-------------------------------|----------------|------------------|-------------------------------|--|
| BAUD   | Fosc = 8.000 MHz Fo |            |                               | Fos            | Fosc = 4.000 MHz |                               | Fosc = 3.6864 MHz |                |                               | Fos            | Fosc = 1.000 MHz |                               |  |
| RATE   | Actual<br>Rate      | %<br>Error | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate | %<br>Error       | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate    | %<br>Error     | SPBRGH<br>:SPBRG<br>(decimal) | Actual<br>Rate | %<br>Error       | SPBRGH<br>:SPBRG<br>(decimal) |  |
| 300    | 300.0               | 0.00       | 6666                          | 300.0          | 0.01             | 3332                          | 300.0             | 0.00           | 3071                          | 300.1          | 0.04             | 832                           |  |
| 1200   | 1200                | -0.02      | 1666                          | 1200           | 0.04             | 832                           | 1200              | 0.00           | 767                           | 1202           | 0.16             | 207                           |  |
| 2400   | 2401                | 0.04       | 832                           | 2398           | 0.08             | 416                           | 2400              | 0.00           | 383                           | 2404           | 0.16             | 103                           |  |
| 9600   | 9615                | 0.16       | 207                           | 9615           | 0.16             | 103                           | 9600              | 0.00           | 95                            | 9615           | 0.16             | 25                            |  |
| 10417  | 10417               | 0.00       | 191                           | 10417          | 0.00             | 95                            | 10473             | 0.53           | 87                            | 10417          | 0.00             | 23                            |  |
| 19.2k  | 19.23k              | 0.16       | 103                           | 19.23k         | 0.16             | 51                            | 19.20k            | 0.00           | 47                            | 19.23k         | 0.16             | 12                            |  |
| 57.6k  | 57.14k              | -0.79      | 34                            | 58.82k         | 2.12             | 16                            | 57.60k            | 0.00           | 15                            | —              | _                | _                             |  |
| 115.2k | 117.6k              | 2.12       | 16                            | 111.1k         | -3.55            | 8                             | 115.2k            | 0.00           | 7                             | —              | —                | —                             |  |

### 18.1.3 MULTIPLE FUNCTIONS OF THE SLEEP COMMAND

The power-managed mode that is invoked with the SLEEP instruction is determined by the setting of the IDLEN bit of the OSCCON register at the time the instruction is executed. All clocks stop and minimum power is consumed when SLEEP is executed with the IDLEN bit cleared. The system clock continues to supply a clock to the peripherals but is disconnected from the CPU when SLEEP is executed with the IDLEN bit set.

#### 18.2 Run Modes

In the Run modes, clocks to both the core and peripherals are active. The difference between these modes is the clock source.

#### 18.2.1 PRI\_RUN MODE

The PRI\_RUN mode is the normal, full power execution mode of the microcontroller. This is also the default mode upon a device Reset, unless Two-Speed Start-up is enabled (see **Section 2.11 "Two-Speed Start-up Mode"** for details). In this mode, the device operated off the oscillator defined by the FOSC bits of the CONFIGH Configuration register.

#### 18.2.2 SEC\_RUN MODE

In SEC\_RUN mode, the CPU and peripherals are clocked from the secondary external oscillator. This gives users the option of lower power consumption while still using a high accuracy clock source.

SEC\_RUN mode is entered by setting the SCS<1:0> bits of the OSCCON register to '01'. When SEC\_RUN mode is active all of the following are true:

- The main clock source is switched to the secondary external oscillator
- · Primary external oscillator is shut down
- T1RUN bit of the T1CON register is set
- · OSTS bit is cleared.
  - Note: The secondary external oscillator should already be running prior to entering SEC\_RUN mode. If the T1OSCEN bit is not set when the SCS<1:0> bits are set to '01', entry to SEC\_RUN mode will not occur until T1OSCEN bit is set and secondary external oscillator is ready.

#### 18.2.3 RC\_RUN MODE

In RC\_RUN mode, the CPU and peripherals are clocked from the internal oscillator. In this mode, the primary external oscillator is shut down. RC\_RUN mode provides the best power conservation of all the Run modes when the LFINTOSC is the system clock.

RC\_RUN mode is entered by setting the SCS1 bit. When the clock source is switched from the primary oscillator to the internal oscillator, the primary oscillator is shut down and the OSTS bit is cleared. The IRCF bits may be modified at any time to immediately change the clock speed.

#### 22.4 Brown-out Reset (BOR)

PIC18(L)F1XK22 devices implement a BOR circuit that provides the user with a number of configuration and power-saving options. The BOR is controlled by the BORV<1:0> and BOREN<1:0> bits of the CONFIG2L Configuration register. There are a total of four BOR configurations which are summarized in Table 22-1.

The BOR threshold is set by the BORV<1:0> bits. If BOR is enabled (any values of BOREN<1:0>, except '00'), any drop of VDD below VBOR for greater than TBOR will reset the device. A Reset may or may not occur if VDD falls below VBOR for less than TBOR. The chip will remain in Brown-out Reset until VDD rises above VBOR.

If the Power-up Timer is enabled, it will be invoked after VDD rises above VBOR; it then will keep the chip in Reset for an additional time delay, TPWRT. If VDD drops below VBOR while the Power-up Timer is running, the chip will go back into a Brown-out Reset and the Power-up Timer will be initialized. Once VDD rises above VBOR, the Power-up Timer will execute the additional time delay.

BOR and the Power-on Timer (PWRT) are independently configured. Enabling BOR Reset does not automatically enable the PWRT.

#### 22.4.1 SOFTWARE ENABLED BOR

When BOREN<1:0> = 01, the BOR can be enabled or disabled by the user in software. This is done with the SBOREN control bit of the RCON register. Setting SBOREN enables the BOR to function as previously described. Clearing SBOREN disables the BOR entirely. The SBOREN bit operates only in this mode; otherwise it is read as '0'. Placing the BOR under software control gives the user the additional flexibility of tailoring the application to its environment without having to reprogram the device to change BOR configuration. It also allows the user to tailor device power consumption in software by eliminating the incremental current that the BOR consumes. While the BOR current is typically very small, it may have some impact in low-power applications.

| Note: | Even   | when     | BOR    | is    | under    | software      |
|-------|--------|----------|--------|-------|----------|---------------|
|       | contro | l, the B | OR Res | set v | oltage l | evel is still |
|       | set by | the BC   | RV<1:  | 0> (  | Configur | ation bits.   |
|       | It can | not be c | hangeo | d by  | softwar  | e.            |

#### 22.4.2 DETECTING BOR

When BOR is enabled, the BOR bit always resets to '0' on any BOR or POR event. This makes it difficult to determine if a BOR event has occurred just by reading the state of BOR alone. A more reliable method is to simultaneously check the state of both POR and BOR. This assumes that the POR and BOR bits are reset to '1' by software immediately after any POR event. If BOR is '0' while POR is '1', it can be reliably assumed that a BOR event has occurred.

#### 22.4.3 DISABLING BOR IN SLEEP MODE

When BOREN<1:0> = 10, the BOR remains under hardware control and operates as previously described. Whenever the device enters Sleep mode, however, the BOR is automatically disabled. When the device returns to any other operating mode, BOR is automatically re-enabled.

This mode allows for applications to recover from brown-out situations, while actively executing code, when the device requires BOR protection the most. At the same time, it saves additional power in Sleep mode by eliminating the small incremental BOR current.

| BOR Con | figuration | Status of           |                                                                                    |
|---------|------------|---------------------|------------------------------------------------------------------------------------|
| BOREN1  | BOREN0     | SBOREN<br>(RCON<6>) | BOR Operation                                                                      |
| 0       | 0          | Unavailable         | BOR disabled; must be enabled by reprogramming the Configuration bits.             |
| 0       | 1          | Available           | BOR enabled by software; operation controlled by SBOREN.                           |
| 1       | 0          | Unavailable         | BOR enabled by hardware in Run and Idle modes, disabled during Sleep mode.         |
| 1       | 1          | Unavailable         | BOR enabled by hardware; must be disabled by reprogramming the Configuration bits. |

TABLE 22-1: BOR CONFIGURATIONS

# PIC18(L)F1XK22

| CLRF                                         | Clear f                                                                                   |                           |                       | CLRWDT                                     | Clear Wat                             | chdog Time      | er              |
|----------------------------------------------|-------------------------------------------------------------------------------------------|---------------------------|-----------------------|--------------------------------------------|---------------------------------------|-----------------|-----------------|
| Syntax:                                      | CLRF f {,a}                                                                               |                           |                       | Syntax:                                    | CLRWDT                                |                 |                 |
| Operands:                                    | $0 \leq f \leq 255$                                                                       |                           |                       | Operands:                                  | None                                  |                 |                 |
|                                              | <b>a</b> ∈ [0,1]                                                                          |                           |                       | Operation:                                 | $000h \rightarrow WI$                 | DT,             |                 |
| Operation:                                   | $\begin{array}{l} 000h \rightarrow f \\ 1 \rightarrow Z \end{array}$                      |                           |                       |                                            | $1 \rightarrow \overline{\text{TO}},$ | DT postscaler,  |                 |
| Status Affected:                             | Z                                                                                         |                           |                       |                                            | $1 \rightarrow PD$                    |                 |                 |
| Encoding:                                    | 0110 1                                                                                    | 101a fff                  | f ffff                | Status Affected:                           | TO, PD                                |                 |                 |
| Description:                                 | Clears the co                                                                             | ontents of the            | specified             | Encoding:                                  | 0000                                  | 0000 00         | 00 0100         |
|                                              | register.<br>If 'a' is '0', the<br>If 'a' is '1', the<br>GPR bank (d<br>If 'a' is '0' and | e BSR is useo<br>efault). | I to select the       | Description:                               | Watchdog 7                            | e WDT. Status   | esets the post- |
|                                              | set is enable                                                                             |                           |                       | Words:                                     | 1                                     |                 |                 |
|                                              | in Indexed Li                                                                             | teral Offset A            | ddressing             | Cycles:                                    | 1                                     |                 |                 |
|                                              | mode whene<br>Section 24.2                                                                | •                         | ,                     | Q Cycle Activity:                          |                                       |                 |                 |
|                                              | <b>Bit-Oriented</b>                                                                       | Instructions              | in Indexed            | Q1                                         | Q2                                    | Q3              | Q4              |
|                                              | Literal Offse                                                                             | t Mode" for a             | letails.              | Decode                                     | No<br>operation                       | Process<br>Data | No<br>operation |
| Words:                                       | 1                                                                                         |                           |                       |                                            |                                       |                 |                 |
| Cycles:                                      | 1                                                                                         |                           |                       | Example:                                   | CLRWDT                                |                 |                 |
| Q Cycle Activity:                            |                                                                                           |                           |                       | Before Instru                              | ction                                 |                 |                 |
| Q1                                           | Q2                                                                                        | Q3                        | Q4                    | WDT C                                      |                                       | ?               |                 |
| Decode                                       | Read<br>register 'f'                                                                      | Process<br>Data           | Write<br>register 'f' | After Instruct<br>WDT Co<br><u>WD</u> T Po |                                       | <b>00h</b><br>0 |                 |
| Example:                                     | CLRF                                                                                      | FLAG_REG,                 | 1                     | <u>TO</u><br>PD                            | =                                     | 1<br>1          |                 |
| Before Instruc<br>FLAG_R<br>After Instructio | EG = 5Ah                                                                                  |                           |                       |                                            |                                       |                 |                 |

# PIC18(L)F1XK22

| MOVSS                                              | Move Indexed to Indexed                                                                                                                                                                                                                            |                                                                                                                                                                                                                  |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:                                            | MOVSS                                                                                                                                                                                                                                              | [z <sub>s</sub> ], [z <sub>d</sub> ]                                                                                                                                                                             |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Operands:                                          | 0                                                                                                                                                                                                                                                  | $\begin{array}{l} 0 \leq z_s \leq 127 \\ 0 \leq z_d \leq 127 \end{array}$                                                                                                                                        |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Operation:                                         | ((FSR2) +                                                                                                                                                                                                                                          | $((FSR2) + z_s) \rightarrow ((FSR2) + z_d)$                                                                                                                                                                      |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Status Affected:                                   | None                                                                                                                                                                                                                                               | None                                                                                                                                                                                                             |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Encoding:<br>1st word (source)<br>2nd word (dest.) | 1110 1011 1zzz zzzz <sub>s</sub><br>1111 xxxx xzzz zzzz <sub>d</sub>                                                                                                                                                                               |                                                                                                                                                                                                                  |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Description                                        | The conter<br>moved to t<br>addresses<br>registers a<br>7-bit literal<br>respective<br>registers c<br>the 4096-b<br>(000h to F<br>The MOVS:<br>PCL, TOS<br>destination<br>If the resul<br>an indirect<br>value retur<br>resultant d<br>an indirect | the destin<br>of the source determ<br>offsets 'z<br>ly, to the v<br>an be loc<br>oyte data in<br>FFh).<br>s instructi<br>U, TOSH<br>negister.<br>tant source<br>addressi<br>ned will b<br>estination<br>addressi | ation regis<br>urce and du-<br>nined by ac<br>s' or 'z <sub>d</sub> ',<br>value of FS<br>ated anyw<br>memory sp<br>on cannot<br>or TOSL a<br>ce address<br>ng register<br>te 00h. If th<br>a address p<br>ng register | ter. The<br>estination<br>dding the<br>SR2. Both<br>here in<br>bace<br>use the<br>as the<br>points to<br>r, the<br>points to<br>r, the |  |  |  |
| Words:                                             | 2                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Cycles:                                            | 2                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                                                                                                                                                       |                                                                                                                                        |  |  |  |
| Q Cycle Activity:                                  |                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                  |                                                                                                                                                                                                                       | <b>.</b>                                                                                                                               |  |  |  |
| Q1                                                 | Q2                                                                                                                                                                                                                                                 | Q3                                                                                                                                                                                                               | 5                                                                                                                                                                                                                     | Q4                                                                                                                                     |  |  |  |

| Q1     | Q2                     | Q3                  | Q4                   |
|--------|------------------------|---------------------|----------------------|
| Decode | Determine              | Determine           | Read                 |
|        | source addr            | source addr         | source reg           |
| Decode | Determine<br>dest addr | Determine dest addr | Write<br>to dest reg |

| Example:                              | MOVSS   | [05h], | [06h] |
|---------------------------------------|---------|--------|-------|
| Before Instructio<br>FSR2<br>Contents | on<br>= | 80h    |       |
| of 85h<br>Contents                    | =       | 33h    |       |
| of 86h                                | =       | 11h    |       |
| After Instruction<br>FSR2<br>Contents | =       | 80h    |       |
| of 85h<br>Contents                    | =       | 33h    |       |
| of 86h                                | =       | 33h    |       |

| Syntax:                                     | PUSHL k                                                |                       | •           |                |  |  |  |
|---------------------------------------------|--------------------------------------------------------|-----------------------|-------------|----------------|--|--|--|
| ,                                           |                                                        |                       |             |                |  |  |  |
| Operands:                                   | $0 \le k \le 255$                                      |                       |             |                |  |  |  |
| Operation:                                  | $k \rightarrow (FSR2),$<br>FSR2 – 1 $\rightarrow$ FSR2 |                       |             |                |  |  |  |
| Status Affected:                            | None                                                   |                       |             |                |  |  |  |
| Encoding:                                   | 1110                                                   | 1010                  | kkkk        | kkkk           |  |  |  |
|                                             | is decremer<br>This instruc                            |                       |             | •              |  |  |  |
| Words:                                      | onto a softv                                           |                       |             |                |  |  |  |
|                                             | onto a softw<br>1                                      |                       |             |                |  |  |  |
|                                             | onto a softw<br>1<br>1                                 |                       |             |                |  |  |  |
| Words:<br>Cycles:<br>Q Cycle Activity<br>Q1 | onto a softw<br>1<br>1                                 | vare stack.           |             | Q4             |  |  |  |
| Cycles:<br>Q Cycle Activity                 | onto a softw<br>1<br>1<br>/:<br>Q2                     | vare stack.<br>k' Pro |             |                |  |  |  |
| Cycles:<br>Q Cycle Activity<br>Q1           | onto a softw<br>1<br>1<br>/:<br>Q2                     | vare stack.<br>k' Pro | Q3<br>Dcess | Q4<br>Write to |  |  |  |

| After Instruction             |   |              |
|-------------------------------|---|--------------|
| FSR2H:FSR2L<br>Memory (01ECh) | = | 01EBh<br>08h |

### 26.2 Standard Operating Conditions

| The standard operating conditions for any device are defined as: |        |
|------------------------------------------------------------------|--------|
| Operating Voltage: $VDDMIN \le VDD \le VDDMAX$                   |        |
| Operating Temperature: $TA\_MIN \le TA \le TA\_MAX$              |        |
| VDD — Operating Supply Voltage <sup>(1)</sup>                    |        |
| PIC18LF1XK22                                                     |        |
| VDDMIN (Fosc $\leq$ 16 MHz)                                      | +1.8V  |
| VDDMIN (Fosc $\leq$ 20 MHz)                                      | +2.0V  |
| VDDMIN (Fosc $\leq$ 64 MHz)                                      | +3.0V  |
| VDDMAX                                                           | +3.6V  |
| PIC18F1XK22                                                      |        |
| VDDMIN (Fosc $\leq$ 20 MHz)                                      | +2.3V  |
| VDDMIN (Fosc $\leq$ 64 MHz)                                      | +3.0V  |
| VDDMAX                                                           | +5.5V  |
| TA — Operating Ambient Temperature Range                         |        |
| Industrial Temperature                                           |        |
| Та_мім                                                           | 40°C   |
| Та_мах                                                           | +85°C  |
| Extended Temperature                                             |        |
| Та_мім                                                           | 40°C   |
| Та_мах                                                           | +125°C |
| Note 1: See Parameter D001, DC Characteristics: Supply Voltage.  |        |