



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, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, HLVD, POR, PWM, WDT                                |
| Number of I/O              | 24                                                                         |
| Program Memory Size        | 16KB (8K x 16)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 768 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                |
| Data Converters            | A/D 19x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°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/pic18f24k22-i-sp |

Email: info@E-XFL.COM

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

| Pin Nu        | umber        |                                  |             | n Buffer       |                                                                  |
|---------------|--------------|----------------------------------|-------------|----------------|------------------------------------------------------------------|
| PDIP,<br>SOIC | QFN,<br>UQFN | Pin Name                         | Pin<br>Type | Buffer<br>Type | Description                                                      |
| 25            | 22           | RB4/IOC0/P1D/T5G/AN11            |             |                |                                                                  |
|               |              | RB4                              | I/O         | TTL            | Digital I/O.                                                     |
|               |              | IOC0                             | Т           | TTL            | Interrupt-on-change pin.                                         |
|               |              | P1D                              | 0           | CMOS           | Enhanced CCP1 PWM output.                                        |
|               |              | T5G                              | I           | ST             | Timer5 external clock gate input.                                |
|               |              | AN11                             | Ι           | Analog         | Analog input 11.                                                 |
| 26            | 23           | RB5/IOC1/P2B/P3A/CCP3/T3CKI/T1   | G/AN13      | 3              |                                                                  |
|               |              | RB5                              | I/O         | TTL            | Digital I/O.                                                     |
|               |              | IOC1                             | I           | TTL            | Interrupt-on-change pin.                                         |
|               |              | P2B <sup>(1)</sup>               | 0           | CMOS           | Enhanced CCP2 PWM output.                                        |
|               |              | P3A <sup>(1)</sup>               | 0           | CMOS           | Enhanced CCP3 PWM output.                                        |
|               |              | CCP3 <sup>(1)</sup>              | I/O         | ST             | Capture 3 input/Compare 3 output/PWM 3 output.                   |
|               |              | T3CKI <sup>(2)</sup>             | I           | ST             | Timer3 clock input.                                              |
|               |              | T1G                              | I           | ST             | Timer1 external clock gate input.                                |
|               |              | AN13                             | Ι           | Analog         | Analog input 13.                                                 |
| 27            | 24           | RB6/IOC2/TX2/CK2/PGC             |             |                |                                                                  |
|               |              | RB6                              | I/O         | TTL            | Digital I/O.                                                     |
|               |              | IOC2                             | Т           | TTL            | Interrupt-on-change pin.                                         |
|               |              | TX2                              | 0           | —              | EUSART asynchronous transmit.                                    |
|               |              | CK2                              | I/O         | ST             | EUSART synchronous clock (see related RXx/DTx).                  |
|               |              | PGC                              | I/O         | ST             | In-Circuit Debugger and ICSP <sup>™</sup> programming clock pin. |
| 28            | 25           | RB7/IOC3/RX2/DT2/PGD             |             | -              |                                                                  |
|               |              | RB7                              | I/O         | TTL            | Digital I/O.                                                     |
|               |              | IOC3                             | I           | TTL            | Interrupt-on-change pin.                                         |
|               |              | RX2                              | I           | ST             | EUSART asynchronous receive.                                     |
|               |              | DT2                              | I/O         | ST             | EUSART synchronous data (see related TXx/CKx).                   |
|               |              | PGD                              | I/O         | ST             | In-Circuit Debugger and ICSP™ programming data pin.              |
| 11            | 8            | RC0/P2B/T3CKI/T3G/T1CKI/SOSCO    |             |                |                                                                  |
|               |              | RCO                              | I/O         | ST             | Digital I/O.                                                     |
|               |              | P2B <sup>(2)</sup>               | 0           | CMOS           | Enhanced CCP1 PWM output.                                        |
|               |              | ТЗСКІ <sup>(1)</sup>             | I           | ST             | Timer3 clock input.                                              |
|               |              | T3G                              | I           | ST             | Timer3 external clock gate input.                                |
|               |              | T1CKI                            | I           | ST             | Timer1 clock input.                                              |
|               |              | SOSCO                            | 0           | —              | Secondary oscillator output.                                     |
| 12            | 9            | RC1/P2A/CCP2/SOSCI               | 1           | I              | 1                                                                |
|               |              | RC1                              | I/O         | ST             | Digital I/O.                                                     |
|               |              | P2A                              | 0           | CMOS           | Enhanced CCP2 PWM output.                                        |
|               |              | CCP2 <sup>(1)</sup>              | I/O         | ST             | Capture 2 input/Compare 2 output/PWM 2 output.                   |
|               |              | SOSCI                            | Ι           | Analog         | Secondary oscillator input.                                      |
| Logond        | TTL          | TTL compatible input CMOS - CMOS | 2 comp      | stible inpu    | t ar autout, CT Cohmitt Trigger input with CMOC levels           |

#### TABLE 1-2: PIC18(L)F2XK22 PINOUT I/O DESCRIPTIONS (CONTINUED)

Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output; ST = Schmitt Trigger input with CMOS levels; I = Input; O = Output; P = Power.

Note 1: Default pin assignment for P2B, T3CKI, CCP3 and CCP2 when Configuration bits PB2MX, T3CMX, CCP3MX and CCP2MX are set.

2: Alternate pin assignment for P2B, T3CKI, CCP3 and CCP2 when Configuration bits PB2MX, T3CMX, CCP3MX and CCP2MX are clear.

| Pin Number |                |     | Pin  | Buffer                |             |            |                                                        |  |
|------------|----------------|-----|------|-----------------------|-------------|------------|--------------------------------------------------------|--|
| PDIP       | TQFP           | QFN | UQFN | Pin Name              | Туре        | Туре       | Description                                            |  |
| 37         | 14             | 14  | 12   | RB4/IOC0/T5G/AN11     |             |            |                                                        |  |
|            |                |     |      | RB4                   | I/O         | TTL        | Digital I/O.                                           |  |
|            |                |     |      | IOC0                  | I           | TTL        | Interrupt-on-change pin.                               |  |
|            |                |     |      | T5G                   | I           | ST         | Timer5 external clock gate input.                      |  |
|            |                |     |      | AN11                  | I           | Analog     | Analog input 11.                                       |  |
| 38         | 15             | 15  | 13   | RB5/IOC1/P3A/CCP3/T3C | KI/T1G/A    | N13        |                                                        |  |
|            |                |     |      | RB5                   | I/O         | TTL        | Digital I/O.                                           |  |
|            |                |     |      | IOC1                  | I           | TTL        | Interrupt-on-change pin.                               |  |
|            |                |     |      | P3A <sup>(1)</sup>    | 0           | CMOS       | Enhanced CCP3 PWM output.                              |  |
|            |                |     |      | CCP3 <sup>(1)</sup>   | I/O         | ST         | Capture 3 input/Compare 3 output/PWM 3 output.         |  |
|            |                |     |      | Т3СКІ <sup>(2)</sup>  | I           | ST         | Timer3 clock input.                                    |  |
|            |                |     |      | T1G                   | I           | ST         | Timer1 external clock gate input.                      |  |
|            |                |     |      | AN13                  | I           | Analog     | Analog input 13.                                       |  |
| 39         | 16             | 16  | 14   | RB6/IOC2/PGC          |             |            |                                                        |  |
|            |                |     |      | RB6                   | I/O         | TTL        | Digital I/O.                                           |  |
|            |                |     |      | IOC2                  | I           | TTL        | Interrupt-on-change pin.                               |  |
|            |                |     |      | PGC                   | I/O         | ST         | In-Circuit Debugger and ICSP™ programming              |  |
|            |                |     |      |                       |             | clock pin. |                                                        |  |
| 40         | 17             | 17  | 15   | RB7/IOC3/PGD          |             |            |                                                        |  |
|            |                |     |      | RB7                   | I/O         | TTL        | Digital I/O.                                           |  |
|            |                |     |      | IOC3                  | I           | TTL        | Interrupt-on-change pin.                               |  |
|            |                |     |      | PGD                   | I/O         | ST         | In-Circuit Debugger and ICSP™ programming<br>data pin. |  |
| 15         | 32             | 34  | 30   | RC0/P2B/T3CKI/T3G/T1C | KI/SOSC     | 0          |                                                        |  |
|            |                |     |      | RC0                   | I/O         | ST         | Digital I/O.                                           |  |
|            |                |     |      | P2B <sup>(2)</sup>    | 0           | CMOS       | Enhanced CCP1 PWM output.                              |  |
|            |                |     |      | Т3СКІ <sup>(1)</sup>  | I           | ST         | Timer3 clock input.                                    |  |
|            |                |     |      | T3G                   | I           | ST         | Timer3 external clock gate input.                      |  |
|            |                |     |      | T1CKI                 | I           | ST         | Timer1 clock input.                                    |  |
|            |                |     |      | SOSCO                 | 0           |            | Secondary oscillator output.                           |  |
| 16         | 35             | 35  | 31   | RC1/P2A/CCP2/SOSCI    |             |            |                                                        |  |
|            |                |     |      | RC1                   | I/O         | ST         | Digital I/O.                                           |  |
|            |                |     |      | P2A <sup>(1)</sup>    | 0           | CMOS       | Enhanced CCP2 PWM output.                              |  |
|            |                |     |      | CCP2 <sup>(1)</sup>   | I/O         | ST         | Capture 2 input/Compare 2 output/PWM 2 output.         |  |
|            |                |     |      | SOSCI                 | I           | Analog     | Secondary oscillator input.                            |  |
| 17         | 36             | 36  | 32   | RC2/CTPLS/P1A/CCP1/T  | 5CKI/AN1    | 4          |                                                        |  |
|            |                |     |      | RC2                   | I/O         | ST         | Digital I/O.                                           |  |
|            |                |     |      | CTPLS                 | ο           |            | CTMU pulse generator output.                           |  |
|            |                |     |      | P1A                   | 0           | смоз       | Enhanced CCP1 PWM output.                              |  |
|            |                |     |      | CCP1                  | I/O         | ST         | Capture 1 input/Compare 1 output/PWM 1 output.         |  |
|            |                |     |      | T5CKI                 | I           | ST         | Timer5 clock input.                                    |  |
|            |                |     |      | AN14                  |             | Analog     | Analog input 14                                        |  |
| Logon      | а. <u>тт</u> і |     | I    |                       | untible inc |            |                                                        |  |

| TABLE 1-3 | PIC18(I)F4XK22 PINOUT I/O DESCRIPTIONS ( | (CONTINUED) |   |
|-----------|------------------------------------------|-------------|---|
|           |                                          |             | / |

Legend: IIL = IIL compatible input CMOS = CMOS compatible input or output; SI = Schmitt Trigger input with CMOS levels; I = Input; O = Output; P = Power.

Note 1: Default pin assignment for P2B, T3CKI, CCP3/P3A and CCP2/P2A when Configuration bits PB2MX, T3CMX, CCP3MX and CCP2MX are set.

2: Alternate pin assignment for P2B, T3CKI, CCP3/P3A and CCP2/P2A when Configuration bits PB2MX, T3CMX, CCP3MX and CCP2MX are clear.

## 4.3 Master Clear (MCLR)

The  $\overline{\text{MCLR}}$  pin provides a method for triggering an external Reset of the device. A Reset is generated by holding the pin low. These devices have a noise filter in the  $\overline{\text{MCLR}}$  Reset path which detects and ignores small pulses. An internal weak <u>pull-up</u> is enabled when the pin is configured as the  $\overline{\text{MCLR}}$  input.

The  $\overline{\text{MCLR}}$  pin is not driven low by any internal Resets, including the WDT.

In PIC18(L)F2X/4XK22 devices, the MCLR input can be disabled with the MCLRE Configuration bit. When MCLR is disabled, the pin becomes a digital input. See **Section 10.6 "PORTE Registers"** for more information.

### 4.4 **Power-on Reset (POR)**

A Power-on Reset pulse is generated on-chip whenever VDD rises above a certain threshold. This allows the device to start in the initialized state when VDD is adequate for operation.

To take advantage of the POR circuitry either leave the pin floating, or tie the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create a Power-on Reset delay. A minimum rise rate for VDD is specified. For a slow rise time, see Figure 4-2.

When the device starts normal operation (i.e., exits the Reset condition), device operating parameters (voltage, frequency, temperature, etc.) must be met to ensure proper operation. If these conditions are not met, the device must be held in Reset until the operating conditions are met.

POR events are captured by the POR bit of the RCON register. The state of the bit is set to '0' whenever a POR occurs; it does not change for any other Reset event. POR is not reset to '1' by any hardware event. To capture multiple events, the user must manually set the bit to '1' by software following any POR.

#### FIGURE 4-2:

#### EXTERNAL POWER-ON RESET CIRCUIT (FOR SLOW VDD POWER-UP)



- Note 1: External Power-on Reset circuit is required only if the VDD power-up slope is too slow. The diode D helps discharge the capacitor quickly when VDD powers down.
  - 2:  $15 \text{ k}\Omega < R < 40 \text{ k}\Omega$  is recommended to make sure that the voltage drop across R does not violate the device's electrical specification.

Operations on the FSRs with POSTDEC, POSTINC and PREINC affect the entire register pair; that is, rollovers of the FSRnL register from FFh to 00h carry over to the FSRnH register. On the other hand, results of these operations do not change the value of any flags in the STATUS register (e.g., Z, N, OV, etc.).

The PLUSW register can be used to implement a form of indexed addressing in the data memory space. By manipulating the value in the W register, users can reach addresses that are fixed offsets from pointer addresses. In some applications, this can be used to implement some powerful program control structure, such as software stacks, inside of data memory.

#### 5.6.3.3 Operations by FSRs on FSRs

Indirect addressing operations that target other FSRs or virtual registers represent special cases. For example, using an FSR to point to one of the virtual registers will not result in successful operations. As a specific case, assume that FSR0H:FSR0L contains FE7h, the address of INDF1. Attempts to read the value of the INDF1 using INDF0 as an operand will return 00h. Attempts to write to INDF1 using INDF0 as the operand will result in a NOP.

On the other hand, using the virtual registers to write to an FSR pair may not occur as planned. In these cases, the value will be written to the FSR pair but without any incrementing or decrementing. Thus, writing to either the INDF2 or POSTDEC2 register will write the same value to the FSR2H:FSR2L.

Since the FSRs are physical registers mapped in the SFR space, they can be manipulated through all direct operations. Users should proceed cautiously when working on these registers, particularly if their code uses indirect addressing.

Similarly, operations by indirect addressing are generally permitted on all other SFRs. Users should exercise the appropriate caution that they do not inadvertently change settings that might affect the operation of the device.

## 5.7 Data Memory and the Extended Instruction Set

Enabling the PIC18 extended instruction set (XINST Configuration bit = 1) significantly changes certain aspects of data memory and its addressing. Specifically, the use of the Access Bank for many of the core PIC18 instructions is different; this is due to the introduction of a new addressing mode for the data memory space.

What does not change is just as important. The size of the data memory space is unchanged, as well as its linear addressing. The SFR map remains the same. Core PIC18 instructions can still operate in both Direct and Indirect Addressing mode; inherent and literal instructions do not change at all. Indirect addressing with FSR0 and FSR1 also remain unchanged.

#### 5.7.1 INDEXED ADDRESSING WITH LITERAL OFFSET

Enabling the PIC18 extended instruction set changes the behavior of indirect addressing using the FSR2 register pair within Access RAM. Under the proper conditions, instructions that use the Access Bank – that is, most bit-oriented and byte-oriented instructions – can invoke a form of indexed addressing using an offset specified in the instruction. This special addressing mode is known as Indexed Addressing with Literal Offset, or Indexed Literal Offset mode.

When using the extended instruction set, this addressing mode requires the following:

- The use of the Access Bank is forced ('a' = 0) and
- The file address argument is less than or equal to 5Fh.

Under these conditions, the file address of the instruction is not interpreted as the lower byte of an address (used with the BSR in direct addressing), or as an 8-bit address in the Access Bank. Instead, the value is interpreted as an offset value to an Address Pointer, specified by FSR2. The offset and the contents of FSR2 are added to obtain the target address of the operation.

#### 5.7.2 INSTRUCTIONS AFFECTED BY INDEXED LITERAL OFFSET MODE

Any of the core PIC18 instructions that can use direct addressing are potentially affected by the Indexed Literal Offset Addressing mode. This includes all byte-oriented and bit-oriented instructions, or almost one-half of the standard PIC18 instruction set. Instructions that only use Inherent or Literal Addressing modes are unaffected.

Additionally, byte-oriented and bit-oriented instructions are not affected if they do not use the Access Bank (Access RAM bit is '1'), or include a file address of 60h or above. Instructions meeting these criteria will continue to execute as before. A comparison of the different possible addressing modes when the extended instruction set is enabled is shown in Figure 5-11.

Those who desire to use byte-oriented or bit-oriented instructions in the Indexed Literal Offset mode should note the changes to assembler syntax for this mode. This is described in more detail in **Section 25.2.1** "Extended Instruction Syntax".

## 9.8 Register Definitions: Interrupt Control

| R/W-0        | R/W-0                                   | R/W-0                                | R/W-0                              | R/W-0                               | R/W-0              | R/W-0            | R/W/-x |
|--------------|-----------------------------------------|--------------------------------------|------------------------------------|-------------------------------------|--------------------|------------------|--------|
| GIE/GIE      | H PEIE/GIEI                             |                                      | INTOIF                             | RBIF                                | TMR0IF             |                  | RBIF   |
| bit 7        |                                         | TWITCHE                              | INTOL                              | TUBIE                               | TWITCOIL           |                  | bit 0  |
|              |                                         |                                      |                                    |                                     |                    |                  |        |
| Legend:      |                                         |                                      |                                    |                                     |                    |                  |        |
| R = Readab   | le bit                                  | W = Writable bi                      | t                                  | U = Unimplem                        | ented bit. read as | '0'              |        |
| -n = Value a | t POR                                   | '1' = Bit is set                     |                                    | '0' = Bit is clea                   | ared               | x = Bit is unkno | wn     |
|              |                                         | . 21110-001                          |                                    | 0 2010 0100                         |                    |                  |        |
| bit 7        | <b>GIE/GIEH:</b> Glol<br>When IPEN = 0  | bal Interrupt Ena                    | ble bit                            |                                     |                    |                  |        |
|              | 1 = Enables all                         | unmasked interr                      | upts                               |                                     |                    |                  |        |
|              | 0 = Disables all                        | l interrupts includ                  | ing peripherals                    | 5                                   |                    |                  |        |
|              | <u>When IPEN = 1</u>                    |                                      |                                    |                                     |                    |                  |        |
|              | 0 = Disables all                        | l interrupts includ                  | ing low priority                   |                                     |                    |                  |        |
| bit 6        | PEIE/GIEL: Pe                           | ripheral Interrupt                   | Enable bit                         |                                     |                    |                  |        |
|              | When $IPEN = 0$                         | ) <u>:</u><br>):                     |                                    |                                     |                    |                  |        |
|              | 1 = Enables all                         | unmasked perip                       | heral interrupts                   | i                                   |                    |                  |        |
|              | 0 = Disables all                        | l peripheral interr                  | upts                               |                                     |                    |                  |        |
|              | <u>When IPEN = 1</u><br>1 – Enchlos all | <u>.</u><br>low priority intor       | runto                              |                                     |                    |                  |        |
|              | 0 = Disables all                        | l low priority inter                 | rupts                              |                                     |                    |                  |        |
| bit 5        | TMROIE: TMRO                            | Overflow Interru                     | upt Enable bit                     |                                     |                    |                  |        |
|              | 1 = Enables the                         | e TMR0 overflow                      | interrupt                          |                                     |                    |                  |        |
|              | 0 = Disables the                        | e TMR0 overflow                      | interrupt                          |                                     |                    |                  |        |
| bit 4        | INTOIE: INTO E                          | xternal Interrupt                    | Enable bit                         |                                     |                    |                  |        |
|              | 1 = Enables the                         | e INT0 external ir                   | nterrupt                           |                                     |                    |                  |        |
| 1.10         | 0 = Disables the                        | e INTU external I                    | nterrupt                           |                                     | 2)                 |                  |        |
| bit 3        | RBIE: Port B In                         | terrupt-On-Chan                      | ge (IOCx) Inter                    | rupt Enable bit                     | -)                 |                  |        |
|              | 1 = Enables the<br>0 = Disables the     | e IOCx port chan                     | ge interrupt                       |                                     |                    |                  |        |
| bit 2        | TMROIF: TMRO                            | ) Overflow Interru                   | upt Flag bit                       |                                     |                    |                  |        |
|              | 1 = TMR0 regis                          | ster has overflow                    | ed (must be cle                    | ared by softwar                     | e)                 |                  |        |
|              | 0 = TMR0 regis                          | ster did not overfl                  | ow                                 |                                     | ,                  |                  |        |
| bit 1        | INTOIF: INTO E                          | xternal Interrupt                    | Flag bit                           |                                     |                    |                  |        |
|              | 1 = The INT0 e                          | xternal interrupt                    | occurred (must                     | be cleared by s                     | oftware)           |                  |        |
|              | 0 = The INT0 e                          | xternal interrupt                    | did not occur                      |                                     |                    |                  |        |
| bit 0        | RBIF: Port B In                         | terrupt-On-Chan                      | ge (IOCx) Inter                    | rupt Flag bit <sup>(1)</sup>        |                    |                  |        |
|              | 1 = At least one<br>0 = None of the     | e of the IOC<3:0><br>e IOC<3:0> (RB< | > (RB<7:4>) pir<br>7:4>) pins have | ns changed state<br>e changed state | e (must be cleared | by software)     |        |
| Note 1:      | A mismatch conditior                    | n will continue to                   | set the RBIF b                     | it. Reading POR                     | TB will end the    |                  |        |
| _            | mismatch condition a                    | and allow the bit t                  | o be cleared.                      |                                     |                    |                  |        |
| 2:           | RB port change inter                    | rupts also require                   | e the individual                   | pin IOCB enable                     | es.                |                  |        |
|              |                                         |                                      |                                    |                                     |                    |                  |        |

### REGISTER 9-1: INTCON: INTERRUPT CONTROL REGISTER

Note: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit. User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt. This feature allows for software polling.

### 10.4 PORTC Registers

PORTC is an 8-bit wide, bidirectional port. The corresponding data direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., disable the output driver). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin).

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

PORTC is multiplexed with several peripheral functions (Table 10-8). The pins have Schmitt Trigger input buffers.

Some of these pin functions can be relocated to alternate pins using the Control fuse bits in CONFIG3H. RC0 is the default pin for T3CKI. Clearing the T3CMX bit moves the pin function to RB5. RC1 is the default pin for the CCP2 peripheral pin. Clearing the CCP2MX bit moves the pin function to the RB3 pin.

Two other pin functions, P2B and CCP3, can be relocated from their default pins to PORTC pins by clearing the control fuses in CONFIG3H. Clearing P2BMX and CCP3MX moves the pin functions to RC0 and RC6<sup>(1)</sup>/RE0<sup>(2)</sup>, respectively.

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. The EUSART and MSSP peripherals override the TRIS bit to make a pin an output or an input, depending on the peripheral configuration. Refer to the corresponding peripheral section for additional information.

Note: On a Power-on Reset, these pins are configured as analog inputs.

The contents of the TRISC register are affected by peripheral overrides. Reading TRISC always returns the current contents, even though a peripheral device may be overriding one or more of the pins.

#### EXAMPLE 10-3: INITIALIZING PORTC

| MOVLB | 0xF    | ; Set BSR for banked SFRs   |
|-------|--------|-----------------------------|
| CLRF  | PORTC  | ; Initialize PORTC by       |
|       |        | ; clearing output           |
|       |        | ; data latches              |
| CLRF  | LATC   | ; Alternate method          |
|       |        | ; to clear output           |
|       |        | ; data latches              |
| MOVLW | 0CFh   | ; Value used to             |
|       |        | ; initialize data           |
|       |        | ; direction                 |
| MOVWF | TRISC  | ; Set RC<3:0> as inputs     |
|       |        | ; RC<5:4> as outputs        |
|       |        | ; RC<7:6> as inputs         |
| MOVLW | 30h    | ; Value used to             |
|       |        | ; enable digital inputs     |
| MOVWF | ANSELC | ; RC<3:2> dig input enable  |
|       |        | ; No ANSEL bits for RC<1:0> |
|       |        | ; RC<7:6> dig input enable  |
|       |        |                             |

#### 10.4.1 PORTC OUTPUT PRIORITY

Each PORTC pin is multiplexed with other functions. The pins, their combined functions and their output priorities are briefly described here. For additional information, refer to the appropriate section in this data sheet.

When multiple outputs are enabled, the actual pin control goes to the peripheral with the higher priority. Table 10-4 lists the PORTC pin functions from the highest to the lowest priority.

Analog input functions, such as ADC, comparator and SR latch inputs, are not shown in the priority lists.

These inputs are active when the I/O pin is set for Analog mode using the ANSELx registers. Digital output functions may control the pin when it is in Analog mode with the priority shown below.

#### 10.5 PORTD Registers

| Note: | PORTD is only available on 40-pin and |
|-------|---------------------------------------|
|       | 44-pin devices.                       |

PORTD is an 8-bit wide, bidirectional port. The corresponding data direction register is TRISD. Setting a TRISD bit (= 1) will make the corresponding PORTD pin an input (i.e., disable the output driver). Clearing a TRISD bit (= 0) will make the corresponding PORTD pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin).

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

All pins on PORTD are implemented with Schmitt Trigger input buffers. Each pin is individually configurable as an input or output.

All of the PORTD pins are multiplexed with analog and digital peripheral modules. See Table 10-11.

**Note:** On a Power-on Reset, these pins are configured as analog inputs.

EXAMPLE 10-4: INITIALIZING PORTD

| MOVLB | 0xF    | ; Set BSR for banked SFRs  |
|-------|--------|----------------------------|
| CLRF  | PORTD  | ; Initialize PORTD by      |
|       |        | ; clearing output          |
|       |        | ; data latches             |
| CLRF  | LATD   | ; Alternate method         |
|       |        | ; to clear output          |
|       |        | ; data latches             |
| MOVLW | 0CFh   | ; Value used to            |
|       |        | ; initialize data          |
|       |        | ; direction                |
| MOVWF | TRISD  | ; Set RD<3:0> as inputs    |
|       |        | ; RD<5:4> as outputs       |
|       |        | ; RD<7:6> as inputs        |
| MOVLW | 30h    | ; Value used to            |
|       |        | ; enable digital inputs    |
| MOVWF | ANSELD | ; RD<3:0> dig input enable |
|       |        | ; RC<7:6> dig input enable |
| 1     |        |                            |

#### 10.5.1 PORTD OUTPUT PRIORITY

Each PORTD pin is multiplexed with other functions. The pins, their combined functions and their output priorities are briefly described here. For additional information, refer to the appropriate section in this data sheet.

When multiple outputs are enabled, the actual pin control goes to the peripheral with the higher priority. Table 10-4 lists the PORTD pin functions from the highest to the lowest priority.

Analog input functions, such as ADC, comparator and SR latch inputs, are not shown in the priority lists.

These inputs are active when the I/O pin is set for Analog mode using the ANSELx registers. Digital output functions may control the pin when it is in Analog mode with the priority shown below.

#### 14.4.1 HALF-BRIDGE MODE

In Half-Bridge mode, two pins are used as outputs to drive push-pull loads. The PWM output signal is output on the CCPx/PxA pin, while the complementary PWM output signal is output on the PxB pin (see Figure 14-9). This mode can be used for half-bridge applications, as shown in Figure 14-9, or for full-bridge applications, where four power switches are being modulated with two PWM signals.

In Half-Bridge mode, the programmable dead-band delay can be used to prevent shoot-through current in halfbridge power devices. The value of the PDC<6:0> bits of the PWMxCON register sets the number of instruction cycles before the output is driven active. If the value is greater than the duty cycle, the corresponding output remains inactive during the entire cycle. See **Section 14.4.5 "Programmable Dead-Band Delay Mode"** for more details of the dead-band delay operations. Since the PxA and PxB outputs are multiplexed with the PORT data latches, the associated TRIS bits must be cleared to configure PxA and PxB as outputs.

#### FIGURE 14-8: EXAMPLE OF HALF-BRIDGE PWM OUTPUT



#### FIGURE 14-9: EXAMPLE OF HALF-BRIDGE APPLICATIONS







#### 15.6.8 ACKNOWLEDGE SEQUENCE TIMING

An Acknowledge sequence is enabled by setting the Acknowledge Sequence Enable bit, ACKEN, of the SSPxCON2 register. When this bit is set, the SCLx pin is pulled low and the contents of the Acknowledge data bit are presented on the SDAx pin. If the user wishes to generate an Acknowledge, then the ACKDT bit should be cleared. If not, the user should set the ACKDT bit before starting an Acknowledge sequence. The Baud Rate Generator then counts for one rollover period (TBRG) and the SCLx pin is deasserted (pulled high). When the SCLx pin is sampled high (clock arbitration), the Baud Rate Generator counts for TBRG. The SCLx pin is then pulled low. Following this, the ACKEN bit is automatically cleared, the Baud Rate Generator is turned off and the MSSPx module then goes into Idle mode (Figure 15-30).

#### 15.6.8.1 WCOL Status Flag

If the user writes the SSPxBUF when an Acknowledge sequence is in progress, then WCOL is set and the contents of the buffer are unchanged (the write does not occur).

#### 15.6.9 STOP CONDITION TIMING

A Stop bit is asserted on the SDAx pin at the end of a receive/transmit by setting the Stop Sequence Enable bit, PEN, of the SSPxCON2 register. At the end of a receive/transmit, the SCLx line is held low after the falling edge of the ninth clock. When the PEN bit is set, the master will assert the SDAx line low. When the SDAx line is sampled low, the Baud Rate Generator is reloaded and counts down to '0'. When the Baud Rate Generator times out, the SCLx pin will be brought high and one TBRG (Baud Rate Generator rollover count) later, the SDAx pin will be deasserted. When the SDAx pin is sampled high while SCLx is high, the P bit of the SSPxSTAT register is set. A TBRG later, the PEN bit is cleared and the SSPxIF bit is set (Figure 15-31).

#### 15.6.9.1 WCOL Status Flag

If the user writes the SSPxBUF when a Stop sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

### FIGURE 15-30: ACKNOWLEDGE SEQUENCE WAVEFORM



#### EXAMPLE 19-1: SETUP FOR CTMU CALIBRATION ROUTINES

```
#include "pl8cxxx.h"
void setup(void)
{ //CTMUCONH/1 - CTMU Control registers
   CTMUCONH = 0x00; //make sure CTMU is disabled
  CTMUCONL = 0x90;
  //CTMU continues to run when emulator is stopped,CTMU continues
  //to run in idle mode, Time Generation mode disabled, Edges are blocked
   //No edge sequence order, Analog current source not grounded, trigger
   //output disabled, Edge2 polarity = positive level, Edge2 source =
   //source 0, Edgel polarity = positive level, Edgel source = source 0,
   //CTMUICON - CTMU Current Control Register
   CTMUICON = 0x01; //0.55uA, Nominal - No Adjustment
//Set up AD converter;
TRISA=0x04;
                        //set channel 2 as an input
   // Configure AN2 as an analog channel
  ANSELAbits ANSA2=1;
  TRISAbits.TRISA2=1;
  // ADCON2
  ADCON2bits.ADFM=1; // Results format 1= Right justified
ADCON2bits.ACQT=1; // Acquition time 7 = 20TAD 2 = 4TAD 1=2TAD
ADCON2bits.ADCS=2; // Clock conversion bits 6= FOSC/64 2=FOSC/
                        // Clock conversion bits 6= FOSC/64 2=FOSC/32
  ADCON2bits.ADCS=2;
  // ADCON1
  ADCON1bits.PVCFG0 =0;
                        // Vref+ = AVdd
  ADCON1bits.NVCFG1 =0;
                         // Vref- = AVss
 // ADCON0
                        // Select ADC channel
  ADCON0bits.CHS=2;
  ADCON0bits.ADON=1; // Turn on ADC
}
```

#### FIGURE 25-1: GENERAL FORMAT FOR INSTRUCTIONS

| 15 10 9 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| OPCODE d a f (FILE #)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ADDWF MYREG, W, B                                                 |
| $      d = 0 \ \text{for result destination to be WREG register} $<br>$      d = 1 \ \text{for result destination to be file register (f)} $<br>$      a = 0 \ \text{to force Access Bank} $<br>$      a = 1 \ \text{for BSR to select bank} $<br>f = 8 -bit file register address                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                   |
| Byte to Byte move operations (2-word)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                   |
| 15 12 11 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                   |
| OPCODE f (Source FILE #)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | MOVFF MYREG1, MYREG2                                              |
| 15 12 11 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                   |
| 1111 f (Destination FILE #)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                   |
| f = 12-bit file register address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                   |
| Bit-oriented file register operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                   |
| 15 12 11 9 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                   |
| OPCODE b (BIT #) a f (FILE #)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | BSF MYREG, bit, B                                                 |
| b = 3-bit position of bit in file reaister (f)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                   |
| a = 0 to force Access Bank                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                   |
| $a = \perp$ for BSR to select bank<br>f = 8-bit file register address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                   |
| Literal operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                   |
| Literal operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | MONTER 755                                                        |
| Literal operations       15     8     7     0       OPCODE     k (literal)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MOVLW 7Fh                                                         |
| Literal operations       15     8     7     0       OPCODE     k (literal)       k = 8-bit immediate value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MOVLW 7Fh                                                         |
| Literal operations<br>15 8 7 0<br>OPCODE k (literal)<br>k = 8-bit immediate value<br>Control operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | MOVLW 7Fh                                                         |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         CALL, GOTO and Branch operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MOVLW 7Fh                                                         |
| Literal operations           15         8         7         0           OPCODE         k (literal)         k         k           k = 8-bit immediate value         k         k         k           Control operations         CALL, GOTO and Branch operations         0           15         8         7         0                                                                                                                                                                                                                                                                                                                                                                            | MOVLW 7Fh                                                         |
| Literal operations           15         8         7         0           OPCODE         k (literal)         k         k           k = 8-bit immediate value         k         k         k           Control operations           CALL, GOTO and Branch operations           15         8         7         0           OPCODE         n<7:0> (literal)         N                                                                                                                                                                                                                                                                                                                                | MOVLW 7Fh<br>GOTO Label                                           |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         CALL, GOTO and Branch operations         15       8       7       0         OPCODE       n<7:0> (literal)         15       12       11       0                                                                                                                                                                                                                                                                                                                                                                                     | MOVLW 7Fh<br>GOTO Label                                           |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         Control operations         15       8       7       0         OPCODE       n<7:0> (literal)       15       12       11       0         1111       n<19:8> (literal)       1111       1111       1111                                                                                                                                                                                                                                                                                                                               | MOVLW 7Fh<br>GOTO Label                                           |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         CALL, GOTO and Branch operations         15       8       7       0         OPCODE       n<7:0> (literal)       15       12       11       0         15       12       11       0       1111       n<19:8> (literal)         n = 20-bit immediate value                                                                                                                                                                                                                                                                            | MOVLW 7Fh<br>GOTO Label                                           |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         Call, GOTO and Branch operations         15       8       7       0         OPCODE       n<7:0> (literal)       1         15       12       11       0         1111       n<19:8> (literal)       1         n = 20-bit immediate value       15       8       7       0                                                                                                                                                                                                                                                            | MOVLW 7Fh<br>GOTO Label                                           |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870 $15$ 1211015121101111n<19:8> (literal)n = 20-bit immediate value15870OPCODESn<7:0> (literal)                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870OPCODE $n<7:0>$ (literal)15121101111 $n<19:8>$ (literal)n = 20-bit immediate value15870OPCODES $n<7:0>$ (literal)1512110                                                                                                                                                                                                                                                                                                                                                                                                                                               | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870OPCODE $n<7:0>$ (literal)15121101111 $n<19:8>$ (literal)n = 20-bit immediate value15870OPCODES $n<7:0>$ (literal)15121101512110151211015121101111 $n<19:8>$ (literal)1                                                                                                                                                                                                                                                                                                                                                                                                 | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870 $0PCODE$ n<7:0> (literal)15121101111n<19:8> (literal)n = 20-bit immediate value15870 $0PCODE$ Sn<7:0> (literal)15121101512110 $15$ 870 $S$ Fast bit $N = 19:8>$ (literal)                                                                                                                                                                                                                                                                                                                                                                                             | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations $15$ 870 $OPCODE$ k (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations $15$ 870 $OPCODE$ n<7:0> (literal)15121101111n<19:8> (literal)n = 20-bit immediate value $15$ 870 $OPCODE$ Sn<7:0> (literal)1512110 $15$ 12110 $15$ 12110 $15$ 12110 $1111$ n<19:8> (literal)SS = Fast bit                                                                                                                                                                                                                                                                                                                                                         | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations         15       8       7       0         OPCODE       k (literal)         k = 8-bit immediate value         Control operations         Control operations         CALL, GOTO and Branch operations         DPCODE       n <7:0> (literal)         15       12       11       0         1111       n <7:0> (literal)         15       12       11       0         15       12       11       0         15       12       11       0         15       12       11       0         15       12       11       0         1111       n <19:8> (literal)       1         15       11       10       0         15       11       10       0         15       11       10       0 | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870OPCODE $n<7:0>$ (literal)15121101111 $n<19:8>$ (literal)n = 20-bit immediate value15870OPCODES $n<7:0>$ (literal)151211015121101111 $n<19:8>$ (literal)SS = Fast bitS $n<10:0>$ (literal)                                                                                                                                                                                                                                                                                                                                                                              | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC<br>BRA MYFUNC              |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870OPCODE $n<7:0>$ (literal)15121101111 $n<19:8>$ (literal)n = 20-bit immediate value15870OPCODES $n<7:0>$ (literal)151211015121101512110S = Fast bit1511101511100OPCODE $n<10:0>$ (literal)1                                                                                                                                                                                                                                                                                                                                                                             | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC                            |
| Literal operations15870OPCODEk (literal)k = 8-bit immediate valueControl operationsCALL, GOTO and Branch operations15870 $0$ $0$ $n < 7:0 > (literal)$ 15121101111 $n < 19:8 > (literal)$ $n = 20$ -bit immediate value15870 $0$ $0$ $0$ $0$ $15$ 12110 $15$ 12110 $15$ 12110 $15$ 12110 $15$ 12110 $15$ 11 $10$ 0 $0$ $0$ $0$ $0$ $15$ 11100 $15$ 870 $0$ $0$ $0$ $0$ $15$ 870 $0$ $0$ $0$ $0$ $15$ 870 $0$ $0$ $0$ $0$ $15$ 870 $0$ $0$ $0$ $0$ $0$ $0$ $0$ $0$                                                                                                                                                                                                                              | MOVLW 7Fh<br>GOTO Label<br>CALL MYFUNC<br>BRA MYFUNC<br>BC MYFUNC |

| MO\                    | /SS                                   | Move Inde                                                                                                                                                                                                                                                                    | exed to In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | dexec               | I                 |  |  |  |
|------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------|--|--|--|
| Synta                  | ax:                                   | MOVSS [z                                                                                                                                                                                                                                                                     | z <sub>s</sub> ], [z <sub>d</sub> ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                     |                   |  |  |  |
| Oper                   | ands:                                 | $0 \le z_s \le 127$<br>$0 \le z_d \le 127$                                                                                                                                                                                                                                   | 7<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     |                   |  |  |  |
| Oper                   | ation:                                | ((FSR2) + z                                                                                                                                                                                                                                                                  | $(FSR) \rightarrow ((FSR))$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2) + z <sub>d</sub> | )                 |  |  |  |
| Statu                  | s Affected:                           | None                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                   |  |  |  |
| Enco<br>1st w<br>2nd v | ding:<br>ord (source)<br>vord (dest.) | 1110 1011 1zzz zzzz <sub>s</sub><br>1111 xxxx xzzz zzzz <sub>d</sub>                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                   |  |  |  |
| Desc                   | ription                               | The content<br>moved to the<br>addresses of<br>registers are<br>7-bit literal of<br>respectively<br>registers can<br>the 4096-by<br>(000h to FF<br>The MOVSS<br>PCL, TOSU<br>destination<br>If the results<br>an indirect a<br>value return<br>resultant de<br>an indirect a | 1111xxxxxzzzzzzz_dThe contents of the source register are<br>moved to the destination register. The<br>addresses of the source and destination<br>registers are determined by adding the<br>7-bit literal offsets 'zs' or 'zd',<br>respectively, to the value of FSR2. Both<br>registers can be located anywhere in<br>the 4096-byte data memory space<br>(000h to FFFh).The MOVSS instruction cannot use the<br>PCL, TOSU, TOSH or TOSL as the<br>destination register.If the resultant source address points to<br>an indirect addressing register, the<br>value returned will be 00h. If the<br>resultant destination address points to<br>an indirect addressing register, the |                     |                   |  |  |  |
| Word                   | ls:                                   | 2                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                   |  |  |  |
| Cycle                  | es:                                   | 2                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                   |  |  |  |
| Q Cycle Activity:      |                                       |                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                   |  |  |  |
|                        | Q1                                    | Q2                                                                                                                                                                                                                                                                           | Q3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     | Q4                |  |  |  |
|                        | Decode                                | Determine                                                                                                                                                                                                                                                                    | Determine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                     | Read              |  |  |  |
|                        |                                       | source addr                                                                                                                                                                                                                                                                  | source add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ir so               | urce reg          |  |  |  |
|                        | Decode                                | Determine<br>dest addr                                                                                                                                                                                                                                                       | Determine<br>dest addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | to                  | Write<br>dest reg |  |  |  |

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

| PUS                                                                   | HL                            | S                   | tore Liter                                                           | al a                                   | t FSR                                           | 2, Decr                                            | em                       | ent FSR2                                     |
|-----------------------------------------------------------------------|-------------------------------|---------------------|----------------------------------------------------------------------|----------------------------------------|-------------------------------------------------|----------------------------------------------------|--------------------------|----------------------------------------------|
| Synta                                                                 | ax:                           | Р                   | USHL k                                                               |                                        |                                                 |                                                    |                          |                                              |
| Oper                                                                  | ands:                         | 0                   | ≤ k ≤ 255                                                            |                                        |                                                 |                                                    |                          |                                              |
| Oper                                                                  | ation:                        | k<br>F              | → (FSR2)<br>SR2 – 1 –                                                | ,<br>→ FS                              | R2                                              |                                                    |                          |                                              |
| Statu                                                                 | s Affected:                   | N                   | one                                                                  |                                        |                                                 |                                                    |                          |                                              |
| Enco                                                                  | ding:                         |                     | 1111                                                                 | 10                                     | 010                                             | kkkk                                               |                          | kkkk                                         |
| Description:                                                          |                               |                     | ne 8-bit lite<br>emory add<br>decremer<br>nis instruc<br>nto a softw | eral f<br>dres<br>nted<br>tion<br>vare | k' is w<br>s spec<br>by 1 a<br>allows<br>stack. | vritten to<br>cified by<br>after the<br>s users to | the<br>FS<br>ope<br>o pu | e data<br>R2. FSR2<br>eration.<br>ush values |
| Word                                                                  | ls:                           | 1                   |                                                                      |                                        |                                                 |                                                    |                          |                                              |
| Cycle                                                                 | es:                           | 1                   |                                                                      |                                        |                                                 |                                                    |                          |                                              |
| QC                                                                    | ycle Activity                 | <b>'</b> :          |                                                                      |                                        |                                                 |                                                    |                          |                                              |
|                                                                       | Q1                            |                     | Q2                                                                   |                                        |                                                 | Q3                                                 |                          | Q4                                           |
|                                                                       | Decode                        |                     | Read 'I                                                              | K'                                     | Pro                                             | ocess<br>lata                                      | d                        | Write to estination                          |
| Example: PUSHL<br>Before Instruction<br>FSR2H:FSR2L<br>Memory (01ECh) |                               |                     |                                                                      | 081                                    | 1<br>=<br>=                                     | 01ECh<br>00h                                       |                          |                                              |
|                                                                       | After Instru<br>FSR2I<br>Memo | ctio<br>H:F<br>ry ( | on<br>SR2L<br>(01ECh)                                                |                                        | =<br>=                                          | 01EBh<br>08h                                       |                          |                                              |

### 26.11 Demonstration/Development Boards, Evaluation Kits, and Starter Kits

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

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

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

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

Also available are starter kits that contain everything needed to experience the specified device. This usually includes a single application and debug capability, all on one board.

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

## 26.12 Third-Party Development Tools

Microchip also offers a great collection of tools from third-party vendors. These tools are carefully selected to offer good value and unique functionality.

- Device Programmers and Gang Programmers from companies, such as SoftLog and CCS
- Software Tools from companies, such as Gimpel and Trace Systems
- Protocol Analyzers from companies, such as Saleae and Total Phase
- Demonstration Boards from companies, such as MikroElektronika, Digilent<sup>®</sup> and Olimex
- Embedded Ethernet Solutions from companies, such as EZ Web Lynx, WIZnet and IPLogika<sup>®</sup>

| PIC18LF2X/4XK22 |                             | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$  |       |       |                 |            |                                                                                  |  |  |
|-----------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------|-------|-------|-----------------|------------|----------------------------------------------------------------------------------|--|--|
| PIC18F2X/4XK22  |                             | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le T_A \le +125^{\circ}C$ |       |       |                 |            |                                                                                  |  |  |
| Param<br>No.    | Device Characteristics      | Тур                                                                                                                   | Max   | Units |                 | Conditions |                                                                                  |  |  |
| D100            | Supply Current (IDD)(1),(2) | 0.030                                                                                                                 | 0.050 | mA    | -40°C to +125°C | Vdd = 1.8V | Fosc = 1 MHz                                                                     |  |  |
| D101            |                             | 0.045                                                                                                                 | 0.065 | mA    | -40°C to +125°C | VDD = 3.0V | ( <b>PRI_IDLE</b> mode,<br>ECM source)                                           |  |  |
| D102            |                             | 0.06                                                                                                                  | 0.12  | mA    | -40°C to +125°C | VDD = 2.3V | Fosc = 1 MHz                                                                     |  |  |
| D103            |                             | 0.08                                                                                                                  | 0.15  | mA    | -40°C to +125°C | VDD = 3.0V | (PRI_IDLE mode,                                                                  |  |  |
| D104            |                             | 0.13                                                                                                                  | 0.20  | mA    | -40°C to +125°C | VDD = 5.0V | Low source)                                                                      |  |  |
| D105            |                             | 0.45                                                                                                                  | 0.8   | mA    | -40°C to +125°C | VDD = 1.8V | Fosc = 20 MHz                                                                    |  |  |
| D106            |                             | 0.70                                                                                                                  | 1.0   | mA    | -40°C to +125°C | VDD = 3.0V | ( <b>PRI_IDLE</b> mode,<br>ECH source)                                           |  |  |
| D107            |                             | 0.55                                                                                                                  | 0.8   | mA    | -40°C to +125°C | VDD = 2.3V | Fosc = 20 MHz<br>( <b>PRI_IDLE</b> mode,<br>ECH source)                          |  |  |
| D108            |                             | 0.75                                                                                                                  | 1.0   | mA    | -40°C to +125°C | VDD = 3.0V |                                                                                  |  |  |
| D109            |                             | 0.90                                                                                                                  | 1.2   | mA    | -40°C to +125°C | VDD = 5.0V | Lon source)                                                                      |  |  |
| D110            |                             | 2.25                                                                                                                  | 3.0   | mA    | -40°C to +125°C | Vdd = 3.0V | Fosc = 64 MHz<br>( <b>PRI_IDLE</b> mode,<br>ECH source)                          |  |  |
| D111            |                             | 2.25                                                                                                                  | 3.0   | mA    | -40°C to +125°C | VDD = 3.0V | Fosc = 64 MHz<br>( <b>PRI_IDLE</b> mode,<br>ECH source)                          |  |  |
| D112            |                             | 2.60                                                                                                                  | 3.5   | mA    | -40°C to +125°C | VDD = 5.0V |                                                                                  |  |  |
| D113            |                             | 0.35                                                                                                                  | 0.6   | mA    | -40°C to +125°C | VDD = 1.8V | Fosc = 4 MHz                                                                     |  |  |
| D114            |                             | 0.55                                                                                                                  | 0.8   | mA    | -40°C to +125°C | VDD = 3.0V | 16 MHz Internal<br>( <b>PRI_IDLE</b> mode,<br>ECM + PLL source)                  |  |  |
| D115            |                             | 0.45                                                                                                                  | 0.6   | mA    | -40°C to +125°C | VDD = 2.3V | Fosc = 4 MHz<br>16 MHz Internal<br>( <b>PRI_IDLE</b> mode,<br>ECM + PLL source)  |  |  |
| D116            |                             | 0.60                                                                                                                  | 0.9   | mA    | -40°C to +125°C | VDD = 3.0V |                                                                                  |  |  |
| D117            |                             | 0.70                                                                                                                  | 1.0   | mA    | -40°C to +125°C | VDD = 5.0V |                                                                                  |  |  |
| D118            |                             | 2.2                                                                                                                   | 3.0   | mA    | -40°C to +125°C | VDD = 3.0V | Fosc = 16 MHz<br>64 MHz Internal<br>( <b>PRI_IDLE</b> mode,<br>ECH + PLL source) |  |  |
| D119            |                             | 2.2                                                                                                                   | 3.0   | mA    | -40°C to +125°C | VDD = 3.0V | Fosc = 16 MHz<br>64 MHz Internal<br>( <b>PRI_IDLE</b> mode,<br>ECH + PLL source) |  |  |
| D120            |                             | 2.5                                                                                                                   | 3.5   | mA    | -40°C to +125°C | VDD = 5.0V |                                                                                  |  |  |

## 27.6 DC Characteristics: Primary Idle Supply Current, PIC18(L)F2X/4XK22

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

Test condition: All Peripheral Module Control bits in PMD0, PMD1 and PMD2 set to '1'.

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

All I/O pins set as outputs driven to Vss;

MCLR = VDD;

OSC1 = external square wave, from rail-to-rail (PRI\_RUN and PRI\_IDLE only).



FIGURE 28-60: PIC18LF2X/4XK22 TYPICAL IDD: PRI\_IDLE EC MEDIUM POWER









FIGURE 28-73: PIC18LF2X/4XK22 MAXIMUM IDD: SEC\_RUN 32.768 kHz





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

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



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

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2156B

44-Lead Plastic Thin Quad Flatpack (PT) 10X10X1 mm Body, 2.00 mm Footprint [TQFP]

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



## RECOMMENDED LAND PATTERN

|                          | MILLIMETERS |          |       |      |
|--------------------------|-------------|----------|-------|------|
| Dimension Limits         |             | MIN      | NOM   | MAX  |
| Contact Pitch            | E           | 0.80 BSC |       |      |
| Contact Pad Spacing      | C1          |          | 11.40 |      |
| Contact Pad Spacing      | C2          |          | 11.40 |      |
| Contact Pad Width (X44)  | X1          |          |       | 0.55 |
| Contact Pad Length (X44) | Y1          |          |       | 1.50 |
| Distance Between Pads    | G           | 0.25     |       |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2076B