



#### 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, LVD, POR, PWM, WDT                                 |
| Number of I/O              | 25                                                                         |
| Program Memory Size        | 16KB (8K × 16)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 1K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                |
| Data Converters            | A/D 24x10b; D/A 1x5b                                                       |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Through Hole                                                               |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                    |
| Supplier Device Package    | 28-SPDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f24k40-e-sp |

Email: info@E-XFL.COM

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

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com**. We welcome your feedback.

# Most Current Data Sheet

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Website at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Website; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our website at www.microchip.com to receive the most current information on all of our products.

# 2.3 Master Clear (MCLR) Pin

The MCLR pin provides two specific device functions: Device Reset, and Device Programming and Debugging. If programming and debugging are not required in the end application, a direct connection to VDD may be all that is required. The addition of other components, to help increase the application's resistance to spurious Resets from voltage sags, may be beneficial. A typical configuration is shown in Figure 2-1. Other circuit designs may be implemented, depending on the application's requirements.

During programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the MCLR pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R1 and C1 will need to be adjusted based on the application and PCB requirements. For example, it is recommended that the capacitor, C1, be isolated from the MCLR pin during programming and debugging operations by using a jumper (Figure 2-2). The jumper is replaced for normal run-time operations.

Any components associated with the  $\overline{\text{MCLR}}$  pin should be placed within 0.25 inch (6 mm) of the pin.

#### FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS



# 2.4 ICSP<sup>™</sup> Pins

The PGC and PGD pins are used for In-Circuit Serial Programming<sup>TM</sup> (ICSP<sup>TM</sup>) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of ohms, not to exceed 100 $\Omega$ .

Pull-up resistors, series diodes and capacitors on the PGC and PGD pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits, and pin input voltage high (VIH) and input low (VIL) requirements.

For device emulation, ensure that the "Communication Channel Select" (i.e., PGCx/PGDx pins), programmed into the device, matches the physical connections for the ICSP to the Microchip debugger/emulator tool.

For more information on available Microchip development tools connection requirements, refer to **Section 36.0 "Development Support"**.

| U-1                                                                                                                                                                                                           | U-1         | R/W-1          | R/W-1 F                         | R/W-1 R/W-1                       | R/W-1                | R/W-1               |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|---------------------------------|-----------------------------------|----------------------|---------------------|--|--|--|--|--|
| —                                                                                                                                                                                                             | WDTCCS<2:0> |                |                                 |                                   | WDTCWS<2:0           | )>                  |  |  |  |  |  |
| bit 7                                                                                                                                                                                                         |             |                |                                 |                                   |                      | bit 0               |  |  |  |  |  |
|                                                                                                                                                                                                               |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
| Legend:                                                                                                                                                                                                       |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '1'                                                                                                                                          |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
| -n = Value for b                                                                                                                                                                                              | lank device | '1' = Bit is s | et '0' =                        | Bit is cleared                    | x = Bit is ur        | nknown              |  |  |  |  |  |
|                                                                                                                                                                                                               |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
| bit 7-6 Unimplemented: Read as '1'                                                                                                                                                                            |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
| bit 5-3 WDTCCS<2:0>: WDT Input Clock Selector bits<br><u>If WDTE&lt;1:0&gt; fuses = 2 'b00</u><br>This bit is ignored.<br><u>Otherwise:</u><br>111 = Software Control<br>110 = Reserved (Default to LFINTOSC) |             |                |                                 |                                   |                      |                     |  |  |  |  |  |
|                                                                                                                                                                                                               | 001 = WI    | DT reference   | clock is the 31.0 kH            | Iz LFINTOSC (defaul               | lt value)            |                     |  |  |  |  |  |
| bit 2-0                                                                                                                                                                                                       | WDTCWS<2:0  | >: WDT Win     | dow Select bits                 |                                   |                      |                     |  |  |  |  |  |
|                                                                                                                                                                                                               |             |                | WINDOW at P                     | OR                                | Software             | Keyed               |  |  |  |  |  |
|                                                                                                                                                                                                               | WDTCWS      | Value          | Window delay<br>Percent of time | Window opening<br>Percent of time | control of<br>WINDOW | access<br>required? |  |  |  |  |  |
|                                                                                                                                                                                                               | 111         | 111            | n/a                             | 100                               | Yes                  | No                  |  |  |  |  |  |
|                                                                                                                                                                                                               | 110         | 111            | n/a                             | 100                               |                      |                     |  |  |  |  |  |

25

37.5

50

62.5

75

87.5

75

62.5

50

37.5

25

12.5

No

#### REGISTER 3-6: CONFIGURATION WORD 3H (30 0005h): WINDOWED WATCHDOG TIMER

101

100

011

010

001

000

101

100

011

010

001

000

Yes

| R/W/HC-0       | /0 R/W-0/0       | U-0               | R-0/0            | R-0/0            | U-0              | U-0              | U-0           |
|----------------|------------------|-------------------|------------------|------------------|------------------|------------------|---------------|
| CSWHOL         | D SOSCPWR        | —                 | ORDY             | NOSCR            | —                | —                | —             |
| bit 7          |                  |                   |                  | •                |                  |                  | bit 0         |
|                |                  |                   |                  |                  |                  |                  |               |
| Legend:        |                  |                   |                  |                  |                  |                  |               |
| R = Readal     | ble bit          | W = Writable      | bit              | U = Unimpler     | nented bit, read | l as '0'         |               |
| u = Bit is ur  | nchanged         | x = Bit is unki   | nown             | -n/n = Value a   | at POR and BO    | R/Value at all o | other Resets  |
| '1' = Bit is s | set              | '0' = Bit is cle  | ared             | HC = Bit is cl   | eared by hardw   | vare             |               |
|                |                  |                   |                  |                  |                  |                  |               |
| bit 7          | CSWHOLD:         | Clock Switch H    | lold bit         |                  |                  |                  |               |
|                | 1 = Clock s      | witch will hold ( | with interrupt)  | when the oscill  | ator selected b  | y NOSC is rea    | dy            |
|                | 0 = Clock s      | witch may proc    | eed when the c   | scillator select | ed by NOSC is    | ready; NOSCF     | R             |
|                | become           | es '1', the switc | h will occur     |                  |                  |                  |               |
| bit 6          | SOSCPWR:         | Secondary Os      | cillator Power N | /lode Select bit |                  |                  |               |
|                | 1 = Second       | ary oscillator o  | perating in Higi | h-Power mode     |                  |                  |               |
| L:1 F          |                  |                   |                  |                  |                  |                  |               |
| DIT 5          | Unimplemen       | ited: Read as     | 0.               |                  |                  |                  |               |
| bit 4          | ORDY: Oscil      | lator Ready bit   | (read-only)      |                  |                  |                  | _             |
|                | 1 = OSCCO        | DN1 = OSCCO       | N2; the current  | system clock i   | s the clock spe  | cified by NOS    | C             |
|                |                  | switch is in pro  | gress            | (1)              |                  |                  |               |
| bit 3          | NOSCR: Nev       | w Oscillator is F | Ready bit (read  | -only)(')        |                  |                  |               |
|                | 1 = A clock      | switch is in pro  | gress and the    | oscillator selec | ted by NOSC in   | ndicates a "rea  | dy" condition |
| h:+ 0 0        |                  |                   | ,<br>,           |                  |                  | s not yet ready  |               |
| DIT 2-0        | Unimplemen       | ited: Read as     | U                |                  |                  |                  |               |
| Note 1:        | If $CSWHOLD = 0$ | the user may      | not see this bit | set because, v   | when the oscilla | tor becomes re   | eady there    |

**Note 1:** If CSWHOLD = 0, the user may not see this bit set because, when the oscillator becomes ready there may be a delay of one instruction clock before this bit is set. The clock switch occurs in the next instruction cycle and this bit is cleared.

# 8.0 RESETS

There are multiple ways to reset this device:

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

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

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





#### 11.1.3 READING THE PROGRAM FLASH MEMORY

The TBLRD instruction retrieves data from program memory and places it into data RAM. Table reads from program memory are performed one byte at a time.

TBLPTR points to a byte address in program space. Executing TBLRD places the byte pointed to into TABLAT. In addition, TBLPTR can be modified automatically for the next table read operation. The CPU operation is suspended during the read, and it resumes immediately after. From the user point of view, TABLAT is valid in the next instruction cycle.

The internal program memory is typically organized by words. The Least Significant bit of the address selects between the high and low bytes of the word. Figure 11-4 shows the interface between the internal program memory and the TABLAT.

# FIGURE 11-4: READS FROM PROGRAM FLASH MEMORY



#### EXAMPLE 11-1: READING A PROGRAM FLASH MEMORY WORD

|           | NOTITI  |                 |   | The dimptomp of the black being |
|-----------|---------|-----------------|---|---------------------------------|
|           | MOVLW   | CODE_ADDR_UPPER | ; | Load TELPTR with the base       |
|           | MOVWF   | TBLPTRU         | ; | address of the word             |
|           | MOVLW   | CODE_ADDR_HIGH  |   |                                 |
|           | MOVWF   | TBLPTRH         |   |                                 |
|           | MOVLW   | CODE_ADDR_LOW   |   |                                 |
|           | MOVWF   | TBLPTRL         |   |                                 |
| READ_WORD |         |                 |   |                                 |
|           | TBLRD*+ |                 | ; | read into TABLAT and increment  |
|           | MOVF    | TABLAT, W       | ; | get data                        |
|           | MOVWF   | WORD_EVEN       |   |                                 |
|           | TBLRD*+ |                 | ; | read into TABLAT and increment  |
|           | MOVFW   | TABLAT, W       | ; | get data                        |
|           | MOVF    | WORD_ODD        |   |                                 |
|           |         |                 |   |                                 |

# 12.0 8x8 HARDWARE MULTIPLIER

# 12.1 Introduction

All PIC18 devices include an 8x8 hardware multiplier as part of the ALU. The multiplier performs an unsigned operation and yields a 16-bit result that is stored in the product register pair, PRODH:PRODL. The multiplier's operation does not affect any flags in the STATUS register.

Making multiplication a hardware operation allows it to be completed in a single instruction cycle. This has the advantages of higher computational throughput and reduced code size for multiplication algorithms and allows the PIC18 devices to be used in many applications previously reserved for digital signal processors. A comparison of various hardware and software multiply operations, along with the savings in memory and execution time, is shown in Table 12-1.

# 12.2 Operation

Example 12-1 shows the instruction sequence for an 8x8 unsigned multiplication. Only one instruction is required when one of the arguments is already loaded in the WREG register.

Example 12-2 shows the sequence to do an 8x8 signed multiplication. To account for the sign bits of the arguments, each argument's Most Significant bit (MSb) is tested and the appropriate subtractions are done.

#### EXAMPLE 12-1: 8x8 UNSIGNED MULTIPLY ROUTINE

| MOVF  | ARG1, | W | ; |       |     |       |    |
|-------|-------|---|---|-------|-----|-------|----|
| MULWF | ARG2  |   | ; | ARG1  | *   | ARG2  | -> |
|       |       |   | ; | PRODI | 1:1 | PRODL |    |

# EXAMPLE 12-2: 8x8 SIGNED MULTIPLY

| MOVF  | ARG1, W  |   |                |
|-------|----------|---|----------------|
| MULWF | ARG2     | ; | ARG1 * ARG2 -> |
|       |          | ; | PRODH:PRODL    |
| BTFSC | ARG2, SB | ; | Test Sign Bit  |
| SUBWF | PRODH, F | ; | PRODH = PRODH  |
|       |          | ; | - ARG1         |
| MOVF  | ARG2, W  |   |                |
| BTFSC | ARG1, SB | ; | Test Sign Bit  |
| SUBWF | PRODH, F | ; | PRODH = PRODH  |
|       |          | ; | - ARG2         |
|       |          |   |                |

|                |                           | Program           | Cvcles | Time     |          |          |         |  |
|----------------|---------------------------|-------------------|--------|----------|----------|----------|---------|--|
| Routine        | Multiply Method           | Memory<br>(Words) | (Max)  | @ 64 MHz | @ 40 MHz | @ 10 MHz | @ 4 MHz |  |
| 9v9 uppigpod   | Without hardware multiply | 13                | 69     | 4.3 μs   | 6.9 μs   | 27.6 μs  | 69 μs   |  |
| oxo unsigneu   | Hardware multiply         | 1                 | 1      | 62.5 ns  | 100 ns   | 400 ns   | 1 μs    |  |
| Que simo d     | Without hardware multiply | 33                | 91     | 5.7 μs   | 9.1 μs   | 36.4 μs  | 91 μs   |  |
| oxo signeu     | Hardware multiply         | 6                 | 6      | 375 ns   | 600 ns   | 2.4 μs   | 6 μs    |  |
| 16x16 unsigned | Without hardware multiply | 21                | 242    | 15.1 μs  | 24.2 μs  | 96.8 μs  | 242 μs  |  |
| 16x16 unsigned | Hardware multiply         | 28                | 28     | 1.8 μs   | 2.8 μs   | 11.2 μs  | 28 μs   |  |
| 16x16 signed   | Without hardware multiply | 52                | 254    | 15.9 μs  | 25.4 μs  | 102.6 μs | 254 μs  |  |
| 16x16 signed   | Hardware multiply         | 35                | 40     | 2.5 μs   | 4.0 μs   | 16.0 μs  | 40 μs   |  |

# TABLE 12-1: PERFORMANCE COMPARISON FOR VARIOUS MULTIPLY OPERATIONS

| Name      | Bit 7               | Bit 6       | Bit 5  | Bit 4   | Bit 3  | Bit 2    | Bit 1   | Bit 0   | Register<br>on Page |  |  |  |
|-----------|---------------------|-------------|--------|---------|--------|----------|---------|---------|---------------------|--|--|--|
| CRCACCH   | ACC<15:8>           |             |        |         |        |          |         |         |                     |  |  |  |
| CRCACCL   |                     | ACC<7:0>    |        |         |        |          |         |         |                     |  |  |  |
| CRCCON0   | EN                  | GO          | BUSY   | ACCM    | —      | —        | SHIFTM  | FULL    | 147                 |  |  |  |
| CRCCON1   | DLEN<3:0> PLEN<3:0> |             |        |         |        |          |         |         |                     |  |  |  |
| CRCDATH   |                     | DATA<15:8>  |        |         |        |          |         |         |                     |  |  |  |
| CRCDATL   |                     | DATA<7:0>   |        |         |        |          |         |         |                     |  |  |  |
| CRCSHIFTH |                     | SHIFT<15:8> |        |         |        |          |         |         |                     |  |  |  |
| CRCSHIFTL |                     | SHIFT<7:0>  |        |         |        |          |         |         |                     |  |  |  |
| CRCXORH   |                     | X<15:8>     |        |         |        |          |         |         |                     |  |  |  |
| CRCXORL   |                     |             |        | X<7:1>  |        |          |         | —       | 150                 |  |  |  |
| PMD0      | SYSCMD              | FVRMD       | HLVDMD | CRCMD   | SCANMD | NVMMD    | CLKRMD  | IOCMD   | 64                  |  |  |  |
| SCANCON0  | SCANEN              | SCANGO      | BUSY   | INVALID | INTM   | —        | MODE    | <1:0>   | 151                 |  |  |  |
| SCANHADRU | —                   | —           |        |         | HADF   | R<21:16> |         |         | 153                 |  |  |  |
| SCANHADRH |                     |             |        | HADR    | <15:8> |          |         |         | 154                 |  |  |  |
| SCANHADRL |                     |             |        | HADF    | R<7:0> |          |         |         | 154                 |  |  |  |
| SCANLADRU | —                   | —           |        |         | LADF   | 21:16>   |         |         | 152                 |  |  |  |
| SCANLADRH |                     |             |        | LADR    | <15:8> |          |         |         | 152                 |  |  |  |
| SCANLADRL |                     |             |        | LADF    | R<7:0> |          |         |         | 153                 |  |  |  |
| SCANTRIG  | —                   | —           | _      | —       |        | TSEI     | _<3:0>  |         | 155                 |  |  |  |
| INTCON    | GIE/GIEH            | PEIE/GIEL   | IPEN   | —       | —      | INT2EDG  | INT1EDG | INT0EDG | 166                 |  |  |  |
| PIR7      | SCANIF              | CRCIF       | NVMIF  | —       | —      | —        | —       | CWG1IF  | 174                 |  |  |  |
| PIE7      | SCANIE              | CRCIE       | NVMIE  | _       | _      | _        | _       | CWG1IE  | 182                 |  |  |  |
| IPR7      | SCANIP              | CRCIP       | NVMIP  | _       | _      | _        | _       | CWG1IP  | 190                 |  |  |  |

| TABLE 13-5: | SUMMARY OF REGISTERS ASSOCIATED WITH CRC |
|-------------|------------------------------------------|
|-------------|------------------------------------------|

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used for the CRC module.

# 17.3 Bidirectional Pins

PPS selections for peripherals with bidirectional signals on a single pin must be made so that the PPS input and PPS output select the same pin. Peripherals that have bidirectional signals include:

- EUSART (synchronous operation)
- MSSP (I<sup>2</sup>C)
- CCP module
- Note: The I<sup>2</sup>C default input pins are I<sup>2</sup>C and SMBus compatible. RB1 and RB2 are additional pins. RC4 and RC3 are default MMP1 pins and are SMBus compatible. Clock and data signals can be routed to any pin, however pins without I<sup>2</sup>C compatibility will operate at standard TTL/ST logic levels as selected by the INVLV register.

# 17.4 PPS Lock

The PPS includes a mode in which all input and output selections can be locked to prevent inadvertent changes. PPS selections are locked by setting the PPSLOCKED bit of the PPSLOCK register. Setting and clearing this bit requires a special sequence as an extra precaution against inadvertent changes. Examples of setting and clearing the PPSLOCKED bit are shown in Example 17-1.

# EXAMPLE 17-1: PPS LOCK SEQUENCE

| ; | Disable inte | errupts:                    |
|---|--------------|-----------------------------|
|   | BCF II       | NTCON,GIE                   |
|   |              |                             |
| ; | Bank to PPSI | LOCK register               |
|   | BANKSEL P    | PSLOCK                      |
|   | MOVLB P      | PSLOCK                      |
|   | MOVLW 5      | 5h                          |
|   |              |                             |
| ; | Required sec | quence, next 4 instructions |
|   | MOVWF P      | PSLOCK                      |
|   | MOVLW A      | Ah                          |
|   | MOVWF P      | PSLOCK                      |
|   |              |                             |
| ; | Set PPSLOCKI | ED bit to disable writes    |
| ; | Only a BSF : | instruction will work       |
|   | BSF P        | PSLOCK,0                    |
|   |              |                             |
| ; | Enable Inter | rupts                       |
|   | BSF I        | NTCON, GIE                  |
|   |              |                             |

#### EXAMPLE 17-2: PPS UNLOCK SEQUENCE

```
; Disable interrupts:
   BCF
           INTCON, GIE
; Bank to PPSLOCK register
   BANKSEL PPSLOCK
   MOVLB
           PPSLOCK
   MOVIW
            55h
; Required sequence, next 4 instructions
   MOVWF
           PPSLOCK
   MOVLW
           AAh
   MOVWF
           PPSLOCK
; Clear PPSLOCKED bit to enable writes
; Only a BCF instruction will work
   BCF
           PPSLOCK,0
; Enable Interrupts
   BSF
            INTCON.GIE
```

# 17.5 PPS One-Way Lock

Using the PPS1WAY Configuration bit, the PPS settings can be locked in. When this bit is set, the PPSLOCKED bit can only be cleared and set one time after a device Reset. This allows for clearing the PPSLOCKED bit so that the input and output selections can be made during initialization. When the PPSLOCKED bit is set after all selections have been made, it will remain set and cannot be cleared until after the next device Reset event.

# 17.6 Operation During Sleep

PPS input and output selections are unaffected by Sleep.

# 17.7 Effects of a Reset

A device Power-on-Reset (POR) clears all PPS input and output selections to their default values. All other Resets leave the selections unchanged. Default input selections are shown in the **Section "Pin Allocation Tables"**. The PPS one-way is also removed.

# **REGISTER 19-4: TMRxGATE: TIMERx GATE ISM REGISTER**

| U-0   | U-0 | U-0 | U-0 | R/W-0/u | R/W-0/u | R/W-0/u | R/W-0/u |
|-------|-----|-----|-----|---------|---------|---------|---------|
| _     | —   | —   | _   |         | GSS     | <3:0>   |         |
| bit 7 |     |     |     |         |         |         | bit 0   |
|       |     |     |     |         |         |         |         |

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

#### bit 7-4 Unimplemented: Read as '0'

bit 3-0 **GSS<3:0>:** Timerx Gate Source Selection bits

| 688  | Timer1                 | Timer3                 | Timer5                 |
|------|------------------------|------------------------|------------------------|
| 033  | Gate Source            | Gate Source            | Gate Source            |
| 1111 | Reserved               | Reserved               | Reserved               |
| 1110 | ZCDOUT                 | ZCDOUT                 | ZCDOUT                 |
| 1101 | CMP2OUT                | CMP2OUT                | CMP2OUT                |
| 1100 | CMP1OUT                | CMP1OUT                | CMP1OUT                |
| 1011 | PWM4OUT                | PWM4OUT                | PWM4OUT                |
| 1010 | PWM3OUT                | PWM3OUT                | PWM3OUT                |
| 1001 | CCP2OUT                | CCP2OUT                | CCP2OUT                |
| 1000 | CCP1OUT                | CCP10UT                | CCP1OUT                |
| 0111 | TMR6OUT (post-scaled)  | TMR6OUT (post-scaled)  | TMR6OUT (post-scaled)  |
| 0110 | TMR5 overflow          | TMR5 overflow          | Reserved               |
| 0101 | TMR4OUT (post-scaled)  | TMR4OUT (post-scaled)  | TMR4OUT (post-scaled)  |
| 0100 | TMR3 overflow          | Reserved               | TMR3 overflow          |
| 0011 | TMR2OUT (post-scaled)  | TMR2OUT (post-scaled)  | TMR2OUT (post-scaled)  |
| 0010 | Reserved               | TMR1 overflow          | TMR1 overflow          |
| 0001 | TMR0 overflow          | TMR0 overflow          | TMR0 overflow          |
| 0000 | Pin selected by T1GPPS | Pin selected by T3GPPS | Pin selected by T5GPPS |

# 20.5 Operation Examples

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

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

The signals are not a part of the Timer2 module.

#### 20.5.1 SOFTWARE GATE MODE

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



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



© -2017 Microchip Technology Inc.

# 20.7 Register Definitions: Timer2/4/6 Control

Long bit name prefixes for the Timer2/4/6 peripherals are shown in Table 20-2. Refer to **Section 1.4.2.2 "Long Bit Names"** for more information. **TABLE 20-2:** 

| Peripheral | Bit Name Prefix |
|------------|-----------------|
| Timer2     | T2              |
| Timer4     | T4              |
| Timer6     | T6              |

#### REGISTER 20-3: TxCLKCON: TIMERx CLOCK SELECTION REGISTER

| U-0   | U-0 | U-0 | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------|-----|-----|-----|---------|---------|---------|---------|
| —     | —   | —   | —   |         |         |         |         |
| bit 7 |     |     |     |         |         |         | bit 0   |
|       |     |     |     |         |         |         |         |
|       |     |     |     |         |         |         |         |

| Legend:          |                   |                |                                                  |
|------------------|-------------------|----------------|--------------------------------------------------|
| R = Readable     | e bit W = Writ    | able bit U = l | Jnimplemented bit, read as '0'                   |
| u = Bit is unch  | nanged x = Bit is | unknown -n/n   | = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set | '0' = Bit i       | s cleared      |                                                  |

#### bit 7-4 Unimplemented: Read as '0'

bit 3-0 CS<3:0>: Timerx Clock Selection bits

| 00-2:0>   | TMR2                    | TMR4                    | TMR6                    |  |  |
|-----------|-------------------------|-------------------------|-------------------------|--|--|
| 03<3:02   | Clock Source            | Clock Source            | Clock Source            |  |  |
| 1111-1001 | Reserved                | Reserved                | Reserved                |  |  |
| 1000      | ZCD_OUT                 | ZCD_OUT                 | ZCD_OUT                 |  |  |
| 0111      | CLKREF_OUT              | CLKREF_OUT              | CLKREF_OUT              |  |  |
| 0110      | SOSC                    | SOSC                    | SOSC                    |  |  |
| 0101      | MFINTOSC (31 kHz)       | MFINTOSC (31 kHz)       | MFINTOSC (31 kHz)       |  |  |
| 0100      | LFINTOSC                | LFINTOSC                | LFINTOSC                |  |  |
| 0011      | HFINTOSC                | HFINTOSC                | HFINTOSC                |  |  |
| 0010      | Fosc                    | Fosc                    | Fosc                    |  |  |
| 0001      | Fosc/4                  | Fosc/4                  | Fosc/4                  |  |  |
| 0000      | Pin selected by T2INPPS | Pin selected by T4INPPS | Pin selected by T6INPPS |  |  |

| R/W-0/0           | R/W-1/1                                                                      | R/W-0/0                                                                                            | R/W-1/1                                                              | R/W-0/0                                              | R/W-1/1                                               | R/W-0/0                                | R/W-1/1 |
|-------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|----------------------------------------|---------|
| P4TSE             | L<1:0>                                                                       | P3TSE                                                                                              | _<1:0>                                                               | C2TSE                                                | EL<1:0>                                               | C1TSEI                                 | _<1:0>  |
| bit 7             |                                                                              |                                                                                                    |                                                                      | ·                                                    |                                                       |                                        | bit 0   |
|                   |                                                                              |                                                                                                    |                                                                      |                                                      |                                                       |                                        |         |
| Legend:           |                                                                              |                                                                                                    |                                                                      |                                                      |                                                       |                                        |         |
| R = Readable I    | bit                                                                          | W = Writable                                                                                       | oit                                                                  | U = Unimplem                                         | nented bit, read                                      | as '0'                                 |         |
| -n = Value at POR |                                                                              | '1' = Bit is set                                                                                   |                                                                      | '0' = Bit is clea                                    | ared                                                  | x = Bit is unkno                       | own     |
| bit 7-6           | P4TSEL<1:0><br>11 = PWM4 1<br>10 = PWM4 1<br>01 = PWM4 1<br>00 = Reserve     | <ul> <li>PWM4 Times<br/>based on TMR<br/>based on TMR<br/>based on TMR<br/>based on TMR</li> </ul> | <sup>-</sup> Selection bit<br>6<br>4<br>2                            | 'S                                                   |                                                       |                                        |         |
| bit 5-4           | P3TSEL<1:0><br>11 = PWM3 =<br>10 = PWM3 =<br>01 = PWM3 =<br>00 = Reserve     | <ul> <li>PWM3 Times<br/>based on TMR<br/>based on TMR<br/>based on TMR<br/>ed</li> </ul>           | <sup>-</sup> Selection bit<br>6<br>4<br>2                            | is                                                   |                                                       |                                        |         |
| bit 3-2           | C2TSEL<1:02<br>11 = CCP2 is<br>10 = CCP2 is<br>01 = CCP2 is<br>00 = Reserve  | CCP2 Timer<br>based off Time<br>based off Time<br>based off Time<br>d                              | Selection bits<br>er5 in Capture<br>er3 in Capture<br>er1 in Capture | s<br>e/Compare mod<br>e/Compare mod<br>e/Compare mod | e and Timer6 ir<br>e and Timer4 ir<br>e and Timer2 ir | n PWM mode<br>n PWM mode<br>n PWM mode |         |
| bit 1-0           | C1TSEL<1:0><br>11 = CCP1 is<br>10 = CCP1 is<br>01 = CCP1 is<br>00 = Reserver | CCP1 Timer<br>based off Time<br>based off Time<br>based off Time<br>d                              | Selection bits<br>er5 in Capture<br>er3 in Capture<br>er1 in Capture | s<br>e/Compare mod<br>e/Compare mod<br>e/Compare mod | e and Timer6 ir<br>e and Timer4 ir<br>e and Timer2 ir | n PWM mode<br>n PWM mode<br>n PWM mode |         |

# REGISTER 21-2: CCPTMRS: CCP TIMERS CONTROL REGISTER

|        | SYNC = 0, BRGH = 1, BRG16 = 0 |            |                             |                  |            |                             |                   |            |                             |                  |            |                             |  |
|--------|-------------------------------|------------|-----------------------------|------------------|------------|-----------------------------|-------------------|------------|-----------------------------|------------------|------------|-----------------------------|--|
| BAUD   | Fosc = 8.000 MHz              |            |                             | Fosc = 4.000 MHz |            |                             | Fosc = 3.6864 MHz |            |                             | Fosc = 1.000 MHz |            |                             |  |
| RATE   | Actual<br>Rate                | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate   | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate   | %<br>Error | SPBRG<br>value<br>(decimal) |  |
| 300    | —                             | —          |                             |                  |            |                             |                   |            | _                           | 300              | 0.16       | 207                         |  |
| 1200   |                               | _          |                             | 1202             | 0.16       | 207                         | 1200              | 0.00       | 191                         | 1202             | 0.16       | 51                          |  |
| 2400   | 2404                          | 0.16       | 207                         | 2404             | 0.16       | 103                         | 2400              | 0.00       | 95                          | 2404             | 0.16       | 25                          |  |
| 9600   | 9615                          | 0.16       | 51                          | 9615             | 0.16       | 25                          | 9600              | 0.00       | 23                          | —                | _          | _                           |  |
| 10417  | 10417                         | 0.00       | 47                          | 10417            | 0.00       | 23                          | 10473             | 0.53       | 21                          | 10417            | 0.00       | 5                           |  |
| 19.2k  | 19231                         | 0.16       | 25                          | 19.23k           | 0.16       | 12                          | 19.2k             | 0.00       | 11                          | —                | _          | _                           |  |
| 57.6k  | 55556                         | -3.55      | 8                           | —                | _          | —                           | 57.60k            | 0.00       | 3                           | —                | _          | —                           |  |
| 115.2k | —                             | —          | —                           | —                | _          | —                           | 115.2k            | 0.00       | 1                           | _                | _          | —                           |  |

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

|        | SYNC = 0, BRGH = 0, BRG16 = 1 |            |                             |                   |            |                             |                   |            |                             |                    |            |                             |  |
|--------|-------------------------------|------------|-----------------------------|-------------------|------------|-----------------------------|-------------------|------------|-----------------------------|--------------------|------------|-----------------------------|--|
| BAUD   | Fosc = 32.000 MHz             |            |                             | Fosc = 20.000 MHz |            |                             | Fosc = 18.432 MHz |            |                             | Fosc = 11.0592 MHz |            |                             |  |
| RATE   | Actual<br>Rate                | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate     | %<br>Error | SPBRG<br>value<br>(decimal) |  |
| 300    | 300.0                         | 0.00       | 6666                        | 300.0             | -0.01      | 4166                        | 300.0             | 0.00       | 3839                        | 300.0              | 0.00       | 2303                        |  |
| 1200   | 1200                          | -0.02      | 3332                        | 1200              | -0.03      | 1041                        | 1200              | 0.00       | 959                         | 1200               | 0.00       | 575                         |  |
| 2400   | 2401                          | -0.04      | 832                         | 2399              | -0.03      | 520                         | 2400              | 0.00       | 479                         | 2400               | 0.00       | 287                         |  |
| 9600   | 9615                          | 0.16       | 207                         | 9615              | 0.16       | 129                         | 9600              | 0.00       | 119                         | 9600               | 0.00       | 71                          |  |
| 10417  | 10417                         | 0.00       | 191                         | 10417             | 0.00       | 119                         | 10378             | -0.37      | 110                         | 10473              | 0.53       | 65                          |  |
| 19.2k  | 19.23k                        | 0.16       | 103                         | 19.23k            | 0.16       | 64                          | 19.20k            | 0.00       | 59                          | 19.20k             | 0.00       | 35                          |  |
| 57.6k  | 57.14k                        | -0.79      | 34                          | 56.818            | -1.36      | 21                          | 57.60k            | 0.00       | 19                          | 57.60k             | 0.00       | 11                          |  |
| 115.2k | 117.6k                        | 2.12       | 16                          | 113.636           | -1.36      | 10                          | 115.2k            | 0.00       | 9                           | 115.2k             | 0.00       | 5                           |  |

|        | SYNC = 0, BRGH = 0, BRG16 = 1 |            |                             |                  |            |                             |                   |            |                             |                |                  |                             |  |
|--------|-------------------------------|------------|-----------------------------|------------------|------------|-----------------------------|-------------------|------------|-----------------------------|----------------|------------------|-----------------------------|--|
| BAUD   | Fosc = 8.000 MHz              |            |                             | Fosc = 4.000 MHz |            |                             | Fosc = 3.6864 MHz |            |                             | Fos            | Fosc = 1.000 MHz |                             |  |
| RATE   | Actual<br>Rate                | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate   | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error       | SPBRG<br>value<br>(decimal) |  |
| 300    | 299.9                         | -0.02      | 1666                        | 300.1            | 0.04       | 832                         | 300.0             | 0.00       | 767                         | 300.5          | 0.16             | 207                         |  |
| 1200   | 1199                          | -0.08      | 416                         | 1202             | 0.16       | 207                         | 1200              | 0.00       | 191                         | 1202           | 0.16             | 51                          |  |
| 2400   | 2404                          | 0.16       | 207                         | 2404             | 0.16       | 103                         | 2400              | 0.00       | 95                          | 2404           | 0.16             | 25                          |  |
| 9600   | 9615                          | 0.16       | 51                          | 9615             | 0.16       | 25                          | 9600              | 0.00       | 23                          | —              | _                | _                           |  |
| 10417  | 10417                         | 0.00       | 47                          | 10417            | 0.00       | 23                          | 10473             | 0.53       | 21                          | 10417          | 0.00             | 5                           |  |
| 19.2k  | 19.23k                        | 0.16       | 25                          | 19.23k           | 0.16       | 12                          | 19.20k            | 0.00       | 11                          | —              | _                | _                           |  |
| 57.6k  | 55556                         | -3.55      | 8                           | —                | _          | _                           | 57.60k            | 0.00       | 3                           | —              | _                | _                           |  |
| 115.2k |                               | _          | _                           | —                | _          | _                           | 115.2k            | 0.00       | 1                           | —              | _                | _                           |  |







# 32.4 Comparator Hysteresis

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

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

# 32.5 Timer1/3/5 Gate Operation

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

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

#### 32.5.1 COMPARATOR OUTPUT SYNCHRONIZATION

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

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

# 32.6 Comparator Interrupt

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

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

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

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

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

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

# 32.7 Comparator Positive Input Selection

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

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

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

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

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

# 32.8 Comparator Negative Input Selection

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

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

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

# PIC18(L)F24/25K40

| LFS                   | R                                     | Load FSF                                                            | R                                 |                                         | r          | MOVF                        | Move f                                                                                                                                            | Move f               |                                   |  |  |  |
|-----------------------|---------------------------------------|---------------------------------------------------------------------|-----------------------------------|-----------------------------------------|------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------------------|--|--|--|
| Synta                 | ax:                                   | LFSR f, k                                                           |                                   |                                         | 5          | Syntax:                     | MOVF f{,                                                                                                                                          | d {,a}}              |                                   |  |  |  |
| Oper                  | ands:                                 | $\begin{array}{l} 0 \leq f \leq 2 \\ 0 \leq k \leq 409 \end{array}$ | 5                                 |                                         | (          | Operands:                   | $\begin{array}{l} 0 \leq f \leq 255 \\ d  \in  [0,1] \end{array}$                                                                                 |                      |                                   |  |  |  |
| Oper                  | ation:                                | $k \to FSRf$                                                        |                                   |                                         |            |                             | a ∈ [0,1]                                                                                                                                         |                      |                                   |  |  |  |
| Status Affected: None |                                       |                                                                     |                                   | (                                       | Operation: | $f \rightarrow \text{dest}$ |                                                                                                                                                   |                      |                                   |  |  |  |
| Enco                  | Encoding: 1110 1110 00ff $k_{11}$ kkk |                                                                     | F                                 | Status Affected:                        | N, Z       | 00da ff                     | ff ffff                                                                                                                                           |                      |                                   |  |  |  |
| Description:          |                                       | The 12-bit<br>File Select                                           | iteral 'k' is lo<br>Register poir | aded into the nted to by 'f'.           | [          | Description:                | The content<br>a destinatio                                                                                                                       | ts of register 'f    | are moved to upon the             |  |  |  |
| Word                  | ls:                                   | 2                                                                   |                                   |                                         |            |                             | status of 'd'                                                                                                                                     | . If 'd' is '0', th  | e result is                       |  |  |  |
| Cycle                 | es:                                   | 2                                                                   |                                   |                                         |            |                             | placed in w                                                                                                                                       | k in register 'f'    | (default).                        |  |  |  |
| QC                    | ycle Activity:                        |                                                                     |                                   |                                         |            |                             | Location 'f'                                                                                                                                      | can be anywh         | ere in the                        |  |  |  |
|                       | Q1                                    | Q2                                                                  | Q3                                | Q4                                      |            |                             | 256-byte ba                                                                                                                                       | ank.<br>ho Accoss Ba | ak is salastad                    |  |  |  |
|                       | Decode                                | Read literal<br>'k' MSB                                             | Process<br>Data                   | Write<br>literal 'k'<br>MSB to<br>FSRfH |            |                             | If 'a' is '1', the GPR bank.<br>If 'a' is '0' all set is enable                                                                                   | ne BSR is use        | d to select the<br>ed instruction |  |  |  |
| Exan                  | Decode                                | Read literal<br>'k' LSB                                             | Process<br>Data                   | Write literal<br>'k' to FSRfL           |            |                             | in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See S<br>tion 35.2.3 "Byte-Oriented and B<br>Oriented Instructions in Indexed |                      |                                   |  |  |  |
|                       | After Instruction                     | ,<br>on                                                             |                                   |                                         |            |                             | eral Offset                                                                                                                                       | Mode" for de         | tails.                            |  |  |  |
|                       | FSR2H                                 | = 03                                                                | h                                 |                                         | ١          | Vords:                      | 1                                                                                                                                                 |                      |                                   |  |  |  |
|                       | FSR2L                                 | = AE                                                                | Sh                                |                                         | (          | Cycles:                     | 1                                                                                                                                                 |                      |                                   |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | Q Cycle Activity:           |                                                                                                                                                   |                      |                                   |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | Q1                          | Q2                                                                                                                                                | Q3                   | Q4                                |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | Decode                      | Read<br>register 'f'                                                                                                                              | Process<br>Data      | Write W                           |  |  |  |
|                       |                                       |                                                                     |                                   |                                         | E          | Example:                    | MOVF RI                                                                                                                                           | EG, 0, 0             |                                   |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | Before Instruc<br>REG<br>W  | tion<br>= 22<br>= FF                                                                                                                              | h<br>h               |                                   |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | After Instructio<br>REG     | on<br>= 22                                                                                                                                        | h                    |                                   |  |  |  |
|                       |                                       |                                                                     |                                   |                                         |            | W                           | = 22                                                                                                                                              | h                    |                                   |  |  |  |

# PIC18(L)F24/25K40

| RRNCF            |                                                             | Rotate Right f (No Carry)                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                |             |         |         |                       |   |
|------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------|-------------|---------|---------|-----------------------|---|
| Syntax:          |                                                             | RRN                                                                                                                                      | RRNCF f {,d {,a}}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                |             |         |         |                       |   |
| Operands:        |                                                             | 0 ≤ f<br>d ∈<br>a ∈                                                                                                                      | $0 \le f \le 255$<br>d $\in [0,1]$<br>a $\in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |                |             |         |         |                       |   |
| Operation:       |                                                             | (f <n:<br>(f&lt;0:</n:<br>                                                                                                               | $(f < n >) \rightarrow dest < n - 1 >,$<br>$(f < 0 >) \rightarrow dest < 7 >$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                |             |         |         |                       |   |
| Status Affected: |                                                             | N, Z                                                                                                                                     | N, Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |                |             |         |         |                       |   |
| Encoding:        |                                                             | 0                                                                                                                                        | 0100 00da ffff ffff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |                |             |         |         | ffff                  |   |
| Description:     |                                                             | The<br>one<br>is plac<br>plac<br>If 'a'<br>sele<br>valu<br>sele<br>If 'a'<br>set i<br>in In<br>mod<br><b>tion</b><br><b>Orie</b><br>eral | The contents of register 'f' are rotated<br>one bit to the right. If 'd' is '0', the result<br>is placed in W. If 'd' is '1', the result is<br>placed back in register 'f' (default).<br>If 'a' is '0', the Access Bank will be<br>selected (default), overriding the BSR<br>value. If 'a' is '1', then the bank will be<br>selected as per the BSR value.<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever f $\leq$ 95 (5Fh). See Sec-<br>tion 35.2.3 "Byte-Oriented and Bit-<br>Oriented Instructions in Indexed Lit-<br>eral Offset Mode" for details. |          |                |             |         |         |                       |   |
| Word             | ls:                                                         | 1                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                |             |         |         |                       |   |
| Cycles:          |                                                             | 1                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                |             |         |         |                       |   |
| QC               | ycle Activity:                                              |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                |             |         |         |                       |   |
|                  | Q1                                                          |                                                                                                                                          | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | Q3             |             |         | Q4      |                       |   |
|                  | Decode                                                      | Re<br>regis                                                                                                                              | ead<br>ster 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          | Pro<br>C       | oce<br>Data | SS<br>a | V<br>de | Vrite to<br>stination | I |
| <u>Exan</u>      | nple 1:<br>Before Instruc<br>REG<br>After Instructic<br>REG | RRN(<br>tion<br>= 1<br>on<br>= 1                                                                                                         | CF<br>1101<br>1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RE<br>01 | G,<br>11<br>11 | 1,          | 0       |         |                       |   |
| Example 2:       |                                                             | RRN                                                                                                                                      | RRNCF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          | REG, 0, 0      |             |         |         |                       |   |
|                  | Before Instruc                                              | tion                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                |             |         |         |                       |   |
|                  | W<br>REG<br>After Instructio                                | = 1<br>= 1<br>on                                                                                                                         | <b>?</b><br>L101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 01       | 11             |             |         |         |                       |   |
|                  | w<br>REG                                                    | = 1<br>= 1                                                                                                                               | L110<br>L101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10<br>01 | 11<br>11       |             |         |         |                       |   |

| SETF                       | Set f                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                 |             |                      |  |  |  |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------|----------------------|--|--|--|
| Syntax:                    | SETF f{,;                                                                                                                                                                                                                                                                                                                                                                                                                                                              | a}                                                              |             |                      |  |  |  |
| Operands:                  | 0 ≤ f ≤ 255<br>a ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                               | $\begin{array}{l} 0 \leq f \leq 255 \\ a \in [0,1] \end{array}$ |             |                      |  |  |  |
| Operation:                 | $FFh\tof$                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                 |             |                      |  |  |  |
| Status Affected:           | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                 |             |                      |  |  |  |
| Encoding:                  | 0110                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 100a                                                            | ffff        | ffff                 |  |  |  |
| Description:               | The contents of the specified register<br>are set to FFh.<br>If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank.<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See Sec-<br>tion 35.2.3 "Byte-Oriented and Bit-<br>Oriented Instructions in Indexed Lit-<br>eral Offset Mode" for details. |                                                                 |             |                      |  |  |  |
| Words:                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                 |             |                      |  |  |  |
| Cycles:                    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                 |             |                      |  |  |  |
| Q Cycle Activity:          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                 |             |                      |  |  |  |
| Q1                         | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Q3                                                              | 1           | Q4                   |  |  |  |
| Decode                     | Read<br>register 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Proce<br>Data                                                   | ess<br>a re | Write<br>egister 'f' |  |  |  |
| Example:<br>Before Instruc | SETF<br>tion<br>= 54                                                                                                                                                                                                                                                                                                                                                                                                                                                   | REG                                                             | ;, 1        |                      |  |  |  |

| REG               | = | 5Ah |
|-------------------|---|-----|
| After Instruction |   |     |
| REG               | = | FFh |