

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

E-XF

| Product Status             | Obsolete                                                                     |
|----------------------------|------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 20MHz                                                                        |
| Connectivity               | I <sup>2</sup> C, SPI                                                        |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                        |
| Number of I/O              | 16                                                                           |
| Program Memory Size        | 3.5KB (2K x 14)                                                              |
| Program Memory Type        | FLASH                                                                        |
| EEPROM Size                | 256 x 8                                                                      |
| RAM Size                   | 256 x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                    |
| Data Converters            | A/D 5x10b                                                                    |
| Oscillator Type            | Internal                                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                               |
| Supplier Device Package    | 18-SOIC                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f819t-i-sotsl |
|                            |                                                                              |

Email: info@E-XFL.COM

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

| Pin Name                                            | PDIP/<br>SOIC<br>Pin# | SSOP<br>Pin# | QFN<br>Pin# | I/O/P<br>Type      | Buffer<br>Type                       | Description                                                                                                                                              |
|-----------------------------------------------------|-----------------------|--------------|-------------|--------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     |                       |              |             |                    |                                      | PORTB is a bidirectional I/O port. PORTB can be<br>software programmed for internal weak pull-up or<br>all inputs.                                       |
| RB0/INT<br>RB0<br>INT                               | 6                     | 7            | 7           | I/O<br>I           | TTL<br>ST <sup>(1)</sup>             | Bidirectional I/O pin.<br>External interrupt pin.                                                                                                        |
| RB1/SDI/SDA<br>RB1<br>SDI<br>SDA                    | 7                     | 8            | 8           | I/O<br>I<br>I/O    | TTL<br>ST<br>ST                      | Bidirectional I/O pin.<br>SPI data in.<br>I <sup>2</sup> C™ data.                                                                                        |
| RB2/SDO/CCP1<br>RB2<br>SDO<br>CCP1                  | 8                     | 9            | 9           | I/O<br>O<br>I/O    | TTL<br>ST<br>ST                      | Bidirectional I/O pin.<br>SPI data out.<br>Capture input, Compare output, PWM output.                                                                    |
| RB3/CCP1/PGM<br>RB3<br>CCP1<br>PGM                  | 9                     | 10           | 10          | I/O<br>I/O<br>I    | TTL<br>ST<br>ST                      | Bidirectional I/O pin.<br>Capture input, Compare output, PWM output.<br>Low-Voltage ICSP™ Programming enable pir                                         |
| RB4/SCK/SCL<br>RB4<br>SCK<br>SCL                    | 10                    | 11           | 12          | I/O<br>I/O<br>I    | TTL<br>ST<br>ST                      | Bidirectional I/O pin. Interrupt-on-change pin.<br>Synchronous serial clock input/output for SPI<br>Synchronous serial clock input for I <sup>2</sup> C. |
| RB5/SS<br>RB5<br>SS                                 | 11                    | 12           | 13          | I/O<br>I           | TTL<br>TTL                           | Bidirectional I/O pin. Interrupt-on-change pin.<br>Slave select for SPI in Slave mode.                                                                   |
| RB6/T1OSO/T1CKI/PGC<br>RB6<br>T1OSO<br>T1CKI<br>PGC | 12                    | 13           | 15          | I/O<br>O<br>I<br>I | TTL<br>ST<br>ST<br>ST <sup>(2)</sup> | Interrupt-on-change pin.<br>Timer1 Oscillator output.<br>Timer1 clock input.<br>In-circuit debugger and ICSP programming<br>clock pin.                   |
| RB7/T1OSI/PGD<br>RB7<br>T1OSI<br>PGD                | 13                    | 14           | 16          | I/O<br>I<br>I      | TTL<br>ST<br>ST <sup>(2)</sup>       | Interrupt-on-change pin.<br>Timer1 oscillator input.<br>In-circuit debugger and ICSP programming<br>data pin.                                            |
| Vss                                                 | 5                     | 5, 6         | 3, 5        | Р                  | _                                    | Ground reference for logic and I/O pins.                                                                                                                 |
| Vdd                                                 | 14                    | 15, 16       | 17, 19      | Р                  | -                                    | Positive supply for logic and I/O pins.                                                                                                                  |

# TABLE 1-2: PIC16F818/819 PINOUT DESCRIPTIONS (CONTINUED)

**Note 1:** This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.

3: This buffer is a Schmitt Trigger input when configured in RC Oscillator mode and a CMOS input otherwise.

# 2.0 MEMORY ORGANIZATION

There are two memory blocks in the PIC16F818/819. These are the program memory and the data memory. Each block has its own bus, so access to each block can occur during the same oscillator cycle.

The data memory can be further broken down into the general purpose RAM and the Special Function Registers (SFRs). The operation of the SFRs that control the "core" are described here. The SFRs used to control the peripheral modules are described in the section discussing each individual peripheral module.

The data memory area also contains the data EEPROM memory. This memory is not directly mapped into the data memory but is indirectly mapped. That is, an indirect address pointer specifies the address of the data EEPROM memory to read/write. The PIC16F818 device's 128 bytes of data EEPROM memory have the address range of 00h-7Fh and the PIC16F819 device's 256 bytes of data EEPROM memory have the address range of 00h-FFh. More details on the EEPROM memory can be found in Section 3.0 "Data EEPROM and Flash Program Memory".

Additional information on device memory may be found in the *"PIC<sup>®</sup> Mid-Range Reference Manual"* (DS33023).



# 2.1 **Program Memory Organization**

The PIC16F818/819 devices have a 13-bit program counter capable of addressing an 8K x 14 program memory space. For the PIC16F818, the first 1K x 14 (0000h-03FFh) is physically implemented (see Figure 2-1). For the PIC16F819, the first 2K x 14 is located at 0000h-07FFh (see Figure 2-2). Accessing a location above the physically implemented address will cause a wraparound. For example, the same instruction will be accessed at locations 020h, 420h, 820h, C20h, 1020h, 1420h, 1820h and 1C20h.

The Reset vector is at 0000h and the interrupt vector is at 0004h.





# 2.2 Data Memory Organization

The data memory is partitioned into multiple banks that contain the General Purpose Registers and the Special Function Registers. Bits RP1 (Status<6>) and RP0 (Status<5>) are the bank select bits.

| RP1:RP0 | Bank |
|---------|------|
| 00      | 0    |
| 01      | 1    |
| 10      | 2    |
| 11      | 3    |

Each bank extends up to 7Fh (128 bytes). The lower locations of each bank are reserved for the Special Function Registers. Above the Special Function Registers are the General Purpose Registers, implemented as static RAM. All implemented banks contain SFRs. Some "high use" SFRs from one bank may be mirrored in another bank for code reduction and quicker access (e.g., the Status register is in Banks 0-3).

| Note: | EEPROM data memory description can be found in Section 3.0 "Data EEPROM and |  |  |  |  |  |  |
|-------|-----------------------------------------------------------------------------|--|--|--|--|--|--|
|       | Flash Program Memory" of this data sheet.                                   |  |  |  |  |  |  |

#### 2.2.1 GENERAL PURPOSE REGISTER FILE

The register file can be accessed either directly or indirectly through the File Select Register, FSR.

```
FIGURE 2-3:
```

## PIC16F818 REGISTER FILE MAP

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ddress      |                                | Address     | [                   | Address      |                                   | ddre       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------------|-------------|---------------------|--------------|-----------------------------------|------------|
| Indirect addr.(*)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00h         | Indirect addr.(*)              | 80h         | Indirect addr.(*)   | 100h         | Indirect addr.(*)                 | 180        |
| TMR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 01h         | OPTION_REG                     | 81h         | TMR0                | 101h         | OPTION_REG                        | 181        |
| PCL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 02h         | PCL                            | 82h         | PCL                 | 102h         | PCL                               | 182        |
| STATUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 03h         | STATUS                         | 83h         | STATUS              | 103h         | STATUS                            | 183        |
| FSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 04h         | FSR                            | 84h         | FSR                 | 104h         | FSR                               | 184        |
| PORTA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 05h         | TRISA                          | 85h         |                     | 105h         |                                   | 185        |
| PORTB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 06h         | TRISB                          | 86h         | PORTB               | 106h         | TRISB                             | 186        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 07h         |                                | 87h         |                     | 107h         |                                   | 187        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 08h         |                                | 88h         |                     | 108h<br>109h |                                   | 188        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 09h<br>0Ah  |                                | 89h         | PCLATH              | 1091<br>10Ah |                                   | 189        |
| PCLATH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0An<br>0Bh  | PCLATH                         | 8Ah         | INTCON              | 10An<br>10Bh | PCLATH                            | 18/        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0Бh<br>0Ch  |                                | 8Bh         |                     | 10Dh         |                                   | 18E        |
| PIR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             | PIE1<br>PIE2                   | 8Ch         | EEDATA<br>EEADR     | 10Ch<br>10Dh | EECON1                            | 180        |
| PIR2<br>TMR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0Dh<br>0Eh  |                                | 8Dh         |                     | 10Dh<br>10Eh | EECON2<br>Reserved <sup>(1)</sup> | 18[        |
| TMR1L<br>TMR1H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0En<br>0Fh  | PCON<br>OSCCON                 | 8Eh<br>8Fh  | EEDATH<br>EEADRH    | 10En<br>10Fh | Reserved <sup>(1)</sup>           | 18E<br>18F |
| TICON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 10h         | OSCTUNE                        |             | EEADKI              | 110h         | Reserved                          | 186        |
| TMR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1011<br>11h | USCIDINE                       | 90h<br>91h  |                     | 11011        |                                   | 190        |
| T2CON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 12h         | PR2                            | 91h<br>92h  |                     |              |                                   |            |
| SSPBUF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 13h         | SSPADD                         | 9211<br>93h |                     |              |                                   |            |
| SSPCON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 14h         | SSPSTAT                        | 931<br>94h  |                     |              |                                   |            |
| CCPR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 15h         |                                | 9411<br>95h |                     |              |                                   |            |
| CCPR1H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 16h         |                                | 96h         |                     |              |                                   |            |
| CCP1CON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 17h         |                                | 97h         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 18h         |                                | 98h         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 19h         |                                | 99h         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1Ah         |                                | 9Ah         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1Bh         |                                | 9Bh         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1Ch         |                                | 9Ch         |                     |              |                                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1Dh         |                                | 9Dh         |                     |              |                                   |            |
| ADRESH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1Eh         | ADRESL                         | 9Eh         |                     |              |                                   |            |
| ADCON0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1Fh         | ADCON1                         | 9Fh         |                     | 11Fh         |                                   | 19F        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 20h         | General<br>Purpose<br>Register | A0h         |                     | 120h         |                                   | 1A)        |
| General                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             | 32 Bytes                       | BFh         |                     |              |                                   |            |
| Purpose<br>Register<br>96 Bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             | Accesses<br>40h-7Fh            | C0h         | Accesses<br>20h-7Fh |              | Accesses<br>20h-7Fh               |            |
| Bank 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7Fh         | Bank 1                         | FFh         | Bank 2              | 17Fh         | Bank 3                            | 1FF        |
| <ul> <li>Dank 1</li> <li>Dank 2</li> <li>Dank 3</li> <li>Dank 3</li> <li>Dank 4</li> <li>Dank 4</li> <li>Dank 5</li> <li>Dank 5</li></ul> |             |                                |             |                     |              |                                   |            |

### 2.2.2.5 PIR1 Register

This register contains the individual flag bits for the peripheral interrupts.

Note: Interrupt flag bits are set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the Global Interrupt Enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt.

### REGISTER 2-5: PIR1: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 1 (ADDRESS 0Ch)

|   | U-0   | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|---|-------|-------|-----|-----|-------|--------|--------|--------|
|   | —     | ADIF  | —   | _   | SSPIF | CCP1IF | TMR2IF | TMR1IF |
| - | bit 7 |       |     |     |       |        |        | bit 0  |

| bit 7   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                      |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | ADIF: A/D Converter Interrupt Flag bit                                                                                                                                                                                                                                                          |
|         | 1 = An A/D conversion completed                                                                                                                                                                                                                                                                 |
|         | <ul> <li>The A/D conversion is not complete</li> </ul>                                                                                                                                                                                                                                          |
| bit 5-4 | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                      |
| bit 3   | SSPIF: Synchronous Serial Port (SSP) Interrupt Flag bit                                                                                                                                                                                                                                         |
|         | <ul> <li>1 = The SSP interrupt condition has occurred and must be cleared in software before returning from the Interrupt Service Routine. The conditions that will set this bit are a transmission/ reception has taken place.</li> <li>0 = No SSP interrupt condition has occurred</li> </ul> |
| bit 2   | CCP1IF: CCP1 Interrupt Flag bit                                                                                                                                                                                                                                                                 |
|         | <u>Capture mode:</u><br>1 = A TMR1 register capture occurred (must be cleared in software)<br>0 = No TMR1 register capture occurred                                                                                                                                                             |
|         | <u>Compare mode:</u><br>1 = A TMR1 register compare match occurred (must be cleared in software)<br>0 = No TMR1 register compare match occurred                                                                                                                                                 |
|         | <u>PWM mode:</u><br>Unused in this mode.                                                                                                                                                                                                                                                        |
| bit 1   | TMR2IF: TMR2 to PR2 Match Interrupt Flag bit                                                                                                                                                                                                                                                    |
|         | <ul> <li>1 = TMR2 to PR2 match occurred (must be cleared in software)</li> <li>0 = No TMR2 to PR2 match occurred</li> </ul>                                                                                                                                                                     |
| bit 0   | TMR1IF: TMR1 Overflow Interrupt Flag bit                                                                                                                                                                                                                                                        |
|         | 1 = TMR1 register overflowed (must be cleared in software)                                                                                                                                                                                                                                      |
|         | 0 = TMR1 register did not overflow                                                                                                                                                                                                                                                              |
|         |                                                                                                                                                                                                                                                                                                 |
|         | Legend:                                                                                                                                                                                                                                                                                         |

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

| REGISTER 3-1:                                                                                       | EECON1:                                                                                                                                                                                                          | EEPROM                                   | ACCESS C        | ONTROL       | REGISTER      | 1 (ADDRI      | ESS 18Ch)     |           |
|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------|--------------|---------------|---------------|---------------|-----------|
|                                                                                                     | R/W-x                                                                                                                                                                                                            | U-0                                      | U-0             | R/W-x        | R/W-x         | R/W-0         | R/S-0         | R/S-0     |
|                                                                                                     | EEPGD                                                                                                                                                                                                            |                                          | _               | FREE         | WRERR         | WREN          | WR            | RD        |
|                                                                                                     | bit 7                                                                                                                                                                                                            |                                          |                 |              |               |               |               | bit 0     |
| bit 7                                                                                               | EEPGD: Pr                                                                                                                                                                                                        | ogram/Data                               | EEPROM          | Select bit   |               |               |               |           |
|                                                                                                     | 0 = Access                                                                                                                                                                                                       | es program<br>es data mei<br>fter a POR; | mory            | not be chang | ged while a v | write operati | on is in prog | jress.    |
| bit 6-5                                                                                             | Unimplem                                                                                                                                                                                                         | ented: Read                              | <b>d as</b> '0' |              |               |               |               |           |
| bit 4                                                                                               | FREE: EEF                                                                                                                                                                                                        | PROM Force                               | ed Row Eras     | se bit       |               |               |               |           |
|                                                                                                     | 1 = Erase tl<br>0 = Perforn                                                                                                                                                                                      |                                          | memory row      | addressed    | by EEADRH     | I:EEADR on    | the next WF   | R command |
| bit 3                                                                                               | WRERR: E                                                                                                                                                                                                         | EPROM Er                                 | ror Flag bit    |              |               |               |               |           |
|                                                                                                     | <ul> <li>1 = A write operation is prematurely terminated (any MCLR or any WDT Reset during normal operation)</li> <li>0 = The write operation completed</li> </ul>                                               |                                          |                 |              |               |               |               |           |
| bit 2                                                                                               | WREN: EE                                                                                                                                                                                                         | PROM Writ                                | e Enable bit    |              |               |               |               |           |
|                                                                                                     | <ul> <li>1 = Allows write cycles</li> <li>0 = Inhibits write to the EEPROM</li> </ul>                                                                                                                            |                                          |                 |              |               |               |               |           |
| bit 1                                                                                               | WR: Write                                                                                                                                                                                                        | Control bit                              |                 |              |               |               |               |           |
|                                                                                                     | <ul> <li>1 = Initiates a write cycle. The bit is cleared by hardware once write is complete. The WR bit can only be set (not cleared) in software.</li> <li>0 = Write cycle to the EEPROM is complete</li> </ul> |                                          |                 |              |               |               |               |           |
| bit 0                                                                                               | RD: Read                                                                                                                                                                                                         | Control bit                              |                 |              |               |               |               |           |
| 1 = Initiates an EEPROM read, RD is cleared in hardware. The RD bit can or<br>cleared) in software. |                                                                                                                                                                                                                  |                                          |                 |              |               | bit can only  | be set (not   |           |
|                                                                                                     | 0 = Does r                                                                                                                                                                                                       | not initiate a                           | n EEPROM        | read         |               |               |               |           |
|                                                                                                     | Legend:                                                                                                                                                                                                          |                                          |                 |              |               |               |               | ]         |

| Legend:           |                  |                      |                                    |
|-------------------|------------------|----------------------|------------------------------------|
| R = Readable bit  | W = Writable bit | S = Set only         | U = Unimplemented bit, read as '0' |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown                 |

An example of the complete four-word write sequence is shown in Example 3-5. The initial address is loaded into the EEADRH:EEADR register pair; the four words of data are loaded using indirect addressing, assuming that a row erase sequence has already been performed.

#### EXAMPLE 3-5: WRITING TO FLASH PROGRAM MEMORY

; This write routine assumes the following: ; 1. The 32 words in the erase block have already been erased. ; 2. A valid starting address (the least significant bits = '00') is loaded into EEADRH:EEADR ; 3. This example is starting at 0x100, this is an application dependent setting. ; 4. The 8 bytes (4 words) of data are loaded, starting at an address in RAM called ARRAY. ; 5. This is an example only, location of data to program is application dependent. ; 6. word\_block is located in data memory. BANKSEL EECON1 ;prepare for WRITE procedure EECON1, EEPGD BSF ; point to program memory EECON1, WREN BSF ;allow write cycles BCF EECON1, FREE ;perform write only BANKSEL word block MOVLW .4 MOVWF word block ;prepare for 4 words to be written BANKSEL EEADRH ;Start writing at 0x100 MOVLW 0x01 MOVWF ;load HIGH address EEADRH MOVLW 0x00 MOVWF EEADR ;load LOW address BANKSEL ARRAY MOVLW ARRAY ; initialize FSR to start of data MOVWF FSR LOOP BANKSEL EEDATA MOVF INDF, W ; indirectly load EEDATA MOVWF EEDATA INCF FSR. F ; increment data pointer MOVF INDF, W ; indirectly load EEDATH MOVWF EEDATH INCE FSR, F ; increment data pointer BANKSEL EECON1 ;required sequence MOVLW 0x55 MOVWF EECON2 MOVIW 0xAA ner MOVWF EECON2 BSF EECON1, WR ;set WR bit to begin write NOP ; instructions here are ignored as processor NOP BANKSEL EEADR INCF EEADR, f ;load next word address BANKSEL word\_block DECFSZ word\_block, f ; have 4 words been written? GOTO loop ;NO, continue with writing BANKSEL EECON1 BCF EECON1, WREN ;YES, 4 words complete, disable writes BSF INTCON, GIE ;enable interrupts

FIGURE 5-1: BLOCK DIAGRAM OF RA0/AN0:RA1/AN1 PINS



FIGURE 5-2:

#### BLOCK DIAGRAM OF RA3/AN3/VREF+ PIN



# FIGURE 5-3: BLOCK DIAGRAM OF RA2/AN2/VREF- PIN



FIGURE 5-4:

#### BLOCK DIAGRAM OF RA4/AN4/T0CKI PIN



| Name                        | Bit#  | Buffer                | Function                                                                                                                                                                       |
|-----------------------------|-------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT                     | bit 0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input.<br>Internal software programmable weak pull-up.                                                                                  |
| RB1/SDI/SDA                 | bit 1 | TTL/ST <sup>(5)</sup> | Input/output pin, SPI data input pin or I <sup>2</sup> C™ data I/O pin.<br>Internal software programmable weak pull-up.                                                        |
| RB2/SDO/CCP1                | bit 2 | TTL/ST <sup>(4)</sup> | Input/output pin, SPI data output pin or<br>Capture input/Compare output/PWM output pin.<br>Internal software programmable weak pull-up.                                       |
| RB3/CCP1/PGM <sup>(3)</sup> | bit 3 | TTL/ST <sup>(2)</sup> | Input/output pin, Capture input/Compare output/PWM output pin<br>or programming in LVP mode. Internal software programmable<br>weak pull-up.                                   |
| RB4/SCK/SCL                 | bit 4 | TTL/ST <sup>(5)</sup> | Input/output pin or SPI and I <sup>2</sup> C clock pin (with interrupt-on-change).<br>Internal software programmable weak pull-up.                                             |
| RB5/SS                      | bit 5 | TTL                   | Input/output pin or SPI slave select pin (with interrupt-on-change).<br>Internal software programmable weak pull-up.                                                           |
| RB6/T1OSO/T1CKI/<br>PGC     | bit 6 | TTL/ST <sup>(2)</sup> | Input/output pin, Timer1 oscillator output pin, Timer1 clock input pin or serial programming clock (with interrupt-on-change).<br>Internal software programmable weak pull-up. |
| RB7/T1OSI/PGD               | bit 7 | TTL/ST <sup>(2)</sup> | Input/output pin, Timer1 oscillator input pin or serial programming data<br>(with interrupt-on-change).<br>Internal software programmable weak pull-up.                        |

**Legend:** TTL = TTL input, ST = Schmitt Trigger input

Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.

3: Low-Voltage ICSP<sup>™</sup> Programming (LVP) is enabled by default which disables the RB3 I/O function. LVP must be disabled to enable RB3 as an I/O pin and allow maximum compatibility to the other 18-pin mid-range devices.

- 4: This buffer is a Schmitt Trigger input when configured for CCP or SSP mode.
- **5:** This buffer is a Schmitt Trigger input when configured for SPI or I<sup>2</sup>C mode.

| TABLE 5-4: | SUMMARY OF REGISTERS ASSOCIATED WITH PORTB |
|------------|--------------------------------------------|
|------------|--------------------------------------------|

| Address   | Name       | Bit 7 | Bit 6                         | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|-----------|------------|-------|-------------------------------|-------|-------|-------|-------|-------|-------|----------------------|---------------------------------|
| 06h, 106h | PORTB      | RB7   | RB6                           | RB5   | RB4   | RB3   | RB2   | RB1   | RB0   | xxxx xxxx            | uuuu uuuu                       |
| 86h, 186h | TRISB      | PORTB | PORTB Data Direction Register |       |       |       |       |       |       | 1111 1111            | 1111 1111                       |
| 81h, 181h | OPTION_REG | RBPU  | INTEDG                        | TOCS  | T0SE  | PSA   | PS2   | PS1   | PS0   | 1111 1111            | 1111 1111                       |

**Legend:** x = unknown, u = unchanged. Shaded cells are not used by PORTB.

#### EXAMPLE 6-1: CHANGING THE PRESCALER ASSIGNMENT FROM TIMER0 TO WDT

| BANKSEL | OPTION_REG  | ; | Select Bank of OPTION_REG                 |
|---------|-------------|---|-------------------------------------------|
| MOVLW   | b'xx0x0xxx' | ; | Select clock source and prescale value of |
| MOVWF   | OPTION_REG  | ; | other than 1:1                            |
| BANKSEL | TMR0        | ; | Select Bank of TMR0                       |
| CLRF    | TMR0        | ; | Clear TMR0 and prescaler                  |
| BANKSEL | OPTION_REG  | ; | Select Bank of OPTION_REG                 |
| MOVLW   | b'xxxx1xxx' | ; | Select WDT, do not change prescale value  |
| MOVWF   | OPTION_REG  |   |                                           |
| CLRWDT  |             | ; | Clears WDT and prescaler                  |
| MOVLW   | b'xxxx1xxx' | ; | Select new prescale value and WDT         |
| MOVWF   | OPTION_REG  |   |                                           |
|         |             |   |                                           |

#### EXAMPLE 6-2: CHANGING THE PRESCALER ASSIGNMENT FROM WDT TO TIMER0

| CLRWDT  |             | ; | Clear WDT and prescaler   |
|---------|-------------|---|---------------------------|
| BANKSEL | OPTION_REG  | ; | Select Bank of OPTION_REG |
| MOVLW   | b'xxxx0xxx' | ; | Select TMR0, new prescale |
| MOVWF   | OPTION_REG  | ; | value and clock source    |
|         |             |   |                           |

### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| Address               | Name       | Bit 7     | Bit 6       | Bit 5  | Bit 4 | Bit 3 | Bit 2  | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|-----------------------|------------|-----------|-------------|--------|-------|-------|--------|-------|-------|----------------------|---------------------------------|
| 01h,101h              | TMR0       | Timer0 Mo | odule Regis | ster   |       |       |        |       |       | xxxx xxxx            | uuuu uuuu                       |
| 0Bh,8Bh,<br>10Bh,18Bh | INTCON     | GIE       | PEIE        | TMR0IE | INTE  | RBIE  | TMR0IF | INTF  | RBIF  | 0000 000x            | 0000 000u                       |
| 81h,181h              | OPTION_REG | RBPU      | INTEDG      | TOCS   | T0SE  | PSA   | PS2    | PS1   | PS0   | 1111 1111            | 1111 1111                       |

Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by Timer0.

# 7.6 Timer1 Oscillator

A crystal oscillator circuit is built-in between pins T1OSI (input) and T1OSO (amplifier output). It is enabled by setting control bit, T1OSCEN (T1CON<3>). The oscillator is a low-power oscillator, rated up to 32.768 kHz. It will continue to run during Sleep. It is primarily intended for a 32 kHz crystal. The circuit for a typical LP oscillator is shown in Figure 7-3. Table 7-1 shows the capacitor selection for the Timer1 oscillator.

The user must provide a software time delay to ensure proper oscillator start-up.

Note: The Timer1 oscillator shares the T1OSI and T1OSO pins with the PGD and PGC pins used for programming and debugging.

When using the Timer1 oscillator, In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) may not function correctly (high-voltage or lowvoltage) or the In-Circuit Debugger (ICD) may not communicate with the controller. As a result of using either ICSP or ICD, the Timer1 crystal may be damaged.

If ICSP or ICD operations are required, the crystal should be disconnected from the circuit (disconnect either lead) or installed after programming. The oscillator loading capacitors may remain in-circuit during ICSP or ICD operation.

#### FIGURE 7-3: EXTERNAL COMPONENTS FOR THE TIMER1 LP OSCILLATOR



#### TABLE 7-1: CAPACITOR SELECTION FOR THE TIMER1 OSCILLATOR

| Osc Type | Freq   | C1    | C2    |  |  |
|----------|--------|-------|-------|--|--|
| LP       | 32 kHz | 33 pF | 33 pF |  |  |

- **Note 1:** Microchip suggests this value as a starting point in validating the oscillator circuit.
  - 2: Higher capacitance increases the stability of the oscillator but also increases the start-up time.
  - 3: Since each resonator/crystal has its own characteristics, the user should consult the resonator/crystal manufacturer for appropriate values of external components.
  - 4: Capacitor values are for design guidance only.

# 7.7 Timer1 Oscillator Layout Considerations

The Timer1 oscillator circuit draws very little power during operation. Due to the low-power nature of the oscillator, it may also be sensitive to rapidly changing signals in close proximity.

The oscillator circuit, shown in Figure 7-3, should be located as close as possible to the microcontroller. There should be no circuits passing within the oscillator circuit boundaries other than VSS or VDD.

If a high-speed circuit must be located near the oscillator, a grounded guard ring around the oscillator circuit, as shown in Figure 7-4, may be helpful when used on a single-sided PCB or in addition to a ground plane.



| RTCinit | BANKSEL<br>MOVLW<br>MOVWF<br>CLRF<br>MOVLW | TMR1H<br>0x80<br>TMR1H<br>TMR1L<br>b'00001111' | ; Preload TMR1 register pair<br>; for 1 second overflow<br>; Configure for external clock, |
|---------|--------------------------------------------|------------------------------------------------|--------------------------------------------------------------------------------------------|
|         | MOVWF                                      | TICON                                          | ; Asynchronous operation, external oscillator                                              |
|         | CLRF<br>CLRF                               | secs<br>mins                                   | ; Initialize timekeeping registers                                                         |
|         | MOVLW                                      | mins<br>.12                                    |                                                                                            |
|         | MOVLW                                      | .12<br>hours                                   |                                                                                            |
|         | BANKSEL                                    | PIE1                                           |                                                                                            |
|         | BSF                                        |                                                | ; Enable Timer1 interrupt                                                                  |
|         | RETURN                                     | ,                                              | ,                                                                                          |
| RTCisr  | BANKSEL                                    | TMR1H                                          |                                                                                            |
|         | BSF                                        | TMR1H, 7                                       | ; Preload for 1 sec overflow                                                               |
|         | BCF                                        | PIR1, TMR1IF                                   | ; Clear interrupt flag                                                                     |
|         | INCF                                       | secs, F                                        | ; Increment seconds                                                                        |
|         | MOVF                                       | secs, w                                        |                                                                                            |
|         | SUBLW                                      | .60                                            |                                                                                            |
|         | BTFSS                                      | STATUS, Z                                      | ; 60 seconds elapsed?                                                                      |
|         | RETURN                                     |                                                | ; No, done                                                                                 |
|         | CLRF                                       | seconds                                        | ; Clear seconds                                                                            |
|         | INCF<br>MOVF                               | mins, f<br>mins, w                             | ; Increment minutes                                                                        |
|         | SUBLW                                      | .60                                            |                                                                                            |
|         | BTFSS                                      | STATUS, Z                                      | ; 60 seconds elapsed?                                                                      |
|         | RETURN                                     | 511105, 2                                      | ; No, done                                                                                 |
|         | CLRF                                       | mins                                           | ; Clear minutes                                                                            |
|         | INCF                                       | hours, f                                       | ; Increment hours                                                                          |
|         | MOVF                                       | hours, w                                       |                                                                                            |
|         | SUBLW                                      | .24                                            |                                                                                            |
|         | BTFSS                                      | STATUS, Z                                      | ; 24 hours elapsed?                                                                        |
|         | RETURN                                     |                                                | ; No, done                                                                                 |
|         | CLRF                                       | hours                                          | ; Clear hours                                                                              |
|         | RETURN                                     |                                                | ; Done                                                                                     |

### TABLE 7-2: REGISTERS ASSOCIATED WITH TIMER1 AS A TIMER/COUNTER

| Address               | Name   | Bit 7   | Bit 6                                                                                         | Bit 5         | Bit 4        | Bit 3         | Bit 2       | Bit 1    | Bit 0  | Valu<br>POR, |      | all c | e on<br>other<br>sets |
|-----------------------|--------|---------|-----------------------------------------------------------------------------------------------|---------------|--------------|---------------|-------------|----------|--------|--------------|------|-------|-----------------------|
| 0Bh,8Bh,<br>10Bh,18Bh | INTCON | GIE     | PEIE                                                                                          | TMR0IE        | INTE         | RBIE          | TMR0IF      | INTF     | RBIF   | 0000         | 000x | 0000  | 000u                  |
| 0Ch                   | PIR1   | _       | ADIF                                                                                          | _             | _            | SSPIF         | CCP1IF      | TMR2IF   | TMR1IF | - 0          | 0000 | - 0   | 0000                  |
| 8Ch                   | PIE1   | _       | ADIE                                                                                          | _             | _            | SSPIE         | CCP1IE      | TMR2IE   | TMR1IE | - 0          | 0000 | - 0   | 0000                  |
| 0Eh                   | TMR1L  | Holding | g Registe                                                                                     | er for the Le | ast Signific | ant Byte of t | he 16-bit T | MR1 Regi | ster   | xxxx         | xxxx | uuuu  | uuuu                  |
| 0Fh                   | TMR1H  | Holding | olding Register for the Most Significant Byte of the 16-bit TMR1 Register xxxx xxxx uuuu uuuu |               |              |               |             |          |        |              |      |       |                       |
| 10h                   | T1CON  | _       | _                                                                                             | T1CKPS1       | T1CKPS0      | T1OSCEN       | T1SYNC      | TMR1CS   | TMR10N | 00           | 0000 | uu    | uuuu                  |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Timer1 module.

|       | R/W-0                                                                                                                                                        | R/W-0                                                                                                                                           | R-0                       | R-0           | R-0          | R-0       | R-0        | R-0   |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------------|--------------|-----------|------------|-------|--|--|--|--|
|       | SMP                                                                                                                                                          | CKE                                                                                                                                             | D/Ā                       | Р             | S            | R/W       | UA         | BF    |  |  |  |  |
|       | bit 7                                                                                                                                                        |                                                                                                                                                 |                           |               |              |           |            | bit 0 |  |  |  |  |
| bit 7 |                                                                                                                                                              | Data Input Sa                                                                                                                                   | mple Phas                 | e bit         |              |           |            |       |  |  |  |  |
|       | <u>SPI Master mode:</u>                                                                                                                                      |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | 0 = Input da                                                                                                                                                 | <ul> <li>1 = Input data sampled at end of data output time</li> <li>0 = Input data sampled at middle of data output time (Microwire)</li> </ul> |                           |               |              |           |            |       |  |  |  |  |
|       | <u>SPI Slave mode:</u><br>This bit must be cleared when SPI is used in Slave mode.                                                                           |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | I his bit mu<br>I <sup>2</sup> C mode:                                                                                                                       | st de cleared                                                                                                                                   | when SPI                  | is used in Si | ave mode.    |           |            |       |  |  |  |  |
|       |                                                                                                                                                              | st be maintaiı                                                                                                                                  | ned clear.                |               |              |           |            |       |  |  |  |  |
| bit 6 | CKE: SPI (                                                                                                                                                   | Clock Edge S                                                                                                                                    | elect bit                 |               |              |           |            |       |  |  |  |  |
|       |                                                                                                                                                              | nit occurs on nit occurs on                                                                                                                     |                           |               |              |           |            |       |  |  |  |  |
|       | Note:                                                                                                                                                        | Polarity of cl                                                                                                                                  | ock state is              | set by the C  | KP bit (SSF  | 2CON<4>). |            |       |  |  |  |  |
|       | <u>I<sup>2</sup>C mode:</u><br>This bit mu                                                                                                                   | st be maintair                                                                                                                                  | ned clear.                |               |              |           |            |       |  |  |  |  |
| bit 5 | D/A: Data/Address bit (l <sup>2</sup> C mode only)                                                                                                           |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | In I <sup>2</sup> C Slave mode:                                                                                                                              |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | <ul><li>1 = Indicates that the last byte received was data</li><li>0 = Indicates that the last byte received was address</li></ul>                           |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
| bit 4 | P: Stop bit <sup>(1)</sup> (I <sup>2</sup> C mode only)                                                                                                      |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       |                                                                                                                                                              | es that a Stop<br>it was not det                                                                                                                |                           | en detected   | last         |           |            |       |  |  |  |  |
| bit 3 | <b>S</b> : Start bit <sup>(1)</sup> (l <sup>2</sup> C mode only)                                                                                             |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | <ul> <li>1 = Indicates that a Start bit has been detected last (this bit is '0' on Reset)</li> <li>0 = Start bit was not detected last</li> </ul>            |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
| bit 2 | R/W: Read                                                                                                                                                    | /Write Inform                                                                                                                                   | ation bit (I <sup>2</sup> | C mode only   | ')           |           |            |       |  |  |  |  |
|       | Holds the $R/\overline{W}$ bit information following the last address match and is only valid from address match to the next Start bit, Stop bit or ACK bit. |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | 1 = Read<br>0 = Write                                                                                                                                        |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
| bit 1 |                                                                                                                                                              | e Address bit                                                                                                                                   | (10-bit I <sup>2</sup> C  | mode only)    |              |           |            |       |  |  |  |  |
| bit 1 | 1 = Indicat                                                                                                                                                  | es that the us                                                                                                                                  | ser needs t               | o update the  | address in t | he SSPADI | O register |       |  |  |  |  |
| bit 0 |                                                                                                                                                              | Full Status bit                                                                                                                                 |                           | puatoa        |              |           |            |       |  |  |  |  |
| Sit 0 |                                                                                                                                                              |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       | <u>Receive (SPI and I<sup>2</sup>C modes):</u><br>1 = Receive complete, SSPBUF is full<br>0 = Receive not complete, SSPBUF is empty                          |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |
|       |                                                                                                                                                              | n I <sup>2</sup> C mode o                                                                                                                       |                           | is empty      |              |           |            |       |  |  |  |  |
|       | 1 = Transm                                                                                                                                                   | it in progress<br>it complete, \$                                                                                                               | , SSPBUF                  |               | )            |           |            |       |  |  |  |  |
|       |                                                                                                                                                              |                                                                                                                                                 |                           |               |              |           |            |       |  |  |  |  |

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











### REGISTER 11-2: ADCON1: A/D CONTROL REGISTER 1 (ADDRESS 9Fh)

|   | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|---|-------|-------|-----|-----|-------|-------|-------|-------|
| ſ | ADFM  | ADCS2 | —   | —   | PCFG3 | PCFG2 | PCFG1 | PCFG0 |
| - | bit 7 |       |     |     |       |       |       | bit 0 |

bit 7 ADFM: A/D Result Format Select bit

1 = Right justified, 6 Most Significant bits of ADRESH are read as '0'

 $_{\rm 0}$  = Left justified, 6 Least Significant bits of ADRESL are read as '0'

bit 6 ADCS2: A/D Clock Divide by 2 Select bit

1 = A/D clock source is divided by 2 when system clock is used 0 = Disabled

bit 5-4 Unimplemented: Read as '0'

bit 3-0 PCFG<3:0>: A/D Port Configuration Control bits

| PCFG | AN4 | AN3   | AN2   | AN1 | AN0 | VREF+ | VREF- | C/R |
|------|-----|-------|-------|-----|-----|-------|-------|-----|
| 0000 | Α   | Α     | Α     | Α   | Α   | AVdd  | AVss  | 5/0 |
| 0001 | Α   | VREF+ | A     | A   | A   | AN3   | AVss  | 4/1 |
| 0010 | Α   | A     | A     | A   | A   | AVdd  | AVss  | 5/0 |
| 0011 | Α   | VREF+ | A     | A   | A   | AN3   | AVss  | 4/1 |
| 0100 | D   | A     | D     | Α   | A   | AVdd  | AVss  | 3/0 |
| 0101 | D   | VREF+ | D     | A   | A   | AN3   | AVss  | 2/1 |
| 011x | D   | D     | D     | D   | D   | AVdd  | AVss  | 0/0 |
| 1000 | Α   | VREF+ | Vref- | Α   | A   | AN3   | AN2   | 3/2 |
| 1001 | Α   | A     | A     | Α   | Α   | AVdd  | AVss  | 5/0 |
| 1010 | Α   | VREF+ | A     | A   | A   | AN3   | AVss  | 4/1 |
| 1011 | Α   | VREF+ | Vref- | Α   | Α   | AN3   | AN2   | 3/2 |
| 1100 | Α   | VREF+ | Vref- | A   | A   | AN3   | AN2   | 3/2 |
| 1101 | D   | VREF+ | Vref- | А   | А   | AN3   | AN2   | 2/2 |
| 1110 | D   | D     | D     | D   | A   | AVdd  | AVss  | 1/0 |
| 1111 | D   | VREF+ | VREF- | D   | A   | AN3   | AN2   | 1/2 |

A = Analog input D = Digital I/O

C/R = Number of analog input channels/Number of A/D voltage references

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

# 11.4 A/D Conversions

Clearing the GO/DONE bit during a conversion will abort the current conversion. The A/D Result register pair will NOT be updated with the partially completed A/D conversion sample. That is, the ADRESH:ADRESL registers will continue to contain the value of the last completed conversion (or the last value written to the ADRESH:ADRESL registers). After the A/D conversion is aborted, a 2-TAD wait is required before the next acquisition is started. After this 2-TAD wait, acquisition on the selected channel is automatically started. The GO/DONE bit can then be set to start the conversion.

In Figure 11-3, after the GO bit is set, the first time segment has a minimum of TCY and a maximum of TAD.

Note: The GO/DONE bit should NOT be set in the same instruction that turns on the A/D.

### 11.4.1 A/D RESULT REGISTERS

The ADRESH:ADRESL register pair is the location where the 10-bit A/D result is loaded at the completion of the A/D conversion. This register pair is 16 bits wide. The A/D module gives the flexibility to left or right justify the 10-bit result in the 16-bit result register. The A/D Format Select bit (ADFM) controls this justification. Figure 11-4 shows the operation of the A/D result justification. The extra bits are loaded with '0's. When an A/D result will not overwrite these locations (A/D disable), these registers may be used as two general purpose 8-bit registers.

### FIGURE 11-3: A/D CONVERSION TAD CYCLES



### FIGURE 11-4: A/D RESULT JUSTIFICATION



| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                                                     |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b < 7 \end{array}$                                                                                                                                        |
| Operation:       | skip if (f <b>) = 1</b>                                                                                                                                                                                 |
| Status Affected: | None                                                                                                                                                                                                    |
| Description:     | If bit 'b' in register 'f' = 0, the next<br>instruction is executed.<br>If bit 'b' = 1, then the next<br>instruction is discarded and a NOP<br>is executed instead, making this a<br>2 Tcy instruction. |

| CLRF             | Clear f                                                               |  |  |
|------------------|-----------------------------------------------------------------------|--|--|
| Syntax:          | [label] CLRF f                                                        |  |  |
| Operands:        | $0 \le f \le 127$                                                     |  |  |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |  |  |
| Status Affected: | Z                                                                     |  |  |
| Description:     | The contents of register 'f' are<br>cleared and the Z bit is set.     |  |  |

| BTFSC            | Bit Test, Skip if Clear                                                                                                                                                                                            |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSC f,b                                                                                                                                                                                                |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                                                |
| Operation:       | skip if (f <b>) = <math>0</math></b>                                                                                                                                                                               |
| Status Affected: | None                                                                                                                                                                                                               |
| Description:     | If bit 'b' in register 'f' = 1, the next<br>instruction is executed.<br>If bit 'b' in register 'f' = 0, the next<br>instruction is discarded and a NOP<br>is executed instead, making this a<br>2 TCY instruction. |

| CLRW             | Clear W                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label] CLRW                                                          |
| Operands:        | None                                                                  |
| Operation:       | $\begin{array}{l} 00h \rightarrow (W) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | W register is cleared. Zero bit (Z) is set.                           |

| CALL             | Call Subroutine                                                                                                                                                                                            | CLRWDT           | Clear Watchdog Timer                                                                                                           |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                    | Syntax:          | [label] CLRWDT                                                                                                                 |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                       | Operands:        | None                                                                                                                           |
| Operation:       | (PC) + 1 → TOS,<br>k → PC<10:0>,<br>(PCLATH<4:3>) → PC<12:11>                                                                                                                                              | Operation:       | $00h \rightarrow WDT$<br>$0 \rightarrow WDT \text{ prescaler,}$<br>$1 \rightarrow \overline{TO}$                               |
| Status Affected: | None                                                                                                                                                                                                       |                  | $1 \rightarrow PD$                                                                                                             |
| Description:     | Call subroutine. First, return                                                                                                                                                                             | Status Affected: | TO, PD                                                                                                                         |
|                  | address (PC + 1) is pushed onto<br>the stack. The eleven-bit<br>immediate address is loaded into<br>PC bits<10:0>. The upper bits of<br>the PC are loaded from PCLATH.<br>CALL is a two-cycle instruction. | Description:     | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. Status bits<br>TO and PD are set. |





| TABLE 15-2: | CLKO AND I/O TIMING REQUIREMENTS |
|-------------|----------------------------------|
|-------------|----------------------------------|

| Param<br>No. | Symbol     | Characterist                                                  | Min                     | Тур†       | Мах | Units        | Conditions |          |
|--------------|------------|---------------------------------------------------------------|-------------------------|------------|-----|--------------|------------|----------|
| 10*          | TosH2ckL   | OSC1 $\uparrow$ to CLKO $\downarrow$                          |                         | _          | 75  | 200          | ns         | (Note 1) |
| 11*          | TosH2ckH   | OSC1 ↑ to CLKO ↑                                              |                         | _          | 75  | 200          | ns         | (Note 1) |
| 12*          | ТскR       | CLKO Rise Time                                                |                         | _          | 35  | 100          | ns         | (Note 1) |
| 13*          | ТскF       | CLKO Fall Time                                                |                         | _          | 35  | 100          | ns         | (Note 1) |
| 14*          | TCKL2IOV   | CLKO ↓ to Port Out Valid                                      |                         |            | _   | 0.5 TCY + 20 | ns         | (Note 1) |
| 15*          | ТюV2скН    | Port In Valid before CLKO ↑                                   |                         | Tosc + 200 | _   | —            | ns         | (Note 1) |
| 16*          | TCKH2IOI   | Port In Hold after CLKO ↑                                     |                         | 0          | —   | —            | ns         | (Note 1) |
| 17*          | TosH2IoV   | OSC1 ↑ (Q1 cycle) to Port Out Valid                           |                         | _          | 100 | 255          | ns         |          |
| 18*          | * TosH2iol | OSC1 ↑ (Q2 cycle) to Port<br>Input Invalid (I/O in hold time) | PIC16F818/819           | 100        | _   | —            | ns         |          |
|              |            |                                                               | PIC16LF818/819          | 200        | —   | _            | ns         |          |
| 19*          | TIOV20sH   | Port Input Valid to OSC1 ↑ (I/O in setup time)                |                         | 0          | _   | —            | ns         |          |
| 20*          | TIOR       | Port Output Rise Time                                         | PIC16F818/819           |            | 10  | 40           | ns         |          |
|              |            |                                                               | PIC16LF818/819          | _          | —   | 145          | ns         |          |
| 21*          | TIOF       | Port Output Fall Time                                         | PIC16 <b>F</b> 818/819  |            | 10  | 40           | ns         |          |
|              |            |                                                               | PIC16 <b>LF</b> 818/819 |            | _   | 145          | ns         |          |
| 22††*        | TINP       | INT pin High or Low Time                                      |                         | Тсү        | —   | —            | ns         |          |
| 23††*        | Trbp       | RB7:RB4 Change INT High or Low Time                           |                         | Тсү        | -   | —            | ns         |          |

\* These parameters are characterized but not tested.

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

tt These parameters are asynchronous events, not related to any internal clock edges.

Note 1: Measurements are taken in RC mode, where CLKO output is 4 x Tosc.



# FIGURE 15-10: SPI MASTER MODE TIMING (CKE = 0, SMP = 0)

### FIGURE 15-11: SPI MASTER MODE TIMING (CKE = 1, SMP = 1)



#### 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.

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

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MTP, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

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

Analog-for-the-Digital Age, Application Maestro, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, SQI, Serial Quad I/O, Total Endurance, TSHARC, UniWinDriver, WiperLock, ZENA and Z-Scale are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

GestIC and ULPP are registered trademarks 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.

© 2001-2013, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

ISBN: 9781620769393

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 mulfacture of development systems is ISO 9001:2000 certified.