



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

| 2011.10                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 64MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, LVD, POR, PWM, WDT                                  |
| Number of I/O              | 25                                                                          |
| Program Memory Size        | 64KB (32K x 16)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 1K x 8                                                                      |
| RAM Size                   | 3.6K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 24x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-UFQFN Exposed Pad                                                        |
| Supplier Device Package    | 28-UQFN (4x4)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf26k40-e-mv |
|                            |                                                                             |

Email: info@E-XFL.COM

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

## 8.0 RESETS

There are multiple ways to reset this device:

- Power-on Reset (POR)
- Brown-out Reset (BOR)
- Low-Power Brown-Out Reset (LPBOR)
- MCLR Reset
- WDT Reset
- RESET instruction
- Stack Overflow
- Stack Underflow
- · Programming mode exit

To allow VDD to stabilize, an optional Power-up Timer can be enabled to extend the Reset time after a BOR or POR event.

A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 8-1.





|                  | ••••••••••••••••••••••••••••••••••••••• |                   |       |              | ••••••           |                  |              |
|------------------|-----------------------------------------|-------------------|-------|--------------|------------------|------------------|--------------|
| R-0/0            | R-0/0                                   | R-0/0             | R-0/0 | R-0/0        | R-0/0            | R-0/0            | R-0/0        |
|                  | ١                                       | VDTTMR<4:0>       |       |              | STATE            | PSCNT            | <17:16>      |
| bit 7            |                                         |                   |       |              |                  |                  | bit 0        |
|                  |                                         |                   |       |              |                  |                  |              |
| Legend:          |                                         |                   |       |              |                  |                  |              |
| R = Readable b   | R = Readable bit W = Writable bit       |                   |       | U = Unimpler | mented bit, read | l as '0'         |              |
| u = Bit is uncha | anged                                   | x = Bit is unkr   | nown  | -n/n = Value | at POR and BO    | R/Value at all o | other Resets |
| '1' = Bit is set |                                         | '0' = Bit is clea | ared  |              |                  |                  |              |

#### REGISTER 9-5: WDTTMR: WDT TIMER REGISTER (READ-ONLY)

bit 7-3 WDTTMR<4:0>: Watchdog Window Value bits

| WINDOW | WDT Win     | Open Bereant |              |
|--------|-------------|--------------|--------------|
| WINDOW | Closed      | Open         | Open Percent |
| 111    | N/A         | 00000-11111  | 100          |
| 110    | 00000-00011 | 00100-11111  | 87.5         |
| 101    | 00000-00111 | 01000-11111  | 75           |
| 100    | 00000-01011 | 01100-11111  | 62.5         |
| 011    | 00000-01111 | 10000-11111  | 50           |
| 010    | 00000-10011 | 10100-11111  | 37.5         |
| 001    | 00000-10111 | 11000-11111  | 25           |
| 000    | 00000-11011 | 11100-11111  | 12.5         |

bit 2 STATE: WDT Armed Status bit

1 = WDT is armed

0 = WDT is not armed

## bit 1-0 **PSCNT<17:16>:** Prescale Select Upper Byte bits<sup>(1)</sup>

**Note 1:** The 18-bit WDT prescale value, PSCNT<17:0> includes the WDTPSL, WDTPSH and the lower bits of the WDTTMR registers. PSCNT<17:0> is intended for debug operations and should be read during normal operation.

| R/W-0/0          | R/W-0/0 | R/W-0/0           | R/W-0/0 | R/W-0/0                  | R/W-0/0          | R/W-0/0          | R/W-0/0     |
|------------------|---------|-------------------|---------|--------------------------|------------------|------------------|-------------|
|                  |         |                   | HADR<   | :15:8> <sup>(1, 2)</sup> |                  |                  |             |
| bit 7            |         |                   |         |                          |                  |                  | bit 0       |
|                  |         |                   |         |                          |                  |                  |             |
| Legend:          |         |                   |         |                          |                  |                  |             |
| R = Readable     | bit     | W = Writable      | bit     | U = Unimpler             | nented bit, read | as '0'           |             |
| u = Bit is unch  | anged   | x = Bit is unkr   | nown    | -n/n = Value a           | at POR and BO    | R/Value at all o | ther Resets |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                          |                  |                  |             |

#### **REGISTER 13-16: SCANHADRH: SCAN HIGH ADDRESS HIGH BYTE REGISTER**

bit 7-0 HADR<15:8>: Scan End Address bits<sup>(1, 2)</sup>

Most Significant bits of the address at the end of the designated scan

- **Note 1:** Registers SCANHADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access; registers should only be read or written while SCANGO = 0 (SCANCON0 register).
  - 2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

#### REGISTER 13-17: SCANHADRL: SCAN HIGH ADDRESS LOW BYTE REGISTER

| R/W-0/0          | R/W-0/0 | R/W-0/0            | R/W-0/0 | R/W-0/0                 | R/W-0/0          | R/W-0/0          | R/W-0/0      |
|------------------|---------|--------------------|---------|-------------------------|------------------|------------------|--------------|
|                  |         |                    | HADR<   | :7:0> <sup>(1, 2)</sup> |                  |                  |              |
| bit 7            |         |                    |         |                         |                  |                  | bit 0        |
|                  |         |                    |         |                         |                  |                  |              |
| Legend:          |         |                    |         |                         |                  |                  |              |
| R = Readable     | bit     | W = Writable       | bit     | U = Unimpler            | mented bit, read | l as '0'         |              |
| u = Bit is uncha | anged   | x = Bit is unknown |         | -n/n = Value            | at POR and BO    | R/Value at all c | other Resets |
| '1' = Bit is set |         | '0' = Bit is clea  | ared    |                         |                  |                  |              |

bit 7-0 HADR<7:0>: Scan End Address bits<sup>(1, 2)</sup>

Least Significant bits of the address at the end of the designated scan

- **Note 1:** Registers SCANHADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access; registers should only be read or written while SCANGO = 0 (SCANCON0 register).
  - 2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

## 14.8 Register Definitions: Interrupt Control

| REGISTER 14-1: | <b>INTCON: INTERRUPT</b> | CONTROL REGISTER |
|----------------|--------------------------|------------------|
|                |                          |                  |

| R/W-0/0               | R/W-0/0                                                                                                                                                                | R/W-0/0                                                                       | U-0                                              | U-0             | R/W-1/1          | R/W-1/1            | R/W-1/1        |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------|-----------------|------------------|--------------------|----------------|
| GIE/GIEH              | PEIE/GIEL                                                                                                                                                              | IPEN                                                                          | —                                                | -               | INT2EDG          | INT1EDG            | INT0EDG        |
| bit 7                 |                                                                                                                                                                        | •                                                                             |                                                  |                 |                  | •                  | bit (          |
|                       |                                                                                                                                                                        |                                                                               |                                                  |                 |                  |                    |                |
| Legend:               |                                                                                                                                                                        |                                                                               |                                                  |                 |                  |                    |                |
| R = Readabl           | e bit                                                                                                                                                                  | W = Writable                                                                  | bit                                              | U = Unimple     | emented bit, rea | d as '0'           |                |
| -n = Value at         | POR                                                                                                                                                                    | '1' = Bit is set                                                              |                                                  | '0' = Bit is c  | leared           | x = Bit is unk     | nown           |
| bit 7                 | <b>GIE/GIEH:</b> G<br>If IPEN = 1:                                                                                                                                     | lobal Interrupt I                                                             | Enable bit                                       |                 |                  |                    |                |
|                       |                                                                                                                                                                        | ables all unma<br>sables all interr                                           |                                                  | pts and cleared | by hardware for  | r high-priority ir | nterrupts only |
|                       | 1 = En                                                                                                                                                                 | ables all unmas<br>sables all interru                                         |                                                  | ots and cleared | by hardware for  | all interrupts     |                |
| bit 6                 |                                                                                                                                                                        | Peripheral Inter                                                              | rupt Enable                                      | bit             |                  |                    |                |
|                       | 0 = Dis                                                                                                                                                                | ables all low-pr<br>sables all low-p                                          |                                                  |                 | d by hardware fo | r low-priority in  | terrupts only  |
|                       |                                                                                                                                                                        | ables all unma<br>sables all peripl                                           |                                                  | -               |                  |                    |                |
| bit 5                 | 1 = Enable                                                                                                                                                             | pt Priority Enab<br>priority levels o<br>priority levels o                    | n interrupts                                     | i               |                  |                    |                |
| bit 4-3               | Unimplemen                                                                                                                                                             | ited: Read as 'd                                                              | )'                                               |                 |                  |                    |                |
| bit 2                 | INT2EDG: External Interrupt 2 Edge Select bit<br>1 = Interrupt on rising edge of INT2 pin<br>0 = Interrupt on falling edge of INT2 pin                                 |                                                                               |                                                  |                 |                  |                    |                |
| bit 1                 | <ul> <li>INTIEDG: External Interrupt 1 Edge Select bit</li> <li>1 = Interrupt on rising edge of INT1 pin</li> <li>0 = Interrupt on falling edge of INT1 pin</li> </ul> |                                                                               |                                                  |                 |                  |                    |                |
| bit 0                 | 1 = Interrup                                                                                                                                                           | xternal Interrupt<br>at on rising edge<br>at on falling edge                  | e of INT0 pir                                    | ı               |                  |                    |                |
| co<br>its<br>er<br>th | iterrupt flag bits a<br>ondition occurs, r<br>s corresponding<br>nable bit. User s<br>le appropriate inf                                                               | egardless of the<br>enable bit or the<br>software should<br>terrupt flag bits | e state of<br>ne global<br>d ensure<br>are clear |                 |                  |                    |                |

prior to enabling an interrupt. This feature

allows for software polling.

| U-0                                                                     | U-0        | U-0              | U-0 | U-0                                     | U-0 | R/W-0/0 | R/W-0/0 |
|-------------------------------------------------------------------------|------------|------------------|-----|-----------------------------------------|-----|---------|---------|
| _                                                                       | —          | —                |     | _                                       | —   | CCP2IE  | CCP1IE  |
| bit 7                                                                   |            |                  |     |                                         |     |         | bit 0   |
|                                                                         |            |                  |     |                                         |     |         |         |
| Legend:                                                                 |            |                  |     |                                         |     |         |         |
| R = Readab                                                              | le bit     | W = Writable I   | bit | U = Unimplemented bit, read as '0'      |     |         |         |
| -n = Value a                                                            | t POR      | '1' = Bit is set |     | '0' = Bit is cleared x = Bit is unknown |     |         | nown    |
|                                                                         |            |                  |     |                                         |     |         |         |
| bit 7-2                                                                 | Unimplemen | ted: Read as 'd  | )'  |                                         |     |         |         |
| bit 1 CCP2IE: ECCP2 Interrupt Enable bit<br>1 = Enabled<br>0 = Disabled |            |                  |     |                                         |     |         |         |
| bit 0 CCP1IE: ECCP1 Interrupt Enable bit<br>1 = Enabled<br>0 = Disabled |            |                  |     |                                         |     |         |         |

#### REGISTER 14-16: PIE6: PERIPHERAL INTERRUPT ENABLE REGISTER 6

|                                                                                                                               |            |                  | -   | -                |                  |                 |         |
|-------------------------------------------------------------------------------------------------------------------------------|------------|------------------|-----|------------------|------------------|-----------------|---------|
| R/W-1/1                                                                                                                       | R/W-1/1    | R/W-1/1          | U-0 | U-0              | U-0              | U-0             | R/W-1/1 |
| SCANIP                                                                                                                        | CRCIP      | NVMIP            | _   | —                | —                | —               | CWG1IP  |
| bit 7                                                                                                                         | ·          |                  |     |                  |                  | •               | bit 0   |
|                                                                                                                               |            |                  |     |                  |                  |                 |         |
| Legend:                                                                                                                       |            |                  |     |                  |                  |                 |         |
| R = Readable                                                                                                                  | bit        | W = Writable     | bit | U = Unimpler     | mented bit, read | as '0'          |         |
| -n = Value at                                                                                                                 | POR        | '1' = Bit is set |     | '0' = Bit is cle | ared             | x = Bit is unkr | nown    |
| bit 7 SCANIP: SCAN Interrupt Priority bit<br>1 = High priority<br>0 = Low priority<br>bit 6 CRCIP: CRC Interrupt Priority bit |            |                  |     |                  |                  |                 |         |
| bit 6 CRCIP: CRC Interrupt Priority bit<br>1 = High priority<br>0 = Low priority                                              |            |                  |     |                  |                  |                 |         |
| bit 5 NVMIP: NVM Interrupt Priority bit<br>1 = High priority<br>0 = Low priority                                              |            |                  |     |                  |                  |                 |         |
| bit 4-1                                                                                                                       | Unimplemen | ted: Read as '   | כ'  |                  |                  |                 |         |
| bit 0                                                                                                                         | -          |                  |     |                  |                  |                 |         |

## REGISTER 14-25: IPR7: PERIPHERAL INTERRUPT PRIORITY REGISTER 7

### 18.3 **Programmable Prescaler**

A software programmable prescaler is available for exclusive use with Timer0. There are 16 prescaler options for Timer0 ranging in powers of two from 1:1 to 1:32768. The prescaler values are selected using the T0CKPS<3:0> bits of the T0CON1 register.

The prescaler is not directly readable or writable. Clearing the prescaler register can be done by writing to the TMR0L register or the T0CON0, T0CON1 registers or by any Reset.

## 18.4 **Programmable Postscaler**

A software programmable postscaler (output divider) is available for exclusive use with Timer0. There are 16 postscaler options for Timer0 ranging from 1:1 to 1:16. The postscaler values are selected using the TOOUTPS<3:0> bits of the TOCON0 register.

The postscaler is not directly readable or writable. Clearing the postscaler register can be done by writing to the TMR0L register or the T0CON0, T0CON1 registers or by any Reset.

## 18.5 Operation During Sleep

When operating synchronously, Timer0 will halt. When operating asynchronously, Timer0 will continue to increment and wake the device from Sleep (if Timer0 interrupts are enabled) provided that the input clock source is active.

## 18.6 Timer0 Interrupts

The Timer0 interrupt flag bit (TMR0IF) is set when either of the following conditions occur:

- 8-bit TMR0L matches the TMR0H value
- 16-bit TMR0 rolls over from 'FFFFh'

When the postscaler bits (TOOUTPS<3:0>) are set to 1:1 operation (no division), the TOIF flag bit will be set with every TMR0 match or rollover. In general, the TMR0IF flag bit will be set every TOOUTPS +1 matches or rollovers.

If Timer0 interrupts are enabled (TMR0IE bit of the PIE0 register = '1'), the CPU will be interrupted and the device may wake from Sleep (see Section 18.2 "Clock Source Selection" for more details).

## 18.7 Timer0 Output

The Timer0 output can be routed to any I/O pin via the RxyPPS output selection register (see **Section 17.0 "Peripheral Pin Select (PPS) Module**" for additional information). The Timer0 output can also be used by other peripherals, such as the auto-conversion trigger of the Analog-to-Digital Converter. Finally, the Timer0 output can be monitored through software via the Timer0 output bit (TOOUT) of the TOCON0 register (Register 18-1).

TMR0\_out will be a pulse of one postscaled clock period when a match occurs between TMR0L and PR0 (Period register for TMR0) in 8-bit mode, or when TMR0 rolls over in 16-bit mode. The Timer0 output is a 50% duty cycle that toggles on each TMR0\_out rising clock edge.

| FIGURE 19-7:           | TIMER1/3/5 GATE SINC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | GLE-PULSE AND TOGGLE COMBINED MODE                  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| TMRxGE                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TxGPOL                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TxGSPM                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TxGTM                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TxGG <u>O/</u><br>DONE | <ul> <li>Set by software</li> <li>Counting enabled of the set of the</li></ul> | Cleared by hardware on falling edge of TxGVAL       |
| TxG_IN                 | rising edge of TxC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                     |
| ТхСКІ                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TxGVAL                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                     |
| TIMER1/3/5             | Ν                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <u>N + 1</u> <u>N + 2</u> <u>N + 3</u> <u>N + 4</u> |
| TMRxGIF                | <ul> <li>Cleared by software</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Set by hardware on<br>falling edge of TxGVAL —      |

## 19.13 Peripheral Module Disable

When a peripheral module is not used or inactive, the module can be disabled by setting the Module Disable bit in the PMD registers. This will reduce power consumption to an absolute minimum. Setting the PMD bits holds the module in Reset and disconnects the module's clock source. The Module Disable bits for Timer1 (TMR1MD), Timer3 (TMR3MD) and Timer5 (TMR5MD) are in the PMD1 register. See Section **7.0 "Peripheral Module Disable (PMD)"** for more information.

## 20.5 Operation Examples

Unless otherwise specified, the following notes apply to the following timing diagrams:

- Both the prescaler and postscaler are set to 1:1 (both the CKPS and OUTPS bits in the TxCON register are cleared).
- The diagrams illustrate any clock except Fosc/4 and show clock-sync delays of at least two full cycles for both ON and Timer2\_ers. When using Fosc/4, the clock-sync delay is at least one instruction period for Timer2\_ers; ON applies in the next instruction period.
- The PWM Duty Cycle and PWM output are illustrated assuming that the timer is used for the PWM function of the CCP module as described in Section
   21.0 "Capture/Compare/PWM Module".

The signals are not a part of the Timer2 module.

#### 20.5.1 SOFTWARE GATE MODE

This mode corresponds to legacy Timer2 operation. The timer increments with each clock input when ON = 1 and does not increment when ON = 0. When the TMRx count equals the PRx period count the timer resets on the next clock and continues counting from 0. Operation with the ON bit software controlled is illustrated in Figure 20-4. With PRx = 5, the counter advances until TMRx = 5, and goes to zero with the next clock.



| MODE                          | 0b00000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMRx_clk                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Instruction <sup>(1)</sup> —— | BSF BSF BSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ON                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PRx                           | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| TMRx 0                        | $\begin{array}{c} \begin{array}{c} \begin{array}{c} \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \begin{array}{c} \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \end{array} \\ \end{array} $ |
| TMRx_postscaled               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PWM Duty                      | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PWM Output                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## 20.5.4 LEVEL-TRIGGERED HARDWARE LIMIT MODE

In the Level-Triggered Hardware Limit Timer modes the counter is reset by high or low levels of the external signal TMRx\_ers, as shown in Figure 20-7. Selecting MODE<4:0> = 0.0110 will cause the timer to reset on a low level external signal. Selecting MODE<4:0> = 0.0111 will cause the timer to reset on a high level external signal. In the example, the counter is reset while TMRx\_ers = 1. ON is controlled by BSF and BCF instructions. When ON = 0 the external signal is ignored.

When the CCP uses the timer as the PWM time base then the PWM output will be set high when the timer starts counting and then set low only when the timer count matches the CCPRx value. The timer is reset when either the timer count matches the PRx value or two clock periods after the external Reset signal goes true and stays true.

The timer starts counting, and the PWM output is set high, on either the clock following the PRx match or two clocks after the external Reset signal relinquishes the Reset. The PWM output will remain high until the timer counts up to match the CCPRx pulse width value. If the external Reset signal goes true while the PWM output is high then the PWM output will remain high until the Reset signal is released allowing the timer to count up to match the CCPRx value.





## 21.5.5 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to the CCPRxH:CCPRxL register pair. The alignment of the 10-bit value is determined by the FMT bit of the CCPxCON register (see Figure 21-5). The CCPRxH:CCPRxL register pair can be written to at any time; however the duty cycle value is not latched into the 10-bit buffer until after a match between PR2 and TMR2.

Equation 21-2 is used to calculate the PWM pulse width.

Equation 21-3 is used to calculate the PWM duty cycle ratio.

FIGURE 21-5: PWM 10-BIT ALIGNMENT



#### EQUATION 21-2: PULSE WIDTH

| Pulse Width = (CCPRx) | H:CCPRxL register pair) • |
|-----------------------|---------------------------|
| Tosc                  | • (TMR2 Prescale Value)   |

## EQUATION 21-3: DUTY CYCLE RATIO

$$Duty Cycle Ratio = \frac{(CCPRxH:CCPRxL register pair)}{4(PR2 + 1)}$$

CCPRxH:CCPRxL register pair are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

The 8-bit timer TMR2 register is concatenated with either the 2-bit internal system clock (FOSC), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1.

When the 10-bit time base matches the CCPRxH:CCPRxL register pair, then the CCPx pin is cleared (see Figure 21-4).

## 21.5.6 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is ten bits when PR2 is 255. The resolution is a function of the PR2 register value as shown by Equation 21-4.

## EQUATION 21-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PR2 + 1)]}{\log(2)}$$
 bits

**Note:** If the pulse-width value is greater than the period the assigned PWM pin(s) will remain unchanged.

| R/W-x/u          | R/W-x/u | R/W-x/u           | R/W-x/u | R/W-x/u        | R/W-x/u          | R/W-x/u          | R/W-x/u      |
|------------------|---------|-------------------|---------|----------------|------------------|------------------|--------------|
|                  |         |                   | DCH     | <7:0>          |                  |                  |              |
| bit 7            |         |                   |         |                |                  |                  | bit 0        |
|                  |         |                   |         |                |                  |                  |              |
| Legend:          |         |                   |         |                |                  |                  |              |
| R = Readable     | bit     | W = Writable b    | oit     | U = Unimplen   | nented bit, read | l as '0'         |              |
| u = Bit is unch  | nanged  | x = Bit is unkn   | own     | -n/n = Value a | t POR and BO     | R/Value at all c | other Resets |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                |                  |                  |              |

#### REGISTER 22-3: PWMxDCH: PWM DUTY CYCLE HIGH BITS

bit 7-0 **DCh<7:0>:** PWM Duty Cycle Most Significant bits These bits are the MSbs of the PWM duty cycle. The two LSbs are found in PWMxDCL Register.

#### REGISTER 22-4: PWMxDCL: PWM DUTY CYCLE LOW BITS

| R/W-x/u | R/W-x/u | U-0 | U-0 | U-0 | U-0 | U-0 | U-0   |
|---------|---------|-----|-----|-----|-----|-----|-------|
| DCL<    | :7:6>   | —   | —   | —   | —   | —   | —     |
| bit 7   |         |     |     |     |     |     | bit 0 |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-6 DC<8:9>: PWM Duty Cycle Least Significant bits These bits are the LSbs of the PWM duty cycle. The MSbs are found in PWMxDCH Register.

bit 5-0 Unimplemented: Read as '0'

## PIC18LF26/45/46K40



## 24.7 Rising Edge and Reverse Dead Band

In Half-Bridge mode, the rising edge dead band delays the turn-on of the CWG1A output after the rising edge of the CWG data input. In Full-Bridge mode, the reverse dead-band delay is only inserted when changing directions from Forward mode to Reverse mode, and only the modulated output CWG1B is affected.

The CWG1DBR register determines the duration of the dead-band interval on the rising edge of the input source signal. This duration is from 0 to 64 periods of the CWG clock.

Dead band is always initiated on the edge of the input source signal. A count of zero indicates that no dead band is present.

If the input source signal reverses polarity before the dead-band count is completed, then no signal will be seen on the respective output.

The CWG1DBR register value is double-buffered. When EN = 0 (Register 24-1), the buffer is loaded when CWG1DBR is written. If EN = 1, then the buffer will be loaded at the rising edge following the first falling edge of the data input, after the LD bit (Register 24-1) is set. Refer to Figure 24-12 for an example.

## 24.8 Falling Edge and Forward Dead Band

In Half-Bridge mode, the falling edge dead band delays the turn-on of the CWG1B output at the falling edge of the CWG data input. In Full-Bridge mode, the forward dead-band delay is only inserted when changing directions from Reverse mode to Forward mode, and only the modulated output CWG1D is affected.

The CWG1DBF register determines the duration of the dead-band interval on the falling edge of the input source signal. This duration is from zero to 64 periods of CWG clock.

Dead-band delay is always initiated on the edge of the input source signal. A count of zero indicates that no dead band is present.

If the input source signal reverses polarity before the dead-band count is completed, then no signal will be seen on the respective output.

The CWG1DBF register value is double-buffered. When EN = 0 (Register 24-1), the buffer is loaded when CWG1DBF is written. If EN = 1, then the buffer will be loaded at the rising edge following the first falling edge of the data input after the LD (Register 24-1) is set. Refer to Figure 24-13 for an example.

## 26.0 MASTER SYNCHRONOUS SERIAL PORT MODULE

Note: The PIC18(L)F26/45/46K40 devices have two MSSP. Therefore, all information in this section refers to both MSSP1 and MSSP2.

## 26.1 MSSP Module Overview

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

- Serial Peripheral Interface (SPI)
- Inter-Integrated Circuit (I<sup>2</sup>C)

The SPI interface supports the following modes and features:

- Master mode
- Slave mode
- · Clock Parity
- Slave Select Synchronization (Slave mode only)
- · Daisy-chain connection of slave devices

The  $I^2C$  interface supports the following modes and features:

- · Master mode
- Slave mode
- Byte NACKing (Slave mode)
- · Limited multi-master support
- 7-bit and 10-bit addressing
- Start and Stop interrupts
- · Interrupt masking
- Clock stretching
- · Bus collision detection
- · General call address matching
- · Address masking
- Address Hold and Data Hold modes
- Selectable SDA hold times

#### 26.2 SPI Mode Overview

The Serial Peripheral Interface (SPI) bus is a synchronous serial data communication bus that operates in Full-Duplex mode. Devices communicate in a master/slave environment where the master device initiates the communication. A slave device is controlled through a Chip Select known as Slave Select.

The SPI bus specifies four signal connections:

- Serial Clock (SCK)
- Serial Data Out (SDO)
- Serial Data In (SDI)
- Slave Select (SS)

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

### 27.2.1.5 TSR Status

The TRMT bit of the TXxSTA register indicates the status of the TSR register. This is a read-only bit. The TRMT bit is set when the TSR register is empty and is cleared when a character is transferred to the TSR register from the TXxREG. The TRMT bit remains clear until all bits have been shifted out of the TSR register. No interrupt logic is tied to this bit, so the user has to poll this bit to determine the TSR status.

| Note: | The TSR register is not mapped in data      |  |  |  |  |  |
|-------|---------------------------------------------|--|--|--|--|--|
|       | memory, so it is not available to the user. |  |  |  |  |  |

#### 27.2.1.6 Transmitting 9-Bit Characters

The EUSART supports 9-bit character transmissions. When the TX9 bit of the TXxSTA register is set, the EUSART will shift nine bits out for each character transmitted. The TX9D bit of the TXxSTA register is the ninth, and Most Significant data bit. When transmitting 9-bit data, the TX9D data bit must be written before writing the eight Least Significant bits into the TXxREG. All nine bits of data will be transferred to the TSR shift register immediately after the TXxREG is written.

A special 9-bit Address mode is available for use with multiple receivers. See **Section 27.2.2.7 "Address Detection"** for more information on the Address mode.

#### 27.2.1.7 Asynchronous Transmission Setup:

- Initialize the SPxBRGH, SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 27.4 "EUSART Baud Rate Generator (BRG)").
- 2. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit.
- 3. If 9-bit transmission is desired, set the TX9 control bit. A set ninth data bit will indicate that the eight Least Significant data bits are an address when the receiver is set for address detection.
- 4. Set SCKP bit if inverted transmit is desired.
- 5. Enable the transmission by setting the TXEN control bit. This will cause the TXxIF interrupt bit to be set.
- If interrupts are desired, set the TXxIE interrupt enable bit of the PIE3 register. An interrupt will occur immediately provided that the GIE and PEIE bits of the INTCON register are also set.
- 7. If 9-bit transmission is selected, the ninth bit should be loaded into the TX9D data bit.
- 8. Load 8-bit data into the TXxREG register. This will start the transmission.



#### FIGURE 27-3: ASYNCHRONOUS TRANSMISSION

| U-0                               | U-0                                                                | U-0                                                       | R/W-0/0       | R/W-0/0            | R/W-0/0      | R/W-0/0            | R/W-0/0 |  |  |
|-----------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------|---------------|--------------------|--------------|--------------------|---------|--|--|
| _                                 | _                                                                  | —                                                         |               |                    | ADACT<4:0>   |                    |         |  |  |
| bit 7                             |                                                                    |                                                           |               |                    |              |                    | bit     |  |  |
|                                   |                                                                    |                                                           |               |                    |              |                    |         |  |  |
| Legend:                           |                                                                    |                                                           |               |                    |              |                    |         |  |  |
| R = Readable bit W = Writable bit |                                                                    | it                                                        | U = Unimpleme | ented bit, read as | s 'O'        |                    |         |  |  |
| u = Bit is unch                   | nanged                                                             | x = Bit is unkno                                          | own           | -n/n = Value at    | POR and BOR/ | /alue at all other | Resets  |  |  |
| '1' = Bit is set                  |                                                                    | '0' = Bit is clea                                         | red           |                    |              |                    |         |  |  |
|                                   |                                                                    |                                                           |               |                    |              |                    |         |  |  |
| bit 7-5                           | •                                                                  | nented: Read as '0'                                       |               |                    |              |                    |         |  |  |
| bit 4-0                           | ADACT<4:0>: Auto-Conversion Trigger Select Bits                    |                                                           |               |                    |              |                    |         |  |  |
|                                   | 11111 = Software write to ADPCH                                    |                                                           |               |                    |              |                    |         |  |  |
|                                   | 11110 = Reserved, do not use<br>11101 = Software read of ADRESH    |                                                           |               |                    |              |                    |         |  |  |
|                                   | 11101 = Software read of ADRESH<br>11100 = Software read of ADERRH |                                                           |               |                    |              |                    |         |  |  |
|                                   | 1100 - Soliwale lead of ADERKH<br>11011 = Reserved, do not use     |                                                           |               |                    |              |                    |         |  |  |
|                                   | •                                                                  |                                                           |               |                    |              |                    |         |  |  |
|                                   | •                                                                  |                                                           |               |                    |              |                    |         |  |  |
|                                   | •                                                                  |                                                           |               |                    |              |                    |         |  |  |
|                                   | 10000 = Reserved, do not use                                       |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01111 = Interrupt-on-change Interrupt Flag                         |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01110 = C2_out                                                     |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01101 = C1_out                                                     |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01100 = PWM4_out<br>01011 = PWM3_out                               |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01011 = PVVM3_0ut<br>01010 = CCP2 trigger                          |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01001 = CCP1_trigger                                               |                                                           |               |                    |              |                    |         |  |  |
|                                   | 01000 = TMR6_postscaled                                            |                                                           |               |                    |              |                    |         |  |  |
|                                   | 00111 = TMR5_overflow                                              |                                                           |               |                    |              |                    |         |  |  |
|                                   | 00110 = TMR4_postscaled                                            |                                                           |               |                    |              |                    |         |  |  |
|                                   | 00101 = TMR3_overflow                                              |                                                           |               |                    |              |                    |         |  |  |
|                                   |                                                                    | MR2_postscaled                                            |               |                    |              |                    |         |  |  |
|                                   |                                                                    | MR1_overflow                                              |               |                    |              |                    |         |  |  |
|                                   |                                                                    | 00010 = TMR0_overflow<br>00001 = Pin selected by ADACTPPS |               |                    |              |                    |         |  |  |
|                                   |                                                                    |                                                           |               |                    |              |                    |         |  |  |

## REGISTER 31-32: ADACT: ADC AUTO CONVERSION TRIGGER CONTROL REGISTER

## 32.4 Comparator Hysteresis

A selectable amount of separation voltage can be added to the input pins of each comparator to provide a hysteresis function to the overall operation. Hysteresis is enabled by setting the CxHYS bit of the CMxCON0 register.

See Comparator Specifications in Table 37-15 for more information.

## 32.5 Timer1/3/5 Gate Operation

The output resulting from a comparator operation can be used as a source for gate control of Timer1/3/5. See **Section 19.8 "Timer1/3/5 Gate"** for more information. This feature is useful for timing the duration or interval of an analog event.

It is recommended that the comparator output be synchronized to Timer1. This ensures that Timer1 does not increment while a change in the comparator is occurring.

#### 32.5.1 COMPARATOR OUTPUT SYNCHRONIZATION

The output from a comparator can be synchronized with Timer1 by setting the SYNC bit of the CMxCON0 register.

Once enabled, the comparator output is latched on the falling edge of the Timer1 source clock. If a prescaler is used with Timer1, the comparator output is latched after the prescaling function. To prevent a race condition, the comparator output is latched on the falling edge of the Timer1 clock source and Timer1 increments on the rising edge of its clock source. See the Comparator Block Diagram (Figure 32-2) and the Timer1 Block Diagram (Figure 19-1) for more information.

## 32.6 Comparator Interrupt

An interrupt can be generated upon a change in the output value of the comparator for each comparator, a rising edge detector and a falling edge detector are present.

When either edge detector is triggered and its associated enable bit is set (CxINTP and/or CxINTN bits of the CMxCON1 register), the Corresponding Interrupt Flag bit (CxIF bit of the PIR2 register) will be set.

To enable the interrupt, you must set the following bits:

- EN and POL bits of the CMxCON0 register
- CxIE bit of the PIE2 register
- INTP bit of the CMxCON1 register (for a rising edge detection)
- INTN bit of the CMxCON1 register (for a falling edge detection)
- PEIE and GIE bits of the INTCON register

The associated interrupt flag bit, CxIF bit of the PIR2 register, must be cleared in software. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence.

**Note:** Although a comparator is disabled, an interrupt can be generated by changing the output polarity with the CxPOL bit of the CMxCON0 register, or by switching the comparator on or off with the CxEN bit of the CMxCON0 register.

## 32.7 Comparator Positive Input Selection

Configuring the PCH<2:0> bits of the CMxPCH register directs an internal voltage reference or an analog pin to the non-inverting input of the comparator:

- CxIN0+, CxIN1+ analog pin
- DAC output
- FVR (Fixed Voltage Reference)
- AVss (Ground)

See Section 28.0 "Fixed Voltage Reference (FVR)" for more information on the Fixed Voltage Reference module.

See Section 30.0 "5-Bit Digital-to-Analog Converter (DAC) Module" for more information on the DAC input signal.

Any time the comparator is disabled (CxEN = 0), all comparator inputs are disabled.

## 32.8 Comparator Negative Input Selection

The NCH<2:0> bits of the CMxNCH register direct an analog input pin and internal reference voltage or analog ground to the inverting input of the comparator:

- · CxIN0-, CxIN1-, CxIN2-, CxIN3- analog pin
- FVR (Fixed Voltage Reference)
- Analog Ground

Note: To use CxINy+ and CxINy- pins as analog input, the appropriate bits must be set in the ANSEL register and the corresponding TRIS bits must also be set to disable the output drivers.

# PIC18(L)F26/45/46K40

| RET          | FIE                                                     | Return fr                                                                                                        | Return from Interrupt                                                                                                                                                                                                                                                                                                                                                                                               |                             |                                             |  |  |  |
|--------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|---------------------------------------------|--|--|--|
| Synta        | ax:                                                     | RETFIE {                                                                                                         | RETFIE {s}                                                                                                                                                                                                                                                                                                                                                                                                          |                             |                                             |  |  |  |
| Operands:    |                                                         | $s \in [0,1]$                                                                                                    | s ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                           |                             |                                             |  |  |  |
| Operation:   |                                                         | $1 \rightarrow GIE/G$<br>if s = 1<br>(WS) $\rightarrow$ W<br>(STATUSS<br>(BSRS) $\rightarrow$                    | $(TOS) \rightarrow PC,$<br>$1 \rightarrow GIE/GIEH \text{ or PEIE/GIEL},$<br>if s = 1<br>$(WS) \rightarrow W,$<br>$(STATUSS) \rightarrow Status,$<br>$(BSRS) \rightarrow BSR,$<br>PCLATU, PCLATH are unchanged.                                                                                                                                                                                                     |                             |                                             |  |  |  |
| Statu        | s Affected:                                             | GIE/GIEH,                                                                                                        | PEIE/GI                                                                                                                                                                                                                                                                                                                                                                                                             | EL.                         |                                             |  |  |  |
| Enco         | ding:                                                   | 0000                                                                                                             | 0000                                                                                                                                                                                                                                                                                                                                                                                                                | 0001                        | l 000s                                      |  |  |  |
| Description: |                                                         | and Top-of<br>the PC. Int<br>setting eith<br>global intel<br>contents o<br>STATUSS<br>their corres<br>Status and | Return from interrupt. Stack is popped<br>and Top-of-Stack (TOS) is loaded into<br>the PC. Interrupts are enabled by<br>setting either the high or low priority<br>global interrupt enable bit. If 's' = 1, the<br>contents of the shadow registers, WS,<br>STATUSS and BSRS, are loaded into<br>their corresponding registers, W,<br>Status and BSR. If 's' = 0, no update of<br>these registers occurs (default). |                             |                                             |  |  |  |
| Word         | s:                                                      | 1                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                                             |  |  |  |
| Cycle        | es:                                                     | 2                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                                             |  |  |  |
| QC           | ycle Activity:                                          |                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                                             |  |  |  |
|              | Q1                                                      | Q2                                                                                                               | Q3                                                                                                                                                                                                                                                                                                                                                                                                                  | 3                           | Q4                                          |  |  |  |
|              | Decode                                                  | No<br>operation                                                                                                  | Nc<br>opera                                                                                                                                                                                                                                                                                                                                                                                                         | tion                        | POP PC<br>from stack<br>Set GIEH or<br>GIEL |  |  |  |
|              | No                                                      | No                                                                                                               | No                                                                                                                                                                                                                                                                                                                                                                                                                  |                             | No                                          |  |  |  |
|              | operation                                               | operation                                                                                                        | opera                                                                                                                                                                                                                                                                                                                                                                                                               | tion                        | operation                                   |  |  |  |
| Example:     |                                                         | RETFIE                                                                                                           | RETFIE 1                                                                                                                                                                                                                                                                                                                                                                                                            |                             |                                             |  |  |  |
|              | After Interrupt<br>PC<br>W<br>BSR<br>Status<br>GIE/GIEH | 1, PEIE/GIEL                                                                                                     | = V<br>= E<br>= S                                                                                                                                                                                                                                                                                                                                                                                                   | TOS<br>VS<br>BSRS<br>STATUS | SS                                          |  |  |  |

| RETLW                | Return I                                           | iteral to V                                                             | v         |                             |  |  |  |  |
|----------------------|----------------------------------------------------|-------------------------------------------------------------------------|-----------|-----------------------------|--|--|--|--|
| Syntax:              | RETLW                                              | RETLW k                                                                 |           |                             |  |  |  |  |
| Operands:            | $0 \le k \le 25$                                   | $0 \leq k \leq 255$                                                     |           |                             |  |  |  |  |
| Operation:           |                                                    | $k \rightarrow W,$ (TOS) $\rightarrow$ PC, PCLATU, PCLATH are unchanged |           |                             |  |  |  |  |
| Status Affected:     | None                                               |                                                                         |           |                             |  |  |  |  |
| Encoding:            | 0000                                               | 1100                                                                    | kkkk      | kkk                         |  |  |  |  |
| Description:         | program of the stat                                | ed with the<br>counter is lo<br>ck (the retu<br>ess latch (F            | baded fro | m the f<br>ss). Th          |  |  |  |  |
| Words:               | 1                                                  |                                                                         |           |                             |  |  |  |  |
| Cycles:              | 2                                                  |                                                                         |           |                             |  |  |  |  |
| Q Cycle Activity     | y:                                                 |                                                                         |           |                             |  |  |  |  |
| Q1                   | Q2                                                 | Q3                                                                      |           | Q4                          |  |  |  |  |
| Decode               | e Read<br>literal 'k'                              | Proce<br>Data                                                           | a fro     | POP Po<br>m stac<br>rite to |  |  |  |  |
| No                   | No                                                 | No                                                                      |           | No                          |  |  |  |  |
| operatio             | n operation                                        | operat                                                                  | ion o     | peratic                     |  |  |  |  |
| Example:             |                                                    |                                                                         |           |                             |  |  |  |  |
| CALL TAB             | LE ; W conta<br>; offset<br>; W now 1<br>; table y | value<br>has                                                            | le        |                             |  |  |  |  |
| TABLE                |                                                    |                                                                         |           |                             |  |  |  |  |
| ADDWF PC             |                                                    | ; W = offset                                                            |           |                             |  |  |  |  |
| RETLW k0<br>RETLW k1 | - 5                                                | cable                                                                   |           |                             |  |  |  |  |
| RETLW KI<br>:<br>:   | ;                                                  |                                                                         |           |                             |  |  |  |  |
| RETLW kn             | ; End of                                           | table                                                                   |           |                             |  |  |  |  |
|                      |                                                    |                                                                         |           |                             |  |  |  |  |

After Instruction W = value of kn

## 40-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) - 5x5 mm Body [UQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                            | MILLIMETERS |          |      |      |  |
|----------------------------|-------------|----------|------|------|--|
| Dimension                  | MIN         | NOM      | MAX  |      |  |
| Contact Pitch              | E           | 0.40 BSC |      |      |  |
| Optional Center Pad Width  | W2          |          |      | 3.80 |  |
| Optional Center Pad Length | T2          |          |      | 3.80 |  |
| Contact Pad Spacing        | C1          |          | 5.00 |      |  |
| Contact Pad Spacing        | C2          |          | 5.00 |      |  |
| Contact Pad Width (X40)    | X1          |          |      | 0.20 |  |
| Contact Pad Length (X40)   | Y1          |          |      | 0.75 |  |
| Distance Between Pads      | G           | 0.20     |      |      |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2156B