



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 64MHz                                                                       |
| Connectivity               | CANbus, I <sup>2</sup> C, LINbus, SPI, UART/USART                           |
| Peripherals                | Brown-out Detect/Reset, DMA, POR, PWM, WDT                                  |
| Number of I/O              | 25                                                                          |
| Program Memory Size        | 32KB (16K x 16)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 1K x 8                                                                      |
| RAM Size                   | 2K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                 |
| Data Converters            | A/D 24x12b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                              |
| Supplier Device Package    | 28-SSOP                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f25k83t-i-ss |
|                            |                                                                             |

Email: info@E-XFL.COM

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

#### TABLE 3-2: SUMMARY OF REGISTERS ASSOCIATED WITH CPU

| Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1   | Bit 0    | Register on page |
|--------|-------|-------|-------|-------|-------|---------|---------|----------|------------------|
| ISRPR  | —     | _     | _     | _     | -     | ISRPR2  | ISRPR1  | ISRPR0   | 20               |
| MAINPR | —     | _     | _     | _     | _     | MAINPR2 | MAINPR1 | MAINPR0  | 20               |
| DMA1PR | —     | _     | _     | _     | _     | DMA1PR2 | DMA1PR1 | DMA1PR0  | 20               |
| DMA2PR | —     | _     | _     | _     | _     | DMA2PR2 | DMA2PR1 | DMA2PR0  | 21               |
| SCANPR | —     | _     | _     | _     | _     | SCANPR2 | SCANPR1 | SCANPR0  | 21               |
| PRLOCK | _     | _     | _     | _     | —     | _       | _       | PRLOCKED | 21               |

**Legend:** — = Unimplemented location, read as '0'.

#### 9.4.3 PREEMPTING LOW PRIORITY INTERRUPTS

Low-priority interrupts can be preempted by high priority interrupts. While in the low priority ISR, if a high-priority interrupt arrives, the high priority interrupt request is generated and the low priority ISR is suspended, while the high priority ISR is executed, see Figure 9-4.

After the high priority ISR is complete and if any other high priority interrupt requests are not active, the execution returns to the preempted low priority ISR.

- **Note 1:** The high priority interrupt flag must be cleared to avoid recursive interrupts.
  - 2: If a low-priority ISR was already serviced halfway before moving on to a high priority ISR, then the low priority ISR is completely serviced even if user code clears GIEL.

#### FIGURE 9-4: INTERRUPT EXECUTION: HIGH PRIORITY INTERRUPT PREEMPTING LOW PRIORITY INTERRUPTS





#### 10.1.2 INTERRUPTS DURING DOZE

If an interrupt occurs and the Recover-On-Interrupt bit is clear (ROI = 0) at the time of the interrupt, the Interrupt Service Routine (ISR) continues to execute at the rate selected by DOZE<2:0>. Interrupt latency is extended by the DOZE<2:0> ratio.

If an interrupt occurs and the ROI bit is set (ROI = 1) at the time of the interrupt, the DOZEN bit is cleared and the CPU executes at full speed. The prefetched instruction is executed and then the interrupt vector sequence is executed. In Figure 10-1, the interrupt occurs during the 2<sup>nd</sup> instruction cycle of the Doze period, and immediately brings the CPU out of Doze. If the Doze-On-Exit (DOE) bit is set (DOE = 1) when the RETFIE operation is executed, DOZEN is set, and the CPU executes at the reduced rate based on the DOZE<2:0> ratio.

#### EXAMPLE 10-1: DOZE SOFTWARE EXAMPLE

```
//Mainline operation
bool somethingToDo = FALSE:
void main()
   initializeSystem();
           // DOZE = 64:1 (for example)
           // ROI = 1;
   GIE = 1; // enable interrupts
   while (1)
   {
       // If ADC completed, process data
       if (somethingToDo)
       {
           doSomething();
           DOZEN = 1; // resume low-power
       }
   }
// Data interrupt handler
void interrupt()
   // DOZEN = 0 because ROI = 1
   if (ADIF)
   {
       somethingToDo = TRUE;
       DOE = 0; // make main() go fast
       ADIF = 0;
   // else check other interrupts...
   if (TMROIF)
   {
       timerTick++;
       DOE = 1; // make main() go slow
       TMROIF = 0;
   }
```

#### 10.2 Sleep Mode

Sleep mode is entered by executing the SLEEP instruction, while the Idle Enable (IDLEN) bit of the CPUDOZE register is clear (IDLEN = 0).

Upon entering Sleep mode, the following conditions exist:

- 1. WDT will be cleared but keeps running if enabled for operation during Sleep
- 2. The PD bit of the STATUS register is cleared (Register 4-2)
- 3. The TO bit of the STATUS register is set (Register 4-2)
- 4. The CPU clock is disabled
- 5. LFINTOSC, SOSC, HFINTOSC and ADCRC are unaffected and peripherals using them may continue operation in Sleep.
- I/O ports maintain the status they had before Sleep was executed (driving high, low, or highimpedance)
- 7. Resets other than WDT are not affected by Sleep mode

Refer to individual chapters for more details on peripheral operation during Sleep.

To minimize current consumption, the following conditions should be considered:

- I/O pins should not be floating
- External circuitry sinking current from I/O pins
- Internal circuitry sourcing current from I/O pins
- Current draw from pins with internal weak pull-ups
- Modules using any oscillator

I/O pins that are high-impedance inputs should be pulled to VDD or Vss externally to avoid switching currents caused by floating inputs.

Examples of internal circuitry that might be sourcing current include modules such as the DAC and FVR modules. See Section 38.0 "5-Bit Digital-to-Analog Converter (DAC) Module" and Section 35.0 "Fixed Voltage Reference (FVR)" for more information on these modules.

#### 12.0 8x8 HARDWARE MULTIPLIER

#### 12.1 Introduction

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

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

#### 12.2 Operation

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

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

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

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

### EXAMPLE 12-2: 8x8 SIGNED MULTIPLY

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

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

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

#### 13.1.5 ERASING PROGRAM FLASH MEMORY

The minimum erase block is 64 words (refer to Table 5-4). Only through the use of an external programmer, or through ICSP™ control, can larger blocks of program memory be bulk erased. Word erase in the program memory array is not supported.

For example, when initiating an erase sequence from a microcontroller with erase row size of 64 words, a block of 64 words (128 bytes) of program memory is erased. The Most Significant 16 bits of the TBLPTR<21:6> point to the block being erased. The TBLPTR<5:0> bits are ignored.

The NVMCON1 register commands the erase operation. The REG<1:0> bits must be set to point to the Program Flash Memory. The WREN bit must be set to enable write operations. The FREE bit is set to select an erase operation.

The NVM unlock sequence described in **Section 13.1.4 "NVM Unlock Sequence**" should be used to guard against accidental writes. This is sometimes referred to as a long write.

A long write is necessary for erasing program memory. Instruction execution is halted during the long write cycle. The long write is terminated by the internal programming timer.

#### 13.1.5.1 Program Flash Memory Erase Sequence

The sequence of events for erasing a block of internal program memory is:

- 1. REG bits of the NVMCON1 register point to PFM
- 2. Set the FREE and WREN bits of the NVMCON1 register
- 3. Perform the unlock sequence as described in Section 13.1.4 "NVM Unlock Sequence"

If the PFM address is write-protected, the WR bit will be cleared and the erase operation will not take place, WRERR is signaled in this scenario.

The operation erases the memory row indicated by masking the LSBs of the current TBLPTR.

While erasing PFM, CPU operation is suspended and it resumes when the operation is complete. Upon completion the WR bit is cleared in hardware, the NVMIF is set and an interrupt will occur if the NVMIE bit is also set.

Write latch data is not affected by erase operations and WREN will remain unchanged.

Note 1: If a write or erase operation is terminated by an unexpected event, WRERR bit will be set which the user can check to decide whether a rewrite of the location(s) is needed.

- 2: WRERR is set if WR is written to '1' while TBLPTR points to a write-protected address.
- **3:** WRERR is set if WR is written to '1' while TBLPTR points to an invalid address location (Table 13-1).

## 15.9.6 ABORT TRIGGER, MESSAGE COMPLETE

Г

The AIRQEN needs to be set in order for the DMA to sample Abort Interrupt sources. When an abort interrupt is received the SIRQEN bit is cleared and the AIRQEN bit is cleared to avoid receiving further abort triggers.

| FIGURE 15-10: | ABORT AT THE END OF MESSAGE |
|---------------|-----------------------------|
|               |                             |

|                            | (j)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction<br>Clock       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| EN                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SIRQEN                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| AIRQEN                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Source Hardware<br>Trigger |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Abort Hardware<br>Trigger  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DGO                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMAxSPTR                   | Ox3EEF         Ox3EF0         Society         Ox3EEF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| DMAxDPTR                   | 0x100         0x101         5         0x109         0x10A         0x100         0x100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DMAxSCNT                   | $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DMAxDCNT                   | $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DMA STATE                  | $ \left( \begin{array}{c} \text{IDLE} \end{array} \right) \left( SR^{(1)} \right) DW^{(2)} \right) SR^{(1)} \left( DW^{(2)} \right) \left( SR^{(1)} \right) DW^{(2)} \left( SR^{(1)} \right) DW^{(2)} \right) OW^{(2)} \left( SR^{(1)} \right) DW^{(2)} \right) OW^{(2)} \left( SR^{(1)} \right) DW^{(2)} \left( SR^{(1)} \right) DW^{(2)} \right) OW^{(2)} \left( SR^{(1)} \right) DW^{(2)} \left( SR^{(1)} \right) $ |
| DMAxSCNTIF _               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMAxDCNTIF -               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DMAxAIF -                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                            | DMAxSSA 0x3EEF DMAxDSA 0x100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | DMAxSSZ 0x2 DMAxDSZ 0xA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Note 1:                    | SR – Source Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2:                         | DW – Destination Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| R/W-0/0          | R/W-0/0                                               | R/W-0/0           | R/W-0/0 | R/W-0/0                            | R/W-0/0 | R/W-0/0 | R/W-0/0 |  |  |  |
|------------------|-------------------------------------------------------|-------------------|---------|------------------------------------|---------|---------|---------|--|--|--|
| WPUx7            | WPUx6                                                 | WPUx5             | WPUx4   | WPUx3                              | WPUx2   | WPUx1   | WPUx0   |  |  |  |
| bit 7            | ·                                                     |                   |         |                                    |         |         | bit 0   |  |  |  |
|                  |                                                       |                   |         |                                    |         |         |         |  |  |  |
| Legend:          |                                                       |                   |         |                                    |         |         |         |  |  |  |
| R = Readable     | R = Readable bit W = Writable bit                     |                   |         | U = Unimplemented bit, read as '0' |         |         |         |  |  |  |
| '1' = Bit is set |                                                       | '0' = Bit is clea | ared    | x = Bit is unkr                    | nown    |         |         |  |  |  |
| -n/n = Value a   | -n/n = Value at POR and BOR/Value at all other Resets |                   |         |                                    |         |         |         |  |  |  |

#### REGISTER 16-5: WPUx: WEAK PULL-UP REGISTER

bit 7-0

WPUx<7:0>: Weak Pull-up PORTx Control bits

1 = Weak Pull-up enabled

0 = Weak Pull-up disabled

#### TABLE 16-6: WEAK PULL-UP PORT REGISTERS

| Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3                | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|----------------------|-------|-------|-------|
| WPUA | WPUA7 | WPUA6 | WPUA5 | WPUA4 | WPUA3                | WPUA2 | WPUA1 | WPUA0 |
| WPUB | WPUB7 | WPUB6 | WPUB5 | WPUB4 | WPUB3                | WPUB2 | WPUB1 | WPUB0 |
| WPUC | WPUC7 | WPUC6 | WPUC5 | WPUC4 | WPUC3                | WPUC2 | WPUC1 | WPUC0 |
| WPUE | _     | _     | _     | _     | WPUE3 <sup>(1)</sup> | _     | —     | —     |

**Note 1:** If MCLRE = 1, the weak pull-up in RE3 is always enabled; bit WPUE3 is not affected.

| FIGURE 21-5:   | TIMER1/3/5 GATE TOGGLE MODE                     |
|----------------|-------------------------------------------------|
|                |                                                 |
| TMRxGE         |                                                 |
| TxGPOL         |                                                 |
| TxGTM          |                                                 |
| TxTxG_IN       |                                                 |
| ТхСКІ          |                                                 |
| TxGV <u>AL</u> |                                                 |
| TIMER1/3/5     | N $(N+1)(N+2)(N+3)(N+4)$ $(N+5)(N+6)(N+7)(N+8)$ |

#### FIGURE 21-6: TIMER1/3/5 GATE SINGLE-PULSE MODE





#### 28.8 NCO Control Registers

| EN       —         bit 7         Legend:         R = Readable bit       W =         u = Bit is unchanged       x = 1         '1' = Bit is set       '0' =         bit 7       EN: NCO1 Enable         1 = NCO1 module       0 = NCO1 module         0 = NCO1 module       0 = NCO1 module         bit 6       Unimplemented:         bit 5       OUT: NCO1 Output         Displays the current       1 = NCO1 output st         0 = NCO1 output st       0 = NCO1 output st         bit 3-1       Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                    |                  |                |                  |                  |              |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|------------------|----------------|------------------|------------------|--------------|--|--|--|
| bit 7  Legend: R = Readable bit W = u = Bit is unchanged x = '1' = Bit is set '0' = bit 7 EN: NCO1 Enable 1 = NCO1 module 0 = NCO1 module bit 6 Unimplemented: bit 5 OUT: NCO1 Outpu Displays the curren bit 4 POL: NCO1 Polari 1 = NCO1 output s 0 = NCO1 output s bit 3-1 Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R-0/0 R/W-0                                                                                        | R/W-0/0          | U-0            | U-0              | U-0              | R/W-0/0      |  |  |  |
| Legend:           R = Readable bit         W =           u = Bit is unchanged         x =           '1' = Bit is set         '0' =           bit 7         EN: NCO1 Enable           1 = NCO1 module         0 = NCO1 module           0 = NCO1 module         0 = NCO1 module           bit 6         Unimplemented:           bit 5         OUT: NCO1 Output           Displays the current         1 = NCO1 output st           bit 4         POL: NCO1 Polarit           1 = NCO1 output st         0 = NCO1 output st           0 = NCO1 output st         0 = NCO1 output st           bit 3-1         Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | OUT POL                                                                                            | POL              | _              | —                | _                | PFM          |  |  |  |
| R = Readable bit       W =         u = Bit is unchanged       x =         '1' = Bit is set       '0' =         bit 7       EN: NCO1 Enable         1 = NCO1 module       1 = NCO1 module         0 = NCO1 module       0 = NCO1 module         bit 6       Unimplemented:         bit 5       OUT: NCO1 Output         Displays the current       1 = NCO1 output st         bit 4       POL: NCO1 Polari         1 = NCO1 output st       0 = NCO1 output st         bit 3-1       Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                    | -                |                |                  |                  | bit 0        |  |  |  |
| R = Readable bit       W =         u = Bit is unchanged       x =         '1' = Bit is set       '0' =         bit 7       EN: NCO1 Enable         1 = NCO1 module       1 = NCO1 module         0 = NCO1 module       0 = NCO1 module         bit 6       Unimplemented:         bit 5       OUT: NCO1 Output         Displays the current       1 = NCO1 output st         bit 4       POL: NCO1 Polari         1 = NCO1 output st       0 = NCO1 output st         bit 3-1       Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                    |                  |                |                  |                  |              |  |  |  |
| u = Bit is unchanged       x = 1         '1' = Bit is set       '0' =         bit 7       EN: NCO1 Enable         1 = NCO1 module       0 = NCO1 module         0 = NCO1 module       0 = NCO1 module         bit 6       Unimplemented:         bit 5       OUT: NCO1 Output         Displays the current       1 = NCO1 output s         bit 4       POL: NCO1 Polari         1 = NCO1 output s       0 = NCO1 output s         bit 3-1       Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                    |                  |                |                  |                  |              |  |  |  |
| '1' = Bit is set'0' =bit 7EN: NCO1 Enable<br>1 = NCO1 module<br>0 = NCO1 modulebit 6Unimplemented:<br>Displays the current<br>Displays the current<br>1 = NCO1 output so<br>0 = NCO1 output so<br>0 = NCO1 output so<br>0 = NCO1 output sobit 3-1Unimplemented:<br>Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | = Writable bit                                                                                     | ble bit          | U = Unimpler   | mented bit, read | l as '0'         |              |  |  |  |
| bit 7<br>EN: NCO1 Enable<br>1 = NCO1 module<br>0 = NCO1 module<br>bit 6<br>Unimplemented:<br>bit 5<br>OUT: NCO1 Output<br>Displays the current<br>bit 4<br>POL: NCO1 Polarit<br>1 = NCO1 output st<br>0 = NCO1 out | = Bit is unknown                                                                                   | unknown          | -n/n = Value a | at POR and BO    | R/Value at all o | other Resets |  |  |  |
| 1 = NCO1 module0 = NCO1 modulebit 6bit 5OUT: NCO1 OutputDisplays the currentbit 4POL: NCO1 Polari1 = NCO1 output so0 = NCO1 output so0 = NCO1 output sobit 3-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | = Bit is cleared                                                                                   | cleared          |                |                  |                  |              |  |  |  |
| 1 = NCO1 output s0 = NCO1 output sbit 3-1Unimplemented:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | le is enabled<br>le is disabled<br>l: Read as '0'<br>put bit<br>rent output value of th            | abled<br>as '0'  | ICO1 module.   |                  |                  |              |  |  |  |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | POL: NCO1 Polarity<br>1 = NCO1 output signal is inverted<br>0 = NCO1 output signal is not inverted |                  |                |                  |                  |              |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | : Read as '0'                                                                                      | <b>as</b> '0'    |                |                  |                  |              |  |  |  |
| 1 = NCO1 operate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | se Frequency Mode t<br>tes in Pulse Frequen<br>tes in Fixed Duty Cyc                               | ulse Frequency i |                | 2                |                  |              |  |  |  |

#### REGISTER 28-1: NCO1CON: NCO CONTROL REGISTER







| R/W-0                                                                                                                                                                                                                                                                                                                                  | R/W-0               | R/W-0               | R/W-0               | R/W-0                                   | R/W-0               | R/W-0                 | R/W-0                 |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------|---------------------|-----------------------------------------|---------------------|-----------------------|-----------------------|--|
| B5IE <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                    | B4IE <sup>(2)</sup> | B3IE <sup>(2)</sup> | B2IE <sup>(2)</sup> | B1IE <sup>(2)</sup>                     | B0IE <sup>(2)</sup> | RXB1IE <sup>(2)</sup> | RXB0IE <sup>(2)</sup> |  |
| bit 7                                                                                                                                                                                                                                                                                                                                  |                     |                     |                     |                                         |                     |                       | bit 0                 |  |
|                                                                                                                                                                                                                                                                                                                                        |                     |                     |                     |                                         |                     |                       |                       |  |
| Legend:                                                                                                                                                                                                                                                                                                                                |                     |                     |                     |                                         |                     |                       |                       |  |
| R = Readable                                                                                                                                                                                                                                                                                                                           | bit                 | W = Writable        | bit                 | U = Unimpler                            | mented bit, read    | as '0'                |                       |  |
| -n = Value at P                                                                                                                                                                                                                                                                                                                        | POR                 | '1' = Bit is set    |                     | '0' = Bit is cleared x = Bit is unknown |                     |                       |                       |  |
| bit 7-2 B<5:0>IE: Programmable Transmit/Receive Buffer 5-0 Interrupt Enable bits <sup>(2)</sup><br>1 = Interrupt is enabled<br>0 = Interrupt is disabled<br>bit 1-0 RXB<1:0>IE: Dedicated Receive Buffer 1-0 Interrupt Enable bits <sup>(2)</sup><br>1 = Interrupt is enabled<br>0 = Interrupt is enabled<br>0 = Interrupt is disabled |                     |                     |                     |                                         |                     |                       |                       |  |

### REGISTER 34-60: BIE0: BUFFER INTERRUPT ENABLE REGISTER 0<sup>(1)</sup>

Note 1: This register is available in Mode 1 and 2 only.

2: Either TXBnIE or RXBnIE, in the PIE5 register, must be set to get an interrupt.

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

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

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

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

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

| CLRWDT                                | Clear Watchdog Timer |                                                                                                                                     |      |                |  |  |  |
|---------------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|------|----------------|--|--|--|
| Syntax:                               | CLRWDT               | CLRWDT                                                                                                                              |      |                |  |  |  |
| Operands:                             | None                 |                                                                                                                                     |      |                |  |  |  |
| Operation:                            |                      |                                                                                                                                     |      |                |  |  |  |
| Status Affected:                      | TO, PD               |                                                                                                                                     |      |                |  |  |  |
| Encoding:                             | 0000                 | 0000                                                                                                                                | 0000 | 0100           |  |  |  |
| Description:                          | Watchdog             | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the post-<br>scaler of the WDT. Status bits, TO and<br>PD, are set. |      |                |  |  |  |
| Words:                                | 1                    |                                                                                                                                     |      |                |  |  |  |
| Cycles:                               | 1                    |                                                                                                                                     |      |                |  |  |  |
| Q Cycle Activity:                     |                      |                                                                                                                                     |      |                |  |  |  |
| Q1                                    | Q2                   | Q3                                                                                                                                  |      | Q4             |  |  |  |
| Decode                                | No<br>operation      | Proces<br>Data                                                                                                                      | -    | No<br>peration |  |  |  |
| Example: CLRWDT                       |                      |                                                                                                                                     |      |                |  |  |  |
| Before Instruction<br>WDT Counter = ? |                      |                                                                                                                                     |      |                |  |  |  |
| After Instructio<br>WDT Cou           |                      | 00h                                                                                                                                 |      |                |  |  |  |
|                                       |                      | 0011                                                                                                                                |      |                |  |  |  |

| COMF              | Complement f                                                                                                                                                                              |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:           | COMF f                                                                                                                                                                                    | COMF f {,d {,a}}                                                                                                                                                   |                                                                                                             |                                                                                                                                    |  |  |  |
| Operands:         | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1]                                                                                                                                                     | d ∈ [0,1]                                                                                                                                                          |                                                                                                             |                                                                                                                                    |  |  |  |
| Operation:        | $(\overline{f}) \rightarrow dest$                                                                                                                                                         |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
| Status Affected:  | N, Z                                                                                                                                                                                      |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
| Encoding:         | 0001                                                                                                                                                                                      | 11da                                                                                                                                                               | ffff                                                                                                        | ffff                                                                                                                               |  |  |  |
|                   | stored in W<br>stored back<br>If 'a' is '0', 1<br>If 'a' is '1', 1<br>GPR bank.<br>If 'a' is '0' a<br>set is enab<br>in Indexed<br>mode when<br>tion 42.2.3<br>Oriented In<br>eral Offset | /. If 'd' is ':<br>k in registe<br>the Acces<br>the BSR is<br>and the ex<br>led, this in<br>Literal Off<br>never $f \leq g$<br><b>"Byte-O</b><br><b>nstruction</b> | 1', the<br>er 'f' (d<br>s Bank<br>s used<br>tended<br>istructi<br>fset Ad<br>05 (5Fr<br>rientec<br>ns in li | efault).<br>to selected.<br>to select the<br>l instruction<br>on operates<br>dressing<br>n). See Sec-<br>t and Bit-<br>ndexed Lit- |  |  |  |
| Words:            | 1                                                                                                                                                                                         |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
| Cycles:           | 1                                                                                                                                                                                         |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
| Q Cycle Activity: |                                                                                                                                                                                           |                                                                                                                                                                    |                                                                                                             |                                                                                                                                    |  |  |  |
| Q1                | Q2                                                                                                                                                                                        | Q3                                                                                                                                                                 |                                                                                                             | Q4                                                                                                                                 |  |  |  |
|                   | Read                                                                                                                                                                                      | Proce                                                                                                                                                              | ss                                                                                                          | Write to                                                                                                                           |  |  |  |
| Decode            | register 'f'                                                                                                                                                                              | Data                                                                                                                                                               | 1                                                                                                           | destination                                                                                                                        |  |  |  |
| Decode            | register 'f'                                                                                                                                                                              |                                                                                                                                                                    | a), 0                                                                                                       | destination                                                                                                                        |  |  |  |

| Before Instru  | uction |     |
|----------------|--------|-----|
| REG            | =      | 13ł |
| After Instruct | tion   |     |

| =   | 13h      |
|-----|----------|
| ion |          |
| =   | 13h      |
| =   | ECh      |
|     | ion<br>= |





#### FIGURE 45-13: CAPTURE/COMPARE/PWM TIMINGS (CCP)



#### TABLE 45-20: CAPTURE/COMPARE/PWM REQUIREMENTS (CCP)

|              | Standard Operating Conditions (unless otherwise stated)Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |                      |                |                       |             |                  |       |                    |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------|----------------------|----------------|-----------------------|-------------|------------------|-------|--------------------|--|--|
| Param<br>No. | Sym.                                                                                                                 | Characteri           | stic           | Min.                  | Тур†        | Max.             | Units | Conditions         |  |  |
| CC01*        | TccL                                                                                                                 | CCPx Input Low Time  | No Prescaler   | 0.5Tcy + 20           | —           |                  | ns    | $\rangle$          |  |  |
|              |                                                                                                                      |                      | With Prescaler | 20                    | <u></u>     | À                | ns    |                    |  |  |
| CC02*        | TccH                                                                                                                 | CCPx Input High Time | No Prescaler   | 0.5Tcy + 20           | /-/         | 1                | ns    |                    |  |  |
|              |                                                                                                                      |                      | With Prescaler | 20/                   | $ \subset $ |                  | ns    |                    |  |  |
| CC03*        | TccP                                                                                                                 | CCPx Input Period    |                | <u>3Tcy + 40</u><br>N |             | $\triangleright$ | ns    | N = prescale value |  |  |

\* These parameters are characterized but not tested.

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

#### 47.1 Package Details

The following sections give the technical details of the packages.

#### 28-Lead Skinny Plastic Dual In-Line (SP) – 300 mil Body [SPDIP]

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



|                            | Units            |          |       |       |  |  |
|----------------------------|------------------|----------|-------|-------|--|--|
|                            | Dimension Limits | MIN      | NOM   | MAX   |  |  |
| Number of Pins             | N                |          | •     |       |  |  |
| Pitch                      | е                | .100 BSC |       |       |  |  |
| Top to Seating Plane       | А                | -        | -     | .200  |  |  |
| Molded Package Thickness   | A2               | .120     | .135  | .150  |  |  |
| Base to Seating Plane      | A1               | .015     | -     | _     |  |  |
| Shoulder to Shoulder Width | E                | .290     | .310  | .335  |  |  |
| Molded Package Width       | E1               | .240     | .285  | .295  |  |  |
| Overall Length             | D                | 1.345    | 1.365 | 1.400 |  |  |
| Tip to Seating Plane       | L                | .110     | .130  | .150  |  |  |
| Lead Thickness             | С                | .008     | .010  | .015  |  |  |
| Upper Lead Width           | b1               | .040     | .050  | .070  |  |  |
| Lower Lead Width           | b                | .014     | .018  | .022  |  |  |
| Overall Row Spacing §      | eB               | _        | -     | .430  |  |  |

#### Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. § Significant Characteristic.
- 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side.
- 4. Dimensioning and tolerancing per ASME Y14.5M.

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

Microchip Technology Drawing C04-070B



Microchip Technology Drawing C04-0209 Rev C Sheet 1 of 2

#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEEL0Q® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

### QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, AnyRate, AVR, AVR logo, AVR Freaks, BeaconThings, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KEELOQ, KEELOQ logo, Kleer, LANCheck, LINK MD, maXStylus, maXTouch, MediaLB, megaAVR, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, Prochip Designer, QTouch, RightTouch, SAM-BA, SpyNIC, SST, SST Logo, SuperFlash, tinyAVR, UNI/O, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, EtherSynch, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and Quiet-Wire are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, CodeGuard, CryptoAuthentication, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, Mindi, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, QMatrix, RightTouch logo, REAL ICE, Ripple Blocker, SAM-ICE, Serial Quad I/O, SMART-I.S., SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

 $\ensuremath{\mathsf{SQTP}}$  is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2017, Microchip Technology Incorporated, All Rights Reserved. ISBN: 978-1-5224-2047-7