



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 64MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, DMA, HLVD, POR, PWM, WDT                           |
| Number of I/O              | 36                                                                         |
| Program Memory Size        | 128KB (64K x 16)                                                           |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 1K x 8                                                                     |
| RAM Size                   | 8K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 35x12b; D/A 1x5b                                                       |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Through Hole                                                               |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                   |
| Supplier Device Package    | 40-PDIP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf47k42-e-p |
|                            |                                                                            |

Email: info@E-XFL.COM

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

| Device         | Data Sheet Index | Program Flash Memory (KB) | Data EEPROM (B) | Data SRAM (bytes) | I/O Pins | 12-bit ADC <sup>2</sup><br>(ch) | 5-bit DAC | Comparator | 8-bit/ (with HLT) /16-bit Timer | Window Watchdog Timer<br>(WWDT) | Signal Measurement Timer<br>(SMT) | CCP/10-bit PWM | CWG | NCO | CLC | Zero-Cross Detect | Direct Memory Access (DMA)<br>(ch) | Memory Access Partition | Vectored Interrupts | UART | l²C/SPI | Peripheral Pin Select | Peripheral Module Disable | Debug <sup>(1)</sup> |
|----------------|------------------|---------------------------|-----------------|-------------------|----------|---------------------------------|-----------|------------|---------------------------------|---------------------------------|-----------------------------------|----------------|-----|-----|-----|-------------------|------------------------------------|-------------------------|---------------------|------|---------|-----------------------|---------------------------|----------------------|
| PIC18(L)F24K42 | А                | 16                        | 256             | 1024              | 25       | 24                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Υ                         | I                    |
| PIC18(L)F25K42 | А                | 32                        | 256             | 2048              | 25       | 24                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Υ                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Υ                         | I                    |
| PIC18(L)F26K42 | В                | 64                        | 1024            | 4096              | 25       | 24                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Υ                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Υ                         | I                    |
| PIC18(L)F27K42 | В                | 128                       | 1024            | 8192              | 25       | 24                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Υ                 | 2                                  | Υ                       | Y                   | 2    | 2/1     | Υ                     | Υ                         | I                    |
| PIC18(L)F45K42 | В                | 32                        | 256             | 2048              | 36       | 35                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Υ                       | Y                   | 2    | 2/1     | Υ                     | Υ                         | 1                    |
| PIC18(L)F46K42 | В                | 64                        | 1024            | 4096              | 36       | 35                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Υ                 | 2                                  | Υ                       | Y                   | 2    | 2/1     | Υ                     | Υ                         | I                    |
| PIC18(L)F47K42 | В                | 128                       | 1024            | 8192              | 36       | 35                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Y                         | I                    |
| PIC18(L)F55K42 | В                | 32                        | 256             | 2048              | 44       | 43                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Y                         | I                    |
| PIC18(L)F56K42 | В                | 64                        | 1024            | 4096              | 44       | 43                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Y                         | I                    |
| PIC18(L)F57K42 | В                | 128                       | 1024            | 8192              | 44       | 43                              | 1         | 2          | 3/4                             | Y                               | Y                                 | 4/4            | 3   | 1   | 4   | Y                 | 2                                  | Y                       | Y                   | 2    | 2/1     | Y                     | Υ                         | I                    |

Note 1: I – Debugging integrated on chip.

#### **Data Sheet Index:**

#### Unshaded devices are not described in this document.

DS40001869 PIC18(L)F24/25K42 Data Sheet, 28-Pin **A**:

B:

DS40001919

PIC18(L)F26/27/45/46/47/55/56/57K42 Data Sheet, 28/40/44/48-Pin

For other small form-factor package availability and marking information, visit **http://www.microchip.com/packaging** or contact your local sales office. Note:

| EXAMPLE 9-3                                    | SETTING UP VECTOR                                                                      | ED INTERRUPTS USING MPASM                                                                                                |
|------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| ISR_TMR0: CC<br>BANKSI<br>BCF<br>BTG<br>RETFIN | L PIRO<br>PIR3, TMROIF<br>LATC, 0, ACCESS                                              | ; ISR code at 0x08C0 in PFM<br>; Select bank for PIR0<br>; Clear TMR0IF<br>; Code to execute in ISR<br>; Return from ISR |
| InterruptInit                                  | :                                                                                      |                                                                                                                          |
| BANKSI                                         | L INTCONO                                                                              | ; Select bank for INTCON0                                                                                                |
| BSF                                            | INTCONO, GIEH                                                                          | ; Enable high priority interrupts                                                                                        |
| BSF                                            | INTCONO, GIEL                                                                          | ; Enable low priority interrupts                                                                                         |
| BSF                                            | INTCONU, IPEN_INTC                                                                     | CON0 ; Enable interrupt priority                                                                                         |
| BANKSI                                         | CL PIEO                                                                                | ; Select bank for PIE0                                                                                                   |
| BSF                                            | PIE3, TMROIE                                                                           | ; Enable TMR0 interrupt                                                                                                  |
| BSF                                            | PIE4, TMR1IE                                                                           | ; Enable TMR1 interrupt                                                                                                  |
| BCF<br>RETURI                                  | IPR3, TMROIP<br>1 1                                                                    | ; Make TMR0 interrupt low priority                                                                                       |
| VectorTableIn                                  | it:                                                                                    |                                                                                                                          |
| ; Set                                          | IVTBASE (optional - defaul                                                             | t is 0x000008)                                                                                                           |
| MOVLW                                          | 0x00                                                                                   | ; This is optional                                                                                                       |
| MOVWF                                          |                                                                                        | ; If not included, then the                                                                                              |
| MOVLW                                          | 0x40                                                                                   | ; hardware default value of                                                                                              |
| MOVWF                                          | IVTBASEH, ACCESS                                                                       | ; 0x0008 will be taken.                                                                                                  |
| MOVLW<br>MOVWF                                 | 0x08<br>IVTBASEL, ACCESS                                                               |                                                                                                                          |
| 110 VW1                                        |                                                                                        |                                                                                                                          |
| ; TMR(                                         | vector at IVTBASE + 2*(TM                                                              | R0 vector number i.e. 31) = 0x4046                                                                                       |
| MOVLW                                          | 0x00                                                                                   | ; Load TBLPTR with the                                                                                                   |
| MOVWF                                          | TBLPTRU, ACCESS                                                                        | ; PFM memory location to be                                                                                              |
| MOVLW<br>MOVWF                                 | 0x40<br>TBLPTRH, ACCESS                                                                | ; written to.                                                                                                            |
| MOVIW                                          | 0x46                                                                                   |                                                                                                                          |
| MOVWF                                          | TBLPTRL, ACCESS                                                                        |                                                                                                                          |
|                                                | te the contents of TMR0 vector<br>TMR0_ADDRESS >> 2 = 0x08C0<br>0x30<br>TABLAT, ACCESS |                                                                                                                          |
| TBLWT                                          |                                                                                        | ; Write to temp table latch                                                                                              |
|                                                |                                                                                        | ,                                                                                                                        |
| MOVLW                                          | 0x02                                                                                   | ; High byte next                                                                                                         |
| MOVWF<br>TBLWT:                                | TABLAT, ACCESS                                                                         | ; Write to temp table latch                                                                                              |
|                                                |                                                                                        | ,                                                                                                                        |
|                                                | e to PFM now using NVMCON                                                              |                                                                                                                          |
| BANKSI                                         |                                                                                        | ; Select bank for NVMCON1                                                                                                |
| MOVLW                                          | 0x84                                                                                   | ; Setting to write to PFM                                                                                                |
| MOVWF                                          | NVMCON1                                                                                |                                                                                                                          |
| MOVLW                                          | 0x55                                                                                   | ; Required unlock sequence                                                                                               |
| MOVWF                                          | NVMCON2                                                                                |                                                                                                                          |
| MOVLW                                          | 0 x A A                                                                                |                                                                                                                          |
| MOVWF                                          | NVMCON2                                                                                |                                                                                                                          |
| BSF                                            | NVMCON1, WR                                                                            | ; Start writing to PFM                                                                                                   |
| BTFSC                                          | NVMCON1, WR                                                                            | ; Wait for write to complete                                                                                             |
| GOTO                                           | \$-2                                                                                   |                                                                                                                          |
| RETURI                                         | 1                                                                                      |                                                                                                                          |
|                                                | -                                                                                      |                                                                                                                          |
| L                                              |                                                                                        |                                                                                                                          |

#### EXAMPLE 9-3: SETTING UP VECTORED INTERRUPTS USING MPASM

# 14.0 CYCLIC REDUNDANCY CHECK (CRC) MODULE WITH MEMORY SCANNER

The Cyclic Redundancy Check (CRC) module provides a software-configurable hardware-implemented CRC checksum generator. This module includes the following features:

- Any standard CRC up to 16 bits can be used
- Configurable Polynomial
- · Any seed value up to 16 bits can be used
- · Standard and reversed bit order available
- Augmented zeros can be added automatically or by the user
- Memory scanner for fast CRC calculations on program/Data EEPROM memory user data
- Software loadable data registers for communication CRC's

# 14.1 CRC Module Overview

The CRC module provides a means for calculating a check value of program/Data EEPROM memory. The CRC module is coupled with a memory scanner for faster CRC calculations. The memory scanner can automatically provide data to the CRC module. The CRC module can also be operated by directly writing data to SFRs, without using a scanner.

# 14.5 CRC Check Value

The CRC check value will be located in the CRCACC registers after the CRC calculation has finished. The check value will depend on two mode settings of the CRCCON0 register: ACCM and SHIFTM. When the ACCM bit is set, the CRC module augments the data with a number of zeros equal to the length of the polynomial to align the final check value. When the ACCM bit is not set, the CRC will stop at the end of the data. A number of zeros equal to the length of the polynomial can then be entered into CRCDAT to find the same check value as augmented mode. Alternatively, the expected check value can be entered at this point to make the final result equal '0'.

When the CRC check value is computed with the SHIFTM bit set, selecting LSb first, and the ACCM bit is also set, then the final value in the CRCACC registers will be reversed such that the LSb will be in the MSb position and vice versa. This is the expected check value in bit reversed form. If you are creating a check value to be appended to a data stream, then a bit reversal must be performed on the final value to achieve the correct checksum. You can use the CRC to do this reversal by the following method:

- Save the CRCACC value in user RAM space
- Clear the CRCACC registers
- Clear the CRCXOR registers
- Write the saved CRCACC value to the CRCDAT input.

The properly oriented check value will be in the CRCACC registers as the result.

# 14.6 CRC Interrupt

The CRC will generate an interrupt when the BUSY bit transitions from 1 to 0. The CRCIF Interrupt Flag is set every time the BUSY bit transitions, regardless of whether or not the CRC interrupt is enabled. The CRCIF bit can only be cleared in software.

# 14.7 Configuring the CRC

The following steps illustrate how to properly configure the CRC.

- Determine if the automatic program memory scan will be used with the scanner or manual calculation through the SFR interface and perform the actions specified in Section 14.4 "CRC Data Sources", depending on which decision was made.
- 2. If desired, seed a starting CRC value into the CRCACCH/L registers.
- 3. Program the CRCXORH/L registers with the desired generator polynomial.
- Program the DLEN<3:0> bits of the CRCCON1 register with the length of the data word - 1 (refer to Example 14-1). This determines how many times the shifter will shift into the accumulator for each data word.
- 5. Program the PLEN<3:0> bits of the CRCCON1 register with the length of the polynomial -2 (refer to Example 14-1).
- 6. Determine whether shifting in trailing zeros is desired and set the ACCM bit of the CRCCON0 register appropriately.
- 7. Likewise, determine whether the MSb or LSb should be shifted first and write the SHIFTM bit of the CRCCON0 register appropriately.
- 8. Write the GO bit of the CRCCON0 register to begin the shifting process.
- 9a. If manual SFR entry is used, monitor the FULL bit of the CRCCON0 register. When FULL = 0, another word of data can be written to the CRCDATH/L registers, keeping in mind that CRCDATH should be written first if the data has more than eight bits, as the shifter will begin upon the CRCDATL register being written.
- 9b. If the scanner is used, the scanner will automatically load words into the CRCDATH/L registers as needed, as long as the GO bit is set.
- 10a. If manual entry is used, monitor the CRCIF (and BUSY bit to determine when the completed CRC calculation can be read from CRCACCH/L registers.
- 10b.If using the memory scanner, monitor the SCANIF (or the GO bit) for the scanner to finish pushing information into the CRCDAT registers. After the scanner is completed, monitor the BUSY bit to determine that the CRC has been completed and the check value can be read from the CRCACC registers. If both the interrupt flags are set and the BUSY and GO bits are cleared, the completed CRC calculation can be read from the CRCACCH/L registers.

## TABLE 17-2: PPS OUTPUT REGISTER DETAILS

| D DD0 (5.0)              |                       |     | Device Configuration |     |   |      |              |       |   |                      |   |   |   |   |   |  |
|--------------------------|-----------------------|-----|----------------------|-----|---|------|--------------|-------|---|----------------------|---|---|---|---|---|--|
| RxyPPS<5:0>              | Pin Rxy Output Source | PIC | 18(L)F26/27          | K42 |   | PIC1 | 8(L)F45/46/4 | 17K42 |   | PIC18(L)F55/56/57K42 |   |   |   |   |   |  |
| 0b01 0010 -<br>0b01 0001 | Reserved              |     |                      |     |   |      |              |       |   |                      |   |   |   |   |   |  |
| 0b01 0000                | PWM8                  | А   | —                    | С   | А | _    | _            | D     | _ | Α                    | — | — | D | — | — |  |
| 0b00 1111                | PWM7                  | А   | —                    | С   | А | _    | С            | _     | _ | _                    | — | С | — | — | F |  |
| 0b00 1110                | PWM6                  | А   | —                    | С   | А | —    | _            | D     | _ | Α                    | — | — | D | — | — |  |
| 0b00 1101                | PWM5                  | А   | —                    | С   | А | _    | С            | _     | _ | Α                    | — | — | — | — | F |  |
| 0b00 1100                | CCP4                  | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0b00 1011                | CCP3                  | -   | В                    | С   | _ | В    | _            | D     | - |                      | В | — | D | — | — |  |
| 0b00 1010                | CCP2                  | _   | В                    | С   | — | В    | С            | _     | _ | _                    | — | С | — | — | F |  |
| 0b00 1001                | CCP1                  | _   | В                    | С   | — | В    | С            | _     | _ | _                    | — | С | — | — | F |  |
| 0b00 1000                | CWG1D                 | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0b00 0111                | CWG1C                 | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0b00 0110                | CWG1B                 | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0b00 0101                | CWG1A                 | _   | В                    | С   | — | В    | С            | _     | _ | _                    | В | С | — | — | — |  |
| 0b00 0100                | CLC4OUT               | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0b00 0011                | CLC3OUT               | _   | В                    | С   | — | В    | _            | D     | _ | —                    | В | — | D | — | — |  |
| 0600 0010                | CLC2OUT               | А   | _                    | С   | А | _    | С            | _     |   | Α                    | — | — | — | — | F |  |
| 0600 0001                | CLC1OUT               | А   | _                    | С   | Α | _    | С            | _     | - | Α                    | — | — | — | — | F |  |
| 0000 0000                | LATxy                 | А   | В                    | С   | Α | В    | С            | D     | E | Α                    | В | С | D | E | F |  |

# 18.0 INTERRUPT-ON-CHANGE

PORTA, PORTB, PORTC and pin RE3 of PORTE can be configured to operate as Interrupt-on-Change (IOC) pins on PIC18(L)F26/27/45/46/47/55/56/57K42 family devices. An interrupt can be generated by detecting a signal that has either a rising edge or a falling edge. Any individual port pin, or combination of port pins, can be configured to generate an interrupt. The interrupt-onchange module has the following features:

- Interrupt-on-Change enable (Master Switch)
- Individual pin configuration
- · Rising and falling edge detection
- · Individual pin interrupt flags

Figure 18-1 is a block diagram of the IOC module.

## 18.1 Enabling the Module

To allow individual port pins to generate an interrupt, the IOCIE bit of the PIEx register must be set. If the IOCIE bit is disabled, the edge detection on the pin will still occur, but an interrupt will not be generated.

## 18.2 Individual Pin Configuration

For each port pin, a rising edge detector and a falling edge detector are present. To enable a pin to detect a rising edge, the associated bit of the IOCxP register is set. To enable a pin to detect a falling edge, the associated bit of the IOCxN register is set.

A pin can be configured to detect rising and falling edges simultaneously by setting both associated bits of the IOCxP and IOCxN registers, respectively.

# 18.3 Interrupt Flags

The IOCAFx, IOCBFx, IOCCFx and IOCEF3 bits located in the IOCAF, IOCBF, IOCCF and IOCEF registers respectively, are status flags that correspond to the interrupt-on-change pins of the associated port. If an expected edge is detected on an appropriately enabled pin, then the status flag for that pin will be set, and an interrupt will be generated if the IOCIE bit is set. The IOCIF bit of the PIRO register reflects the status of all IOCAFx, IOCBFx, IOCCFx and IOCEF3 bits.

# 18.4 Clearing Interrupt Flags

The individual status flags, (IOCAFx, IOCBFx, IOCCFx and IOCEF3 bits), can be cleared by resetting them to zero. If another edge is detected during this clearing operation, the associated status flag will be set at the end of the sequence, regardless of the value actually being written.

In order to ensure that no detected edge is lost while clearing flags, only AND operations masking out known changed bits should be performed. The following sequence is an example of what should be performed.

#### EXAMPLE 18-1: CLEARING INTERRUPT FLAGS (PORTA EXAMPLE)

| MOVLW | 0xff   |   |
|-------|--------|---|
| XORWF | IOCAF, | W |
| ANDWF | IOCAF, | F |
|       |        |   |

# 18.5 Operation in Sleep

The interrupt-on-change interrupt sequence will wake the device from Sleep mode, if the IOCIE bit is set.

If an edge is detected while in Sleep mode, the IOCxF register will be updated prior to the first instruction executed out of Sleep.

| REGISTER      | 21-2: IXGC                                                                                  | UN: HMER                                                          | X GATE CO                        | NIROL REGIS                                                                       | IER                                |                  |       |
|---------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------|------------------------------------|------------------|-------|
| R/W-0/u       | R/W-0/u                                                                                     | R/W-0/u                                                           | R/W-0/u                          | R/W-0/u                                                                           | R-x                                | U-0              | U-0   |
| GE            | GPOL                                                                                        | GTM                                                               | GSPM                             | GGO/DONE                                                                          | GVAL                               | _                | _     |
| bit 7         |                                                                                             |                                                                   |                                  |                                                                                   |                                    |                  | bit 0 |
|               |                                                                                             |                                                                   |                                  |                                                                                   |                                    |                  |       |
| Legend:       |                                                                                             |                                                                   |                                  |                                                                                   |                                    |                  |       |
| R = Readable  | e bit                                                                                       | W = Writable                                                      | bit                              | U = Unimpleme                                                                     | nted bit, read as                  | s 'O'            |       |
| -n = Value at | POR                                                                                         | '1' = Bit is se                                                   | t                                | '0' = Bit is cleare                                                               | ed                                 | x = Bit is unkno | own   |
| bit 7         | If TMRxON =           1 =         Timerx           0 =         Timerx           If TMRxON = | counting is co<br>is always cour                                  | ntrolled by th                   | e Timerx gate fur                                                                 | nction                             |                  |       |
| bit 6         | 1 = Timerx                                                                                  |                                                                   | -high (Timerx                    | counts when gat                                                                   |                                    |                  |       |
| bit 5         | 1 = Timerx<br>0 = Timerx                                                                    | Gate Toggle I<br>Gate Toggle m<br>Gate Toggle m<br>Flip Flop Togg | node is enabl<br>node is disabl  | ed and Toggle flip                                                                | p-flop is cleared                  |                  |       |
| bit 4         | 1 = Timerx                                                                                  | rx Gate Single<br>Gate Single P<br>Gate Single P                  | ulse mode is                     | enabled and is co                                                                 | ontrolling Timer                   | gate)            |       |
| bit 3         | 1 = Timerx<br>0 = Timerx                                                                    | Gate Single P<br>Gate Single P                                    | ulse Acquisiti<br>ulse Acquisiti | Acquisition Status<br>on is ready, waitii<br>on has completed<br>(GSPM is cleared | ng for an edge<br>d or has not bee | n started.       |       |
| bit 2         | Indicates the                                                                               | rx Gate Currer<br>current state o<br>y Timerx Gate                | of the Timerx                    | gate that could b<br>RxGE)                                                        | e provided to TN                   | MRxH:TMRxL       |       |
| bit 1-0       | Unimpleme                                                                                   | nted: Read as                                                     | ʻ0 <b>'</b>                      |                                                                                   |                                    |                  |       |
|               |                                                                                             |                                                                   |                                  |                                                                                   |                                    |                  |       |

#### REGISTER 21-2: TxGCON: TIMERx GATE CONTROL REGISTER

# 22.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 TMR2\_ers, as shown in Figure 22-7. Selecting MODE<4:0> = 00110 will cause the timer to reset on a low level external signal. Selecting MODE<4:0> = 00111 will cause the timer to reset on a high level external signal. In the example, the counter is reset while TMR2\_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 T2PR 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 T2PR 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.



|                              | Rev. 10.00/98C<br>912295                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODE                         | 0b00111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TMRx_clk                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TxPR                         | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Instruction <sup>(1)</sup> - | BSF BSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ON                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TMRx_ers                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TxTMR                        | $0  \begin{pmatrix} 1 \\ 2 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 5 \\ 0 \\ 1 \\ 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 0 \\ \end{pmatrix} \\ \begin{pmatrix} 0 \\ 1 \\ 2 \\ 3 \\ 1 \\ 2 \\ 1 \\ 1 \\ 2 \\ 1 \\ 1 \\ 2 \\ 1 \\ 1$ |
| TMRx_postscaled              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PWM Duty<br>Cycle            | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PWM Output                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                              | : BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 22.5.8 LEVEL RESET, EDGE-TRIGGERED HARDWARE LIMIT ONE-SHOT MODES

In Level Triggered One-Shot mode, the timer count is reset on the external signal level and starts counting on the rising/falling edge of the transition from reset level to the active level while the ON bit is set. Reset levels are selected as follows:

• Low reset level (MODE<4:0> = 01110)

• High reset level (MODE<4:0> = 01111)

When the timer count matches the T2PR period count, the timer is reset and the ON bit is cleared. When the ON bit is cleared by either a T2PR match or by software control a new external signal edge is required after the ON bit is set to start the counter.

When Level Triggered Reset One-Shot mode is used in conjunction with the CCP PWM operation, the PWM drive goes active with the external signal edge that starts the timer. The PWM drive goes inactive when the timer count equals the CCPRx pulse-width count. The PWM drive does not go active when the timer count clears at the T2PR period count match.

PIC18(L)F26/27/45/46/47/55/56/57K42

#### FIGURE 22-11: LOW LEVEL RESET, EDGE-TRIGGERED HARDWARE LIMIT ONE-SHOT MODE TIMING DIAGRAM (MODE = 01110)



#### **REGISTER 28-8:** NCO1INCU: NCO1 INCREMENT REGISTER – UPPER BYTE<sup>(1)</sup>

| U-0   | U-0 | U-0 | U-0 | R/W-0/0    | R/W-0/0 | R/W-0/0 | R/W-0/0 |  |  |  |
|-------|-----|-----|-----|------------|---------|---------|---------|--|--|--|
| —     | —   | _   | —   | INC<19:16> |         |         |         |  |  |  |
| 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-4 Unimplemented: Read as '0'

bit 3-0 INC<19:16>: NCO1 Increment, Upper Byte

**Note 1:** The logical increment spans NCO1INCU:NCO1INCH:NCO1INCL.

TABLE 28-1: SUMMARY OF REGISTERS ASSOCIATED WITH NCO

| Name     | Bit 7        | Bit 6     | Bit 5 | Bit 4    | Bit 3 | Bit 2   | Bit 1     | Bit 0 | Register<br>on Page |
|----------|--------------|-----------|-------|----------|-------|---------|-----------|-------|---------------------|
| NCO1CON  | N1EN         | —         | N1OUT | N1POL    | _     | _       |           | N1PFM | 453                 |
| NCO1CLK  |              | N1PWS<2:0 | )>    | —        | _     | N       | 1CKS<2:0> |       | 454                 |
| NCO1ACCL | NCO1ACC<7:0> |           |       |          |       |         |           |       |                     |
| NCO1ACCH |              |           |       | NCO1ACC< | 15:8> |         |           |       | 455                 |
| NCO1ACCU | _            | _         | —     | —        |       | NCO1ACC | <19:16>   |       | 456                 |
| NCO1INCL |              |           |       | NCO1INC< | 7:0>  |         |           |       | 456                 |
| NCO1INCH |              |           |       | NCO1INC< | 15:8> |         |           |       | 456                 |
| NCO1INCU | —            | —         | —     | —        |       | NCO1INC | <19:16>   |       | 457                 |

**Legend:** – = unimplemented read as '0'. Shaded cells are not used for NCO module.



# 31.5 LIN Modes (UART1 only)

LIN is a protocol used primarily in automotive applications. The LIN network consists of two kinds of software processes: a Master process and a Slave process. Each network has only one Master process and one or more Slave processes.

From a physical layer point of view, the UART on one processor may be driven by both a Master and a Slave process, as long as only one Master process exists on the network.

A LIN transaction consists of a Master process followed by a Slave process. The Slave process may involve more than one Slave where one is transmitting and the other(s) are receiving. The transaction begins by the following Master process transmission sequence:

- 1. Break
- 2. Delimiter bit
- 3. Sync Field
- 4. PID byte

The PID determines which Slave processes are expected to respond to the Master. When the PID byte is complete, the TX output remains in the Idle state. One or more of the Slave processes may respond to the Master process. If no one responds within the interbyte period, the Master is free to start another transmission. The inter-byte period is timed by software using a means other than the UART.

The Slave process follows the Master process. When the Slave software recognizes the PID then that Slave process responds by either transmitting the required response or by receiving the transmitted data. Only Slave processes send data. Therefore, Slave processes receiving data are receiving that of another Slave process.

When a Slave sends data, the Slave UART automatically calculates the checksum for the transmitted bytes as they are sent and appends the inverted checksum byte to the slave response.

When a Slave receives data, the checksum is accumulated on each byte as it is received using the same algorithm as the sending process. The last byte, which is the inverted checksum value calculated by the sending process, is added to the locally calculated checksum by the UART. The check passes when the result is all '1's, otherwise the check fails and the CERIF bit is set.

Two methods for computing the checksum are available: legacy and enhanced. The legacy checksum includes only the data bytes. The enhanced checksum includes the PID and the data. The COEN control bit in the UxCON2 register determines the checksum method. Setting COEN to '1' selects the enhanced method. Software must select the appropriate method before the Start bit of the checksum byte is received.

#### 31.5.1 LIN MASTER/SLAVE MODE

The LIN Master mode includes capabilities to generate Slave processes. The Master process stops at the PID transmission. Any data that is transmitted in Master/ Slave mode is done as a Slave process. LIN Master/ Slave mode is configured by the following settings:

- MODE<3:0> = 1100
- **TXEN =** 1
- RXEN = 1
- UxBRGH:L = Value to achieve desired baud rate
- TXPOL = 0 (for high Idle state)
- STP = desired Stop bits selection
- C0EN = desired checksum mode
- RxyPPS = TX pin selection code
- TX pin TRIS control = 0
- ON = 1

Note: The TXEN bit must be set before the Master process is received and remain set while in LIN mode whether or not the slave process is a transmitter.

# 31.9 Stop Bits

The number of Stop bits is user selectable with the STP bits in the UxCON2 register. The STP bits affect all modes of operation.

Stop bits selections include:

- 1 transmit with receive verify on first
- 1.5 transmit with receive verify on first
- · 2 transmit with receive verify on both
- · 2 transmit with receive verify on first only

In all modes, except DALI, the transmitter is idle for the number of Stop bit periods between each consecutively transmitted word. In DALI, the Stop bits are generated after the last bit in the transmitted data stream.

The input is checked for the idle level in the middle of the first Stop bit, when receive verify on first is selected, as well as in the middle of the second Stop bit, when verify on both is selected. If any Stop bit verification indicates a non-idle level, the framing error FERIF bit is set for the received word.

#### 31.9.1 DELAYED UXRXIF

When operating in Half-Duplex mode, where the microcontroller needs to reverse the transceiver direction after a reception, it may be more convenient to hold off the UxRXIF interrupt until the end of the Stop bits to avoid line contention. The user selects when the UxRXIF interrupt occurs with the STPMD bit in the UxFIFO register. When STPMD is '1', the UxRXIF occurs at the end of the last Stop bit. When STPMD is '0', UxRXIF occurs when the received byte is stored in the receive FIFO. When STP < 1:0 > = 10, the store operation is performed in the middle of the second Stop bit, otherwise, it is performed in the middle of the first Stop bit. The FERIF and PERIF interrupts are not delayed with STPMD. Only UxRXIF is delayed when STPMD is set and should be the only indicator for reversing transceiver direction.

## 31.10 Operation after FIFO overflow

The Receive Shift Register (RSR) can be configured to stop or continue running during a receive FIFO overflow condition. Stopped operation is the Legacy mode.

When the RSR continues to run during an overflow condition, the first word received after clearing the overflow will always be valid.

When the RSR is stopped during an overflow condition, synchronization with the Start bits is lost. Therefore, the first word received after the overflow is cleared may start in the middle of a word.

Operation during overflow is selected with the RUNOVF bit in the UxCON2 register. Setting the RUNOVF bit selects the run during overflow method.

## 31.11 Receive and Transmit Buffers

The UART uses small buffer areas to transmit and receive data. These are sometimes referred to as FIFOs.

The receiver has a Receive Shift Register (RSR) and two buffer registers. The buffer at the top of the FIFO (earliest byte to enter the FIFO) is by retrieved by reading the UxRXB register.

The transmitter has one Transmit Shift Register (TSR) and one buffer register. Writes to UxTXB go to the transmit buffer then immediately to the TSR, if it is empty. When the TSR is not empty, writes to UxTXB are held then transferred to the TSR when it becomes available.

#### 31.11.1 FIFO STATUS

The UxFIFO register contains several status bits for determining the state of the receive and transmit buffers.

The RXBE bit indicates that the receive FIFO is empty. This bit is essentially the inverse of UxRXIF. The RXBF bit indicates that the receive FIFO is full.

The transmitter has only one buffer register so the status bits are essentially a copy and inverse of the UxTXIF bit. The TXBE bit indicates that the buffer is empty (same as UxTXIF) and the TXBF bit indicates that the buffer is full (UxTXIF inverse). A third transmitter status bit, TXWRE (transmit write error), is set whenever a UxTXB write is performed when the TXBF bit is set. This indicates that the write was unsuccessful.

#### 31.11.2 FIFO RESET

All modes support resetting the receive and transmit buffers.

The receive buffer is flushed and all unread data discarded when the RXBE bit in the UxFIFO register is written to '1'. The MOVWF instruction with the TXBE bit cleared should be used to avoid inadvertently clearing a byte pending in the TSR when UxTXB is empty.

Data written to UxTXB when TXEN is low will be held in the Transmit Shift Register (TSR) then sent when TXEN is set. The transmit buffer and inactive TSR are flushed by setting the TXBE bit in the UxFIFO register. Setting TXBE while a character is actively transmitting from the TSR will complete the transmission without being flushed.

Clearing the ON bit will discard all received data and transmit data pending in the TSR and UxTXB.

U = Unimplemented bit, read as '0'

-n/n = Value at POR and BOR/Value at all other Resets

| U-0     | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0/0 |
|---------|-----|-----|-----|-----|-----|-----|---------|
| _       | —   | _   |     |     | —   | _   | P3<8>   |
| bit 7   |     |     |     |     |     |     | bit 0   |
|         |     |     |     |     |     |     |         |
| Legend: |     |     |     |     |     |     |         |

#### REGISTER 31-16: UxP3H: UART PARAMETER 3 HIGH REGISTER

W = Writable bit

x = Bit is unknown

'0' = Bit is cleared

P3<8>: Most Significant Bit of Parameter 3

Unimplemented: Read as '0'

DMX mode:

Other modes: Not used

R = Readable bit

'1' = Bit is set

bit 7-6

bit 0

u = Bit is unchanged

# REGISTER 31-17: UxP3L: UART PARAMETER 3 LOW REGISTER

Most Significant bit of last address of receive block

| R/W-0/0 |  |
|---------|---------|---------|---------|---------|---------|---------|---------|--|
| P3<7:0> |         |         |         |         |         |         |         |  |
| bit 7   |         |         |         |         |         |         |         |  |

| 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-0
P3<7:0>: Least Significant Bits of Parameter 3
DMX mode:
Least Significant Byte of last address of receive block
LIN Slave mode:
Number of data bytes to receive
Asynchronous Address mode:
Receiver address mask. Received address is XOR'd with UxP2L then AND'd with UxP3L
Match occurs when result is zero
Other modes:
Not used

| R/W-0/0      | R/W-0/0                                              | R/W-0/0          | R/W-0/0         | U-0         | R/W-0/0          | R/W-0/0  | U-0 |  |  |  |  |
|--------------|------------------------------------------------------|------------------|-----------------|-------------|------------------|----------|-----|--|--|--|--|
| SRMTIE       | TCZIE                                                | SOSIE            | EOSIE           |             | RXOIE            | TXUIE    | _   |  |  |  |  |
| bit 7        |                                                      |                  |                 |             |                  |          | bit |  |  |  |  |
| Legend:      |                                                      |                  |                 |             |                  |          |     |  |  |  |  |
| R = Readable | e bit                                                | W = Writable     | bit             | U = Unimple | mented bit, read | l as '0' |     |  |  |  |  |
|              |                                                      |                  |                 |             |                  |          |     |  |  |  |  |
| bit 7        | SRMTIE: Shift Register Empty Interrupt Enable bit    |                  |                 |             |                  |          |     |  |  |  |  |
|              | 1 = Enables the Shift Register Empty Interrupt       |                  |                 |             |                  |          |     |  |  |  |  |
|              | 0 = Disables the Shift Register Empty Interrupt      |                  |                 |             |                  |          |     |  |  |  |  |
| bit 6        | TCZIE: Transfer Counter is Zero Interrupt Enable bit |                  |                 |             |                  |          |     |  |  |  |  |
|              | 1 = Enables the Transfer Counter is Zero Interrupt   |                  |                 |             |                  |          |     |  |  |  |  |
|              | 0 = Disables the Transfer Counter is Zero Interrupt  |                  |                 |             |                  |          |     |  |  |  |  |
| bit 5        | SOSIE: Start of Slave Select Interrupt Enable bit    |                  |                 |             |                  |          |     |  |  |  |  |
|              | 1 = Enables the Start of Slave Select Interrupt      |                  |                 |             |                  |          |     |  |  |  |  |
|              | 0 = Disables the Start of Slave Select Interrupt     |                  |                 |             |                  |          |     |  |  |  |  |
| bit 4        | EOSIE: End of Slave Select Interrupt Enable bit      |                  |                 |             |                  |          |     |  |  |  |  |
|              | 1 = Enables the End of Slave Select Interrupt        |                  |                 |             |                  |          |     |  |  |  |  |
|              | 0 = Disables the End of Slave Select Interrupt       |                  |                 |             |                  |          |     |  |  |  |  |
| bit 3        | Unimplemen                                           | ted: Read as '   | 0'              |             |                  |          |     |  |  |  |  |
| bit 2        | RXOIE: Rece                                          | eiver Overflow I | nterrupt Enabl  | e bit       |                  |          |     |  |  |  |  |
|              | 1 = Enables the Receiver Overflow Interrupt          |                  |                 |             |                  |          |     |  |  |  |  |
|              | 0 = Disables                                         | the Receiver C   | verflow Interru | ıpt         |                  |          |     |  |  |  |  |
| bit 1        | TXUIE: Trans                                         | smitter Underflo | w Interrupt Er  | able bit    |                  |          |     |  |  |  |  |
|              | 1 = Enables t                                        | he Transmitter   | Underflow Inte  | errupt      |                  |          |     |  |  |  |  |
|              | 0 = Disables                                         | the Transmitter  | Underflow Int   | terrupt     |                  |          |     |  |  |  |  |
| bit 0        | Unimplemen                                           | ted: Read as '   | 0'              |             |                  |          |     |  |  |  |  |

#### **REGISTER 32-3:** SPIXTCNTL – SPI TRANSFER COUNTER LSB REGISTER

| R/W-0/0 | R/W-0/0 R/W-0/0 R/ |       | /-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W- |   | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|---------|--------------------|-------|------------------------------------|---|---------|---------|---------|
| TCNT7   | TCNT6              | TCNT5 | TCNT4 TCNT3 TC                     |   | TCNT2   | TCNT1   | TCNT0   |
| bit 7   | •                  |       |                                    | • |         |         | bit 0   |

| Legend:                                 |                    |                             |                                                            |  |
|-----------------------------------------|--------------------|-----------------------------|------------------------------------------------------------|--|
| R = Read                                | lable bit          | W = Writable bit            | U = Unimplemented bit, read as '0'                         |  |
|                                         |                    |                             |                                                            |  |
| bit 7-0                                 | TCNT<7:0>          |                             |                                                            |  |
|                                         | BMODE = 0          |                             |                                                            |  |
|                                         | Bits 10-3 of t     | he Transfer Counter, cou    | unting the total number of bits to transfer                |  |
|                                         | <b>BMODE =</b> 1   |                             |                                                            |  |
| Bits 7-0 of the Transfer Counter, count |                    | e Transfer Counter, cour    | nting the total number of bytes to transfer                |  |
| Note:                                   | This register shou | uld not be written to while | e a transfer is in progress (BUSY bit of SPIxCON2 is set). |  |

© 2017 Microchip Technology Inc.

| REGISTE                                                                                       | ER 33-6: I2CxS                                                                                                                                                                                                                                                                                                                                                                                     | TAT0: I <sup>2</sup> C ST                                                | ATUS REGI                                                                       | STER 0                                                           |                               |                                                               |             |
|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------|---------------------------------------------------------------|-------------|
| R-0                                                                                           | R-0                                                                                                                                                                                                                                                                                                                                                                                                | R-0                                                                      | R-0                                                                             | R-0                                                              | U-0                           | U-0                                                           | U-0         |
| BFRE <sup>(</sup>                                                                             | <sup>3)</sup> SMA                                                                                                                                                                                                                                                                                                                                                                                  | MMA                                                                      | R <sup>(1, 2)</sup>                                                             | D                                                                | _                             | _                                                             | _           |
| bit 7                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                          |                                                                                 |                                                                  |                               |                                                               | bit 0       |
|                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                          |                                                                                 |                                                                  |                               |                                                               |             |
| Legend:                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                          |                                                                                 |                                                                  |                               |                                                               |             |
| R = Read                                                                                      | able bit                                                                                                                                                                                                                                                                                                                                                                                           | W = Writable                                                             | bit                                                                             | U = Unimpler                                                     | mented bit, read              | <b>d as</b> '0'                                               |             |
| u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                          |                                                                                 |                                                                  |                               |                                                               | ther Resets |
| '1' = Bit is                                                                                  | set                                                                                                                                                                                                                                                                                                                                                                                                | '0' = Bit is cle                                                         | ared                                                                            | HS = Hardwa                                                      | are set HC =                  | Hardware clear                                                | r           |
| bit 7                                                                                         | 1 = Indicates<br>Both SC<br>I2CCLK                                                                                                                                                                                                                                                                                                                                                                 | Cmust select a                                                           | idle<br>ive been high<br>valid clock so                                         | for time-out se<br>ource for this bit<br>ected, this bit re      | to function.                  | ON2 <bfret<1< td=""><td>:0&gt;&gt; bits.</td></bfret<1<>      | :0>> bits.  |
| bit 6                                                                                         | 1 = Set after<br>Set after<br>Set after<br>after a p<br>0 = Cleared                                                                                                                                                                                                                                                                                                                                | r the 8th falling<br>the 8th falling<br>previous match<br>by any Restart | SCL edge of a<br>SCL edge of<br>SCL edge of<br>ing high and I<br>/Stop detected | a received ma<br>a received mate<br>ow w/ write.<br>d on the bus |                               | e address<br>ave <b>low</b> address<br>ve <b>high</b> w/ read |             |
| bit 5                                                                                         | Cleared by BTOIF and BCLIF conditions<br><b>MMA:</b> Master Module Active Status bit<br>1 = Master Mode state machine is active<br>Set when master state machine asserts a Start on bus<br>0 = Master state machine is idle<br>Cleared when BCLIF is set<br>Cleared when Stop is shifted out by master.<br>Cleared for BTOIF condition, after the master successfully shifts out a Stop condition. |                                                                          |                                                                                 |                                                                  |                               |                                                               |             |
| bit 4                                                                                         | 1 = Indicates                                                                                                                                                                                                                                                                                                                                                                                      |                                                                          | ning received                                                                   | (high) address<br>(high) address                                 | was a Read rec<br>was a Write | quest                                                         |             |
| bit 3                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                          |                                                                                 | nsmitted was d<br>nsmitted was a                                 |                               |                                                               |             |
| bit 2-0                                                                                       | Unimplemen                                                                                                                                                                                                                                                                                                                                                                                         | ted: Read as                                                             | 1 <b>'</b> b0                                                                   |                                                                  |                               |                                                               |             |
| Note 1:                                                                                       | This bit holds the I<br>the Master or appe                                                                                                                                                                                                                                                                                                                                                         | earing on the b                                                          | us without a r                                                                  | natch do not af                                                  | fect this bit.                |                                                               | nsmitted by |
| 2:<br>3:                                                                                      | Clock requests an<br>Software must use                                                                                                                                                                                                                                                                                                                                                             |                                                                          | •                                                                               |                                                                  |                               | 3.                                                            |             |

#### REGISTER 36-24: ADACCU: ADC ACCUMULATOR REGISTER UPPER

| U-0                                                                          | U-0 | U-0 | U-0 | U-0                                | U-0          | R/W-x/x    | R/W-x/x |  |
|------------------------------------------------------------------------------|-----|-----|-----|------------------------------------|--------------|------------|---------|--|
| —                                                                            | _   | _   | —   |                                    | —            | ACC<17:16> |         |  |
| bit 7 bit 0                                                                  |     |     |     |                                    |              |            |         |  |
|                                                                              |     |     |     |                                    |              |            |         |  |
| Legend:                                                                      |     |     |     |                                    |              |            |         |  |
| R = Readable bit W = Writable bit                                            |     |     | bit | U = Unimplemented bit, read as '0' |              |            |         |  |
| u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at |     |     |     | R/Value at all o                   | other Resets |            |         |  |

bit 7-2 Unimplemented: Read as '0'

'1' = Bit is set

bit 1-0 ACC<17:16>: ADC Accumulator MSB. Upper two bits of accumulator value. See Table 36-2 for more details.

#### **REGISTER 36-25: ADACCH: ADC ACCUMULATOR REGISTER HIGH**

'0' = Bit is cleared

| R/W-x/x   | R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/V |  |  |  |  | R/W-x/x | R/W-x/x |  |
|-----------|-------------------------------------|--|--|--|--|---------|---------|--|
| ACC<15:8> |                                     |  |  |  |  |         |         |  |
| bit 7 b   |                                     |  |  |  |  |         |         |  |

| 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-0 ACC<15:8>: ADC Accumulator middle bits. Middle eight bits of accumulator value. See Table 36-2 for more details.

#### REGISTER 36-26: ADACCL: ADC ACCUMULATOR REGISTER LOW

| R/W-x/x     | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x |  |
|-------------|---------|---------|---------|---------|---------|---------|---------|--|
| ACC<7:0>    |         |         |         |         |         |         |         |  |
| bit 7       |         |         |         |         |         |         | bit 0   |  |
|             |         |         |         |         |         |         |         |  |
| I a manuali |         |         |         |         |         |         |         |  |

| 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-0 ACC<7:0>: ADC Accumulator LSB. Lower eight bits of accumulator value. See Table 36-2 for more details.

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

# 39.0 HIGH/LOW-VOLTAGE DETECT (HLVD)

The PIC18(L)F26/27/45/46/47/55/56/57K42 family of devices has a High/Low-Voltage Detect module (HLVD). This is a programmable circuit that sets both a device voltage trip point and the direction of change from that point (positive going, negative going or both). If the device experiences an excursion past the trip point in that direction, an interrupt flag is set. If the interrupt is enabled, the program execution branches to the interrupt vector address and the software responds to the interrupt.

Complete control of the HLVD module is provided through the HLVDCON0 and HLVDCON1 register. This allows the circuitry to be "turned off" by the user under software control, which minimizes the current consumption for the device.

The module's block diagram is shown in Figure 39-1.

Since the HLVD can be software enabled through the EN bit, setting and clearing the enable bit does not produce a false HLVD event glitch. Each time the HLVD module is enabled, the circuitry requires some time to stabilize. The RDY bit (HLVDCON0<4>) is a read-only bit used to indicate when the band gap reference voltages are stable.

The module can only generate an interrupt after the module is turned ON and the band gap reference voltages are ready.

The INTH and INTL bits determine the overall operation of the module. When INTH is set, the module monitors for rises in VDD above the trip point set by the HLVDCON1 register. When INTL is set, the module monitors for drops in VDD below the trip point set by the HLVDCON1 register. When both the INTH and INTL bits are set, any changes above or below the trip point set by the HLVDCON1 register can be monitored.

The OUT bit can be read to determine if the voltage is greater than or less than the voltage level selected by the HLVDCON1 register.

# **39.6 Operation During Sleep**

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

#### 39.7 Operation During Idle and Doze Modes

In both Idle and Doze modes, the module is active and events are generated if peripheral is enabled.

# **39.8 Operation During Freeze**

When in Freeze mode, no new event or interrupt can be generated. The state of the LRDY bit is frozen.

Register reads and writes through the CPU interface are allowed.

## **39.9 Effects of a Reset**

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

| Mnemo    | onic,  | Description                    | Cycles | 16-  | Bit Inst | ruction | Word | Status   | Notes |
|----------|--------|--------------------------------|--------|------|----------|---------|------|----------|-------|
| Opera    | nds    | Description                    | Cycles | MSb  |          |         | LSb  | Affected | Notes |
| CONTROL  | INSTRU | CTIONS                         |        |      |          |         |      |          |       |
| BC       | n      | Branch if Carry                | 1 (2)  | 1110 | 0010     | nnnn    | nnnn | None     | 1     |
| BN       | n      | Branch if Negative             | 1 (2)  | 1110 | 0110     | nnnn    | nnnn | None     | 1     |
| BNC      | n      | Branch if Not Carry            | 1 (2)  | 1110 | 0011     | nnnn    | nnnn | None     | 1     |
| BNN      | n      | Branch if Not Negative         | 1 (2)  | 1110 | 0111     | nnnn    | nnnn | None     | 1     |
| BNOV     | n      | Branch if Not Overflow         | 1 (2)  | 1110 | 0101     | nnnn    | nnnn | None     | 1     |
| BNZ      | n      | Branch if Not Zero             | 2      | 1110 | 0001     | nnnn    | nnnn | None     | 1     |
| BOV      | n      | Branch if Overflow             | 1 (2)  | 1110 | 0100     | nnnn    | nnnn | None     | 1     |
| BRA      | n      | Branch Unconditionally         | 1 (2)  | 1101 | 0nnn     | nnnn    | nnnn | None     |       |
| BZ       | n      | Branch if Zero                 | 1 (2)  | 1110 | 0000     | nnnn    | nnnn | None     | 1     |
| CALL     | n, s   | Call subroutine 1st word       | 2      | 1110 | 110s     | nnnn    | nnnn | None     | 2     |
|          |        | 2nd word                       |        | 1111 | nnnn     | nnnn    | nnnn |          |       |
| GOTO     | n      | Go to address 1st word         | 2      | 1110 | 1111     | nnnn    | nnnn | None     | 2     |
|          | —      | 2nd word                       |        | 1111 | nnnn     | nnnn    | nnnn |          |       |
| CALLW    | —      | W -> PCL and Call subroutine   | 2      | 0000 | 0000     | 0001    | 0100 | None     | 1     |
| RCALL    | n      | Relative Call                  | 2      | 1101 | 1nnn     | nnnn    | nnnn | None     | 1     |
| RETFIE   | S      | Return from interrupt enable   | 2      | 0000 | 0000     | 0001    | 000s | None     | 1     |
| RETLW    | k      | Return with literal in WREG    | 2      | 0000 | 1100     | kkkk    | kkkk | None     | 1     |
| RETURN   | S      | Return from Subroutine         | 2      | 0000 | 0000     | 0001    | 001s | None     | 1     |
| INHERENT | INSTRU | CTIONS                         |        |      |          |         |      |          |       |
| CLRWDT   | _      | Clear Watchdog Timer           | 1      | 0000 | 0000     | 0000    | 0100 | None     |       |
| DAW      | _      | Decimal Adjust WREG            | 1      | 0000 | 0000     | 0000    | 0111 | С        |       |
| NOP      | _      | No Operation                   | 1      | 0000 | 0000     | 0000    | 0000 | None     |       |
| NOP      | _      | No Operation                   | 1      | 1111 | XXXX     | XXXX    | XXXX | None     | 2     |
| POP      | _      | Pop top of return stack (TOS)  | 1      | 0000 | 0000     | 0000    | 0110 | None     |       |
| PUSH     | _      | Push top of return stack (TOS) | 1      | 0000 | 0000     | 0000    | 0101 | None     |       |
| RESET    |        | Software device Reset          | 1      | 0000 | 0000     | 1111    | 1111 | All      |       |
| SLEEP    | _      | Go into Standby mode           | 1      | 0000 | 0000     | 0000    | 0011 | None     |       |

#### TABLE 41-2: INSTRUCTION SET (CONTINUED)

Note 1: If Program Counter (PC) is modified or a conditional test is true, the instruction requires an additional cycle. The extra cycle is executed as a NOP.

2: Some instructions are multi word instructions. The second/third words of these instructions will be decoded as a NOP, unless the first word of the instruction retrieves the information embedded in these 16-bits. This ensures that all program memory locations have a valid instruction.

3: f<sub>s</sub> and f<sub>d</sub> do not cover the full memory range. 2 MSBs of bank selection are forced to 'b00 to limit the range of these instructions to lower 4k addressing space.

#### TABLE 44-4: POWER-DOWN CURRENT (IPD)<sup>(1,2)</sup>

| PIC18LF26/45/46/55/56K42 |           |                                           |                      |       | Standard Operating Conditions (unless otherwise stated)               |                |       |               |                        |  |
|--------------------------|-----------|-------------------------------------------|----------------------|-------|-----------------------------------------------------------------------|----------------|-------|---------------|------------------------|--|
| PIC18F26/45/46/55/56K42  |           |                                           |                      |       | Standard Operating Conditions (unless otherwise stated)<br>VREGPM = 1 |                |       |               |                        |  |
| Param.<br>No.            | Symbol    | Device Characteristics                    | Min.                 | Тур.† | Max.<br>+85°C                                                         | Max.<br>+125°C | Units | Conditions    |                        |  |
|                          |           |                                           |                      |       |                                                                       |                |       | VDD           | Note                   |  |
| D200                     | IPD       | IPD Base                                  |                      | 0.07  | 2                                                                     | 6              | μΑ    | 3.0V          |                        |  |
| D200                     | IPD       | IPD Base                                  | _                    | 0.4   | 4                                                                     | 8              | μA    | 3.0V          |                        |  |
| D200A                    |           |                                           |                      | 20    | 38                                                                    | 42             | μΑ    | 3.0V          | VREGPM = 0             |  |
| D201                     | IPD_WDT   | Low-Frequency Internal Oscillator/<br>WDT | -                    | 0.9   | 3.2                                                                   | 7              | μA    | 3.0V          | $\bigcirc$             |  |
| D201                     | IPD_WDT   | Low-Frequency Internal Oscillator/<br>WDT | -                    | 1.1   | 3.2                                                                   | 9              | μΑ    | 3.0V          |                        |  |
| D202                     | IPD_SOSC  | Secondary Oscillator (Sosc)               |                      | 0.75  | 5                                                                     | 9              | μΑ    | 3.0V          | LP mode                |  |
| D202                     | IPD_SOSC  | Secondary Oscillator (SOSC)               | —                    | 1.0   | 6.5                                                                   | 10             | ~#A   | 3.0V          | LP mode                |  |
| D203                     | IPD_FVR   | FVR                                       |                      | 45    | 74                                                                    | 75 <           | ЦĄ    | 3.0∀_         | FVRCON = 0x81 or 0x84  |  |
| D203                     | IPD_FVR   | FVR                                       |                      | 40    | 70                                                                    | 76             | \μÀ   | ∕3.0¥         | FVRCON = 0x81 or 0x84  |  |
| D204                     | IPD_BOR   | Brown-out Reset (BOR)                     |                      | 9.4   | 14                                                                    | _ 18           | àA ∽  | 3.0V          |                        |  |
| D204                     | IPD_BOR   | Brown-out Reset (BOR)                     |                      | 9.4   | 15 <                                                                  | 18             | μÀ    | <b>∖</b> 3.0V |                        |  |
| D205                     | IPD_LPBOR | Low-Power Brown-out Reset (LPBOR)         |                      | 0.2   | 3                                                                     | 6              | μΑ \  | 3.0V          |                        |  |
| D206                     | IPD_HLVD  | High/Low Voltage Detect (HLVD)            | -                    | 9.5   | 14.8                                                                  | -18            | μA    | 3.0V          |                        |  |
| D206                     | IPD_HLVD  | High/Low Voltage Detect (HLVD)            |                      | 9.7   | 14.2                                                                  | 17             | , µA  | 3.0V          |                        |  |
| D207                     | IPD_ADCA  | ADC - Non-Converting                      | —                    | Q.1   | 2                                                                     | 6              | μΑ    | 3.0V          | ADC not converting (4) |  |
| D207                     | IPD_ADCA  | ADC - Non-Converting                      |                      | 0.1   | A                                                                     | 8              | μΑ    | 3.0V          | ADC not converting (4) |  |
| D208                     | IPD_CMP   | Comparator                                | $\overline{\langle}$ | 33    | 49                                                                    | 50             | μΑ    | 3.0V          |                        |  |
| D208                     | IPD_CMP   | Comparator                                | _/                   | 30    | 49                                                                    | 50             | μΑ    | 3.0V          |                        |  |

† Data in "Typ." column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: The peripheral current is the sum of the base loop and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base loop or IPD current from this limit. Max. values should be used when calculating total current consumption.

2: The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode with all I/O pins in high-impedance state and tied to Vss.

- 3: All peripheral currents listed are on a per-peripheral basis if more than one instance of a peripheral is available.
- 4: ADC clock source is FRC.