

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



### Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









### 28/40-Pin 8-Bit CMOS FLASH Microcontrollers

#### **Devices Included in this Data Sheet:**

PIC16F873
 PIC16F876
 PIC16F877
 PIC16F877

#### **Microcontroller Core Features:**

- · High performance RISC CPU
- · Only 35 single word instructions to learn
- All single cycle instructions except for program branches which are two cycle
- Operating speed: DC 20 MHz clock input
   DC 200 ns instruction cycle
- Up to 8K x 14 words of FLASH Program Memory, Up to 368 x 8 bytes of Data Memory (RAM)
   Up to 256 x 8 bytes of EEPROM Data Memory
- Pinout compatible to the PIC16C73B/74B/76/77
- Interrupt capability (up to 14 sources)
- · Eight level deep hardware stack
- · Direct, indirect and relative addressing modes
- · Power-on Reset (POR)
- Power-up Timer (PWRT) and Oscillator Start-up Timer (OST)
- Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation
- Programmable code protection
- · Power saving SLEEP mode
- · Selectable oscillator options
- Low power, high speed CMOS FLASH/EEPROM technology
- Fully static design
- In-Circuit Serial Programming™ (ICSP) via two pins
- Single 5V In-Circuit Serial Programming capability
- · In-Circuit Debugging via two pins
- Processor read/write access to program memory
- Wide operating voltage range: 2.0V to 5.5V
- · High Sink/Source Current: 25 mA
- Commercial, Industrial and Extended temperature ranges
- Low-power consumption:
  - < 0.6 mA typical @ 3V, 4 MHz</li>
  - 20 μA typical @ 3V, 32 kHz
  - < 1 μA typical standby current

#### Pin Diagram



#### **Peripheral Features:**

- Timer0: 8-bit timer/counter with 8-bit prescaler
- Timer1: 16-bit timer/counter with prescaler, can be incremented during SLEEP via external crystal/clock
- Timer2: 8-bit timer/counter with 8-bit period register, prescaler and postscaler
- Two Capture, Compare, PWM modules
  - Capture is 16-bit, max. resolution is 12.5 ns
  - Compare is 16-bit, max. resolution is 200 ns
  - PWM max. resolution is 10-bit
- 10-bit multi-channel Analog-to-Digital converter
- Synchronous Serial Port (SSP) with SPI (Master mode) and I<sup>2</sup>C<sup>™</sup> (Master/Slave)
- Universal Synchronous Asynchronous Receiver Transmitter (USART/SCI) with 9-bit address detection
- Parallel Slave Port (PSP) 8-bits wide, with external RD, WR and CS controls (40/44-pin only)
- Brown-out detection circuitry for Brown-out Reset (BOR)

#### **Pin Diagrams**



| Key Features<br>PIC <sup>®</sup> MCU Mid-Range Reference<br>Manual (DS33023) | PIC16F873               | PIC16F874               | PIC16F876               | PIC16F877               |
|------------------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
| Operating Frequency                                                          | DC - 20 MHz             |
| RESETS (and Delays)                                                          | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) | POR, BOR<br>(PWRT, OST) |
| FLASH Program Memory<br>(14-bit words)                                       | 4K                      | 4K                      | 8K                      | 8K                      |
| Data Memory (bytes)                                                          | 192                     | 192                     | 368                     | 368                     |
| EEPROM Data Memory                                                           | 128                     | 128                     | 256                     | 256                     |
| Interrupts                                                                   | 13                      | 14                      | 13                      | 14                      |
| I/O Ports                                                                    | Ports A,B,C             | Ports A,B,C,D,E         | Ports A,B,C             | Ports A,B,C,D,E         |
| Timers                                                                       | 3                       | 3                       | 3                       | 3                       |
| Capture/Compare/PWM Modules                                                  | 2                       | 2                       | 2                       | 2                       |
| Serial Communications                                                        | MSSP, USART             | MSSP, USART             | MSSP, USART             | MSSP, USART             |
| Parallel Communications                                                      | _                       | PSP                     | _                       | PSP                     |
| 10-bit Analog-to-Digital Module                                              | 5 input channels        | 8 input channels        | 5 input channels        | 8 input channels        |
| Instruction Set                                                              | 35 instructions         | 35 instructions         | 35 instructions         | 35 instructions         |

#### **Table of Contents**

| 1.0   | Device Overview                                                             | 5   |
|-------|-----------------------------------------------------------------------------|-----|
| 2.0   | Memory Organization                                                         | 11  |
| 3.0   | I/O Ports                                                                   | 29  |
| 4.0   | Data EEPROM and FLASH Program Memory                                        | 41  |
| 5.0   | Timer0 Module                                                               | 47  |
| 6.0   | Timer1 Module                                                               | 51  |
| 7.0   | Timer2 Module                                                               |     |
| 8.0   | Capture/Compare/PWM Modules                                                 |     |
| 9.0   | Master Synchronous Serial Port (MSSP) Module                                |     |
| 10.0  | Addressable Universal Synchronous Asynchronous Receiver Transmitter (USART) | 95  |
| 11.0  | Analog-to-Digital Converter (A/D) Module                                    | 111 |
|       | Special Features of the CPU                                                 |     |
| 13.0  | Instruction Set Summary                                                     | 135 |
|       |                                                                             |     |
|       | Electrical Characteristics                                                  |     |
| 16.0  | DC and AC Characteristics Graphs and Tables                                 | 177 |
|       | Packaging Information                                                       |     |
| Appe  | endix A: Revision History                                                   | 197 |
|       | endix B: Device Differences                                                 |     |
| Appe  | endix C: Conversion Considerations                                          | 198 |
| Index | ·                                                                           | 199 |
| On-L  | ine Support                                                                 | 207 |
| Read  | der Response                                                                | 208 |
| PIC1  | 6E87X Product Identification System                                         | 200 |

#### TO OUR VALUED CUSTOMERS

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

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@mail.microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### **Most Current Data Sheet**

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

http://www.microchip.com

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

#### **Errata**

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

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

- Microchip's Worldwide Web site; http://www.microchip.com
- · Your local Microchip sales office (see last page)
- The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277

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

#### **Customer Notification System**

Register on our web site at www.microchip.com/cn to receive the most current information on all of our products.

#### 1.0 DEVICE OVERVIEW

This document contains device specific information. Additional information may be found in the PIC<sup>®</sup> MCU Mid-Range Reference Manual (DS33023), which may be obtained from your local Microchip Sales Representative or downloaded from the Microchip website. The Reference Manual should be considered a complementary document to this data sheet, and is highly recommended reading for a better understanding of the device architecture and operation of the peripheral modules.

There are four devices (PIC16F873, PIC16F874, PIC16F876 and PIC16F877) covered by this data sheet. The PIC16F876/873 devices come in 28-pin packages and the PIC16F877/874 devices come in 40-pin packages. The Parallel Slave Port is not implemented on the 28-pin devices.

The following device block diagrams are sorted by pin number; 28-pin for Figure 1-1 and 40-pin for Figure 1-2. The 28-pin and 40-pin pinouts are listed in Table 1-1 and Table 1-2, respectively.

FIGURE 1-1: PIC16F873 AND PIC16F876 BLOCK DIAGRAM



FIGURE 1-2: PIC16F874 AND PIC16F877 BLOCK DIAGRAM



**TABLE 1-1:** PIC16F873 AND PIC16F876 PINOUT DESCRIPTION

| Pin Name         | DIP<br>Pin# | SOIC<br>Pin# | I/O/P<br>Type | Buffer<br>Type         | Description                                                                                                                                                                                                  |
|------------------|-------------|--------------|---------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKIN       | 9           | 9            | I             | ST/CMOS <sup>(3)</sup> | Oscillator crystal input/external clock source input.                                                                                                                                                        |
| OSC2/CLKOUT      | 10          | 10           | 0             | _                      | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, the OSC2 pin outputs CLKOUT which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. |
| MCLR/VPP         | 1           | 1            | I/P           | ST                     | Master Clear (Reset) input or programming voltage input. This pin is an active low RESET to the device.                                                                                                      |
|                  |             |              |               |                        | PORTA is a bi-directional I/O port.                                                                                                                                                                          |
| RA0/AN0          | 2           | 2            | I/O           | TTL                    | RA0 can also be analog input0.                                                                                                                                                                               |
| RA1/AN1          | 3           | 3            | I/O           | TTL                    | RA1 can also be analog input1.                                                                                                                                                                               |
| RA2/AN2/VREF-    | 4           | 4            | I/O           | TTL                    | RA2 can also be analog input2 or negative analog reference voltage.                                                                                                                                          |
| RA3/AN3/VREF+    | 5           | 5            | I/O           | TTL                    | RA3 can also be analog input3 or positive analog reference voltage.                                                                                                                                          |
| RA4/T0CKI        | 6           | 6            | I/O           | ST                     | RA4 can also be the clock input to the Timer0 module. Output is open drain type.                                                                                                                             |
| RA5/SS/AN4       | 7           | 7            | I/O           | TTL                    | RA5 can also be analog input4 or the slave select for the synchronous serial port.                                                                                                                           |
|                  |             |              |               |                        | PORTB is a bi-directional I/O port. PORTB can be software                                                                                                                                                    |
|                  |             |              |               | (1)                    | programmed for internal weak pull-up on all inputs.                                                                                                                                                          |
| RB0/INT          | 21          | 21           | I/O           | TTL/ST <sup>(1)</sup>  | RB0 can also be the external interrupt pin.                                                                                                                                                                  |
| RB1              | 22          | 22           | I/O           | TTL                    |                                                                                                                                                                                                              |
| RB2              | 23          | 23           | I/O           | TTL                    |                                                                                                                                                                                                              |
| RB3/PGM          | 24          | 24           | 1/0           | TTL                    | RB3 can also be the low voltage programming input.                                                                                                                                                           |
| RB4              | 25          | 25           | 1/0           | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                     |
| RB5              | 26          | 26           | 1/0           | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                     |
| RB6/PGC          | 27          | 27           | I/O           | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming clock.                                                                                                                                |
| RB7/PGD          | 28          | 28           | I/O           | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming data.                                                                                                                                 |
|                  |             |              |               |                        | PORTC is a bi-directional I/O port.                                                                                                                                                                          |
| RC0/T1OSO/T1CKI  | 11          | 11           | I/O           | ST                     | RC0 can also be the Timer1 oscillator output or Timer1 clock input.                                                                                                                                          |
| RC1/T1OSI/CCP2   | 12          | 12           | I/O           | ST                     | RC1 can also be the Timer1 oscillator input or Capture2 input/Compare2 output/PWM2 output.                                                                                                                   |
| RC2/CCP1         | 13          | 13           | I/O           | ST                     | RC2 can also be the Capture1 input/Compare1 output/<br>PWM1 output.                                                                                                                                          |
| RC3/SCK/SCL      | 14          | 14           | I/O           | ST                     | RC3 can also be the synchronous serial clock input/output for both SPI and I <sup>2</sup> C modes.                                                                                                           |
| RC4/SDI/SDA      | 15          | 15           | I/O           | ST                     | RC4 can also be the SPI Data In (SPI mode) or data I/O ( $I^2$ C mode).                                                                                                                                      |
| RC5/SDO          | 16          | 16           | I/O           | ST                     | RC5 can also be the SPI Data Out (SPI mode).                                                                                                                                                                 |
| RC6/TX/CK        | 17          | 17           | I/O           | ST                     | RC6 can also be the USART Asynchronous Transmit or Synchronous Clock.                                                                                                                                        |
| RC7/RX/DT        | 18          | 18           | I/O           | ST                     | RC7 can also be the USART Asynchronous Receive or Synchronous Data.                                                                                                                                          |
| Vss              | 8, 19       | 8, 19        | Р             | _                      | Ground reference for logic and I/O pins.                                                                                                                                                                     |
| VDD              | 20          | 20           | Р             | _                      | Positive supply for logic and I/O pins.                                                                                                                                                                      |
| Legend: L= input | O = outr    |              | 1/0           | input/output           | P = nower                                                                                                                                                                                                    |

Legend: I = input

O = output

I/O = input/output

P = power

— = Not used

TTL = TTL input ST = Schmitt Trigger input

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

- This buffer is a Schmitt Trigger input when used in Serial Programming mode.
   This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.

**TABLE 1-2:** PIC16F874 AND PIC16F877 PINOUT DESCRIPTION

| Pin Name      | DIP<br>Pin# | PLCC<br>Pin# | QFP<br>Pin# | I/O/P<br>Type | Buffer<br>Type         | Description                                                                                                                                                                                              |
|---------------|-------------|--------------|-------------|---------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKIN    | 13          | 14           | 30          | I             | ST/CMOS <sup>(4)</sup> | Oscillator crystal input/external clock source input.                                                                                                                                                    |
| OSC2/CLKOUT   | 14          | 15           | 31          | 0             | _                      | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, OSC2 pin outputs CLKOUT which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. |
| MCLR/VPP      | 1           | 2            | 18          | I/P           | ST                     | Master Clear (Reset) input or programming voltage input. This pin is an active low RESET to the device.                                                                                                  |
|               |             |              |             |               |                        | PORTA is a bi-directional I/O port.                                                                                                                                                                      |
| RA0/AN0       | 2           | 3            | 19          | I/O           | TTL                    | RA0 can also be analog input0.                                                                                                                                                                           |
| RA1/AN1       | 3           | 4            | 20          | I/O           | TTL                    | RA1 can also be analog input1.                                                                                                                                                                           |
| RA2/AN2/VREF- | 4           | 5            | 21          | I/O           | TTL                    | RA2 can also be analog input2 or negative analog reference voltage.                                                                                                                                      |
| RA3/AN3/VREF+ | 5           | 6            | 22          | I/O           | TTL                    | RA3 can also be analog input3 or positive analog reference voltage.                                                                                                                                      |
| RA4/T0CKI     | 6           | 7            | 23          | I/O           | ST                     | RA4 can also be the clock input to the Timer0 timer/ counter. Output is open drain type.                                                                                                                 |
| RA5/SS/AN4    | 7           | 8            | 24          | I/O           | TTL                    | RA5 can also be analog input4 or the slave select for the synchronous serial port.                                                                                                                       |
|               |             |              |             |               |                        | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs.                                                                                            |
| RB0/INT       | 33          | 36           | 8           | I/O           | TTL/ST <sup>(1)</sup>  | RB0 can also be the external interrupt pin.                                                                                                                                                              |
| RB1           | 34          | 37           | 9           | I/O           | TTL                    |                                                                                                                                                                                                          |
| RB2           | 35          | 38           | 10          | I/O           | TTL                    |                                                                                                                                                                                                          |
| RB3/PGM       | 36          | 39           | 11          | I/O           | TTL                    | RB3 can also be the low voltage programming input.                                                                                                                                                       |
| RB4           | 37          | 41           | 14          | I/O           | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                 |
| RB5           | 38          | 42           | 15          | I/O           | TTL                    | Interrupt-on-change pin.                                                                                                                                                                                 |
| RB6/PGC       | 39          | 43           | 16          | I/O           | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming clock.                                                                                                                         |
| RB7/PGD       | 40          | 44           | 17          | I/O           | TTL/ST <sup>(2)</sup>  | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming data.                                                                                                                          |

Legend: I = input

O = output - = Not used

I/O = input/output

TTL = TTL input

P = power ST = Schmitt Trigger input

Note 1: This buffer is a Schmitt Trigger input when configured as an 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 as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus).
- 4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.

**TABLE 1-2:** PIC16F874 AND PIC16F877 PINOUT DESCRIPTION (CONTINUED)

| RC7/RX/DT   26   29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Pin Name        | DIP<br>Pin# | PLCC<br>Pin#   | QFP<br>Pin#     | I/O/P<br>Type | Buffer<br>Type        | Description                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|----------------|-----------------|---------------|-----------------------|---------------------------------------------------------------------------------|
| RC1/T1OSI/CCP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |             |                |                 |               |                       | PORTC is a bi-directional I/O port.                                             |
| RC2/CCP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RC0/T1OSO/T1CKI | 15          | 16             | 32              | I/O           | ST                    | ·                                                                               |
| RC3/SCK/SCL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RC1/T1OSI/CCP2  | 16          | 18             | 35              | I/O           | ST                    |                                                                                 |
| RC4/SDI/SDA   23   25   42   I/O   ST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RC2/CCP1        | 17          | 19             | 36              | I/O           | ST                    |                                                                                 |
| RC5/SDO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RC3/SCK/SCL     | 18          | 20             | 37              | I/O           | ST                    |                                                                                 |
| RC6/TX/CK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RC4/SDI/SDA     | 23          | 25             | 42              | I/O           | ST                    | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode). |
| RC7/RX/DT   26   29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RC5/SDO         | 24          | 26             | 43              | I/O           | ST                    | RC5 can also be the SPI Data Out (SPI mode).                                    |
| RD0/PSP0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RC6/TX/CK       | 25          | 27             | 44              | I/O           | ST                    | RC6 can also be the USART Asynchronous Transmit or Synchronous Clock.           |
| RD0/PSP0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RC7/RX/DT       | 26          | 29             | 1               | I/O           | ST                    |                                                                                 |
| RD1/PSP1         20         22         39         I/O         ST/TTL(3)           RD2/PSP2         21         23         40         I/O         ST/TTL(3)           RD3/PSP3         22         24         41         I/O         ST/TTL(3)           RD4/PSP4         27         30         2         I/O         ST/TTL(3)           RD5/PSP5         28         31         3         I/O         ST/TTL(3)           RD6/PSP6         29         32         4         I/O         ST/TTL(3)           RD7/PSP7         30         33         5         I/O         ST/TTL(3)           RE0/RD/AN5         8         9         25         I/O         ST/TTL(3)         RE0 can also be read control for the parallel slave port, or analog input5.           RE1/WR/AN6         9         10         26         I/O         ST/TTL(3)         RE1 can also be write control for the parallel slave port, or analog input6.           RE2/CS/AN7         10         11         27         I/O         ST/TTL(3)         RE2 can also be select control for the parallel slave port, or analog input7.           Vss         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VDD                         |                 |             |                |                 |               |                       |                                                                                 |
| RD2/PSP2         21         23         40         I/O         ST/TTL(3)           RD3/PSP3         22         24         41         I/O         ST/TTL(3)           RD4/PSP4         27         30         2         I/O         ST/TTL(3)           RD5/PSP5         28         31         3         I/O         ST/TTL(3)           RD6/PSP6         29         32         4         I/O         ST/TTL(3)           RD7/PSP7         30         33         5         I/O         ST/TTL(3)           RE0/RD/AN5         8         9         25         I/O         ST/TTL(3)           RE1/WR/AN6         9         10         26         I/O         ST/TTL(3)         RE1 can also be write control for the parallel slave port, or analog input5.           RE2/CS/AN7         10         11         27         I/O         ST/TTL(3)         RE2 can also be select control for the parallel slave port, or analog input6.           Vss         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VbD         11,32         12,35         7,28         P         —         Positive supply for logic and I/O pins.           NC         —         1,17,28, 12,                                      | RD0/PSP0        | 19          | 21             | 38              | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RD3/PSP3         22         24         41         I/O         ST/TTL(3)         RD4/PSP4         27         30         2         I/O         ST/TTL(3)         RD5/PSP5         28         31         3         I/O         ST/TTL(3)         RD6/PSP6         29         32         4         I/O         ST/TTL(3)         RD7/PSP7         30         33         5         I/O         ST/TTL(3)         RE0 can also be read control for the parallel slave port, or analog input5.           RE1/WR/AN6         9         10         26         I/O         ST/TTL(3)         RE1 can also be write control for the parallel slave port, or analog input6.           RE2/CS/AN7         10         11         27         I/O         ST/TTL(3)         RE2 can also be select control for the parallel slave port, or analog input6.           VSS         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VDD         11,32         12,35         7,28         P         —         Positive supply for logic and I/O pins.           NC         —         1,17,28, 12,13,         —         These pins are not internally connected. These pins                                                     | RD1/PSP1        | 20          | 22             | 39              | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RD4/PSP4         27         30         2         I/O         ST/TTL(3)         RD5/PSP5         28         31         3         I/O         ST/TTL(3)         RD6/PSP6         29         32         4         I/O         ST/TTL(3)         RD7/PSP7         30         33         5         I/O         ST/TTL(3)         PORTE is a bi-directional I/O port.           RE0/RD/AN5         8         9         25         I/O         ST/TTL(3)         RE0 can also be read control for the parallel slave port, or analog input5.           RE1/WR/AN6         9         10         26         I/O         ST/TTL(3)         RE1 can also be write control for the parallel slave port, or analog input6.           RE2/CS/AN7         10         11         27         I/O         ST/TTL(3)         RE2 can also be select control for the parallel slave port, or analog input6.           VSS         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VDD         11,32         12,35         7,28         P         —         Positive supply for logic and I/O pins.           NC         —         1,17,28         12,13         —         These pins are not internally connected. These pins | RD2/PSP2        | 21          | 23             | 40              | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RD5/PSP5         28         31         3         I/O         ST/TTL <sup>(3)</sup> RD6/PSP6         29         32         4         I/O         ST/TTL <sup>(3)</sup> PORTE is a bi-directional I/O port.           RD7/PSP7         30         33         5         I/O         ST/TTL <sup>(3)</sup> PORTE is a bi-directional I/O port.           RE0/RD/AN5         8         9         25         I/O         ST/TTL <sup>(3)</sup> RE0 can also be read control for the parallel slave port, or analog input5.           RE1/WR/AN6         9         10         26         I/O         ST/TTL <sup>(3)</sup> RE1 can also be write control for the parallel slave port, or analog input6.           RE2/CS/AN7         10         11         27         I/O         ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input7.           Vss         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VDD         11,32         12,35         7,28         P         —         Positive supply for logic and I/O pins.           NC         —         1,17,28, 12,13, 13,34         —         These pins are not internally connected. These pins          | RD3/PSP3        | 22          | 24             | 41              | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RD6/PSP6         29         32         4         I/O         ST/TTL(3)           RD7/PSP7         30         33         5         I/O         ST/TTL(3)           RE0/RD/AN5         8         9         25         I/O         ST/TTL(3)         RE0 can also be read control for the parallel slave port, or analog input5.           RE1/WR/AN6         9         10         26         I/O         ST/TTL(3)         RE1 can also be write control for the parallel slave port, or analog input6.           RE2/CS/AN7         10         11         27         I/O         ST/TTL(3)         RE2 can also be select control for the parallel slave port, or analog input7.           Vss         12,31         13,34         6,29         P         —         Ground reference for logic and I/O pins.           VDD         11,32         12,35         7,28         P         —         Positive supply for logic and I/O pins.           NC         —         1,17,28, 12,13,         —         These pins are not internally connected. These pins                                                                                                                                                                                                               | RD4/PSP4        | 27          | 30             | 2               | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RD7/PSP7  30  33  5  I/O  ST/TTL <sup>(3)</sup> PORTE is a bi-directional I/O port.  RE0/RD/AN5  8  9  25  I/O  ST/TTL <sup>(3)</sup> RE0 can also be read control for the parallel slave port, or analog input5.  RE1/WR/AN6  9  10  26  I/O  ST/TTL <sup>(3)</sup> RE1 can also be write control for the parallel slave port, or analog input6.  RE2/CS/AN7  10  11  27  I/O  ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input6.  RE2 can also be select control for the parallel slave port, or analog input7.  Vss  12,31  13,34  6,29  P  Ground reference for logic and I/O pins.  VDD  11,32  12,35  7,28  P  Positive supply for logic and I/O pins.  NC  These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RD5/PSP5        | 28          | 31             | 3               | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RE0/RD/AN5  8  9  25  I/O  ST/TTL(3)  RE0 can also be read control for the parallel slave port, or analog input5.  RE1/WR/AN6  9  10  26  I/O  ST/TTL(3)  RE1 can also be write control for the parallel slave port, or analog input6.  RE2/CS/AN7  10  11  27  I/O  ST/TTL(3)  RE1 can also be write control for the parallel slave port, or analog input6.  RE2 can also be select control for the parallel slave port, or analog input7.  Vss  12,31  13,34  6,29  P  Ground reference for logic and I/O pins.  VDD  11,32  12,35  7,28  P  Positive supply for logic and I/O pins.  NC  These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RD6/PSP6        | 29          | 32             | 4               | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RE0/RD/AN5       8       9       25       I/O       ST/TTL(3)       RE0 can also be read control for the parallel slave port, or analog input5.         RE1/WR/AN6       9       10       26       I/O       ST/TTL(3)       RE1 can also be write control for the parallel slave port, or analog input6.         RE2/CS/AN7       10       11       27       I/O       ST/TTL(3)       RE2 can also be select control for the parallel slave port, or analog input7.         Vss       12,31       13,34       6,29       P       —       Ground reference for logic and I/O pins.         VDD       11,32       12,35       7,28       P       —       Positive supply for logic and I/O pins.         NC       —       1,17,28, 12,13,       —       These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RD7/PSP7        | 30          | 33             | 5               | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| RE1/WR/AN6  9 10 26 I/O ST/TTL <sup>(3)</sup> RE1 can also be write control for the parallel slave port, or analog input6.  RE2/CS/AN7 10 11 27 I/O ST/TTL <sup>(3)</sup> RE2 can also be select control for the parallel slave port, or analog input6.  RE2 can also be select control for the parallel slave port, or analog input7.  Vss 12,31 13,34 6,29 P Ground reference for logic and I/O pins.  VDD 11,32 12,35 7,28 P Positive supply for logic and I/O pins.  NC These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |             |                |                 |               |                       | PORTE is a bi-directional I/O port.                                             |
| RE2/CS/AN7  10  11  27  I/O  ST/TTL(3)  port, or analog input6.  RE2 can also be select control for the parallel slave port, or analog input7.  Vss  12,31  13,34  6,29  P  Ground reference for logic and I/O pins.  VDD  11,32  12,35  7,28  P  Positive supply for logic and I/O pins.  NC   1,17,28, 12,13,  These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RE0/RD/AN5      | 8           | 9              | 25              | I/O           | ST/TTL <sup>(3)</sup> |                                                                                 |
| Vss12,3113,346,29P—Ground reference for logic and I/O pins.VDD11,3212,357,28P—Positive supply for logic and I/O pins.NC—1,17,28,12,13,—These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RE1/WR/AN6      | 9           | 10             | 26              | I/O           | ST/TTL <sup>(3)</sup> | ·                                                                               |
| VDD     11,32     12,35     7,28     P     —     Positive supply for logic and I/O pins.       NC     —     1,17,28, 12,13,     —     These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RE2/CS/AN7      | 10          | 11             | 27              | I/O           | ST/TTL <sup>(3)</sup> | ·                                                                               |
| NC — 1,17,28, 12,13, — These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Vss             | 12,31       | 13,34          | 6,29            | Р             | _                     | Ground reference for logic and I/O pins.                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | VDD             | 11,32       | 12,35          | 7,28            | Р             | _                     | Positive supply for logic and I/O pins.                                         |
| Silouid be left unconfriected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | NC              | _           | 1,17,28,<br>40 | 12,13,<br>33,34 |               | _                     | These pins are not internally connected. These pins should be left unconnected. |

Legend: I = input

O = output - = Not used I/O = input/output

TTL = TTL input

P = power

ST = Schmitt Trigger input

- Note 1: This buffer is a Schmitt Trigger input when configured as an 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 as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus).
  - 4: This buffer is a Schmitt Trigger input when configured in RC oscillator mode and a CMOS input otherwise.

**NOTES:** 

#### 2.0 MEMORY ORGANIZATION

There are three memory blocks in each of the PIC16F87X MCUs. The Program Memory and Data Memory have separate buses so that concurrent access can occur and is detailed in this section. The EEPROM data memory block is detailed in Section 4.0.

Additional information on device memory may be found in the  $PIC^{\circledR}$  MCU Mid-Range Reference Manual, (DS33023).

FIGURE 2-1: PIC16F877/876 PROGRAM MEMORY MAP AND STACK



#### 2.1 Program Memory Organization

The PIC16F87X devices have a 13-bit program counter capable of addressing an 8K x 14 program memory space. The PIC16F877/876 devices have 8K x 14 words of FLASH program memory, and the PIC16F873/874 devices have 4K x 14. Accessing a location above the physically implemented address will cause a wraparound.

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

FIGURE 2-2: PIC16F874/873 PROGRAM MEMORY MAP AND STACK



#### 2.2 Data Memory Organization

The data memory is partitioned into multiple banks which 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 General Purpose Registers, implemented as static RAM. All implemented banks contain Special Function Registers. Some frequently used Special Function Registers from one bank may be mirrored in another bank for code reduction and quicker access.

| Note: | EEPROM Data Memory description can be    |
|-------|------------------------------------------|
|       | found in Section 4.0 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: PIC16F877/876 REGISTER FILE MAP

|                                            | File<br>Address | ,                                          | File<br>Address |                                            | File<br>Address |                                            | Fil<br>Addr |
|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-----------------|--------------------------------------------|-------------|
| Indirect addr.(*)                          | 00h             | Indirect addr.(*)                          | 80h             | Indirect addr.(*)                          | 100h            | Indirect addr.(*)                          | 18          |
| TMR0                                       | 01h             | OPTION_REG                                 | 81h             | TMR0                                       | 101h            | OPTION_REG                                 | 18          |
| PCL                                        | 02h             | PCL                                        | 82h             | PCL                                        | 102h            | PCL                                        | 18          |
| STATUS                                     | 03h             | STATUS                                     | 83h             | STATUS                                     | 103h            | STATUS                                     | 18          |
| FSR                                        | 04h             | FSR                                        | 84h             | FSR                                        | 104h            | FSR                                        | 18          |
| PORTA                                      | 05h             | TRISA                                      | 85h             |                                            | 105h            |                                            | 18          |
| PORTB                                      | 06h             | TRISB                                      | 86h             | PORTB                                      | 106h            | TRISB                                      | 18          |
| PORTC                                      | 07h             | TRISC                                      | 87h             |                                            | 107h            |                                            | 18          |
| PORTD <sup>(1)</sup>                       | 08h             | TRISD <sup>(1)</sup>                       | 88h             |                                            | 108h            |                                            | 18          |
| PORTE <sup>(1)</sup>                       | 09h             | TRISE <sup>(1)</sup>                       | 89h             |                                            | 109h            |                                            | 18          |
| PCLATH                                     | 0Ah             | PCLATH                                     | 8Ah             | PCLATH                                     | 10Ah            | PCLATH                                     | 18          |
| INTCON                                     | 0Bh             | INTCON                                     | 8Bh             | INTCON                                     | 10Bh            | INTCON                                     | 18          |
| PIR1                                       | 0Ch             | PIE1                                       | 8Ch             | EEDATA                                     | 10Ch            | EECON1                                     | 18          |
| PIR2                                       | 0Dh             | PIE2                                       | 8Dh             | EEADR                                      | 10Dh            | EECON2                                     | 18          |
| TMR1L                                      | 0Eh             | PCON                                       | 8Eh             | EEDATH                                     | 10Eh            | Reserved <sup>(2)</sup>                    | 18          |
| TMR1H                                      | 0Fh             |                                            | 8Fh             | EEADRH                                     | 10Fh            | Reserved <sup>(2)</sup>                    | 18          |
| T1CON                                      | 10h             |                                            | 90h             |                                            | 110h            |                                            | 19          |
| TMR2                                       | 11h             | SSPCON2                                    | 91h             |                                            | 111h            |                                            | 19          |
| T2CON                                      | 12h             | PR2                                        | 92h             |                                            | 112h            |                                            | 19          |
| SSPBUF                                     | 13h             | SSPADD                                     | 93h             |                                            | 113h            |                                            | 19          |
| SSPCON                                     | 14h             | SSPSTAT                                    | 94h             |                                            | 114h            |                                            | 19          |
| CCPR1L                                     | 15h             |                                            | 95h             |                                            | 115h            |                                            | 19          |
| CCPR1H                                     | 16h             |                                            | 96h             |                                            | 116h            |                                            | 19          |
| CCP1CON                                    | 17h             |                                            | 97h             | General<br>Purpose                         | 117h            | General<br>Purpose                         | 19          |
| RCSTA                                      | 18h             | TXSTA                                      | 98h             | Register                                   | 118h            | Register                                   | 19          |
| TXREG                                      | 19h             | SPBRG                                      | 99h             | 16 Bytes                                   | 119h            | 16 Bytes                                   | 19          |
| RCREG                                      | 1Ah             |                                            | 9Ah             |                                            | 11Ah            |                                            | 19          |
| CCPR2L                                     | 1Bh             |                                            | 9Bh             |                                            | 11Bh            |                                            | 19          |
| CCPR2H                                     | 1Ch             |                                            | 9Ch             |                                            | 11Ch            |                                            | 19          |
| CCP2CON                                    | 1Dh             |                                            | 9Dh             |                                            | 11 Dh           |                                            | 19          |
| ADRESH                                     | 1Eh             | ADRESL                                     | 9Eh             |                                            | 11Eh            |                                            | 19          |
| ADCON0                                     | 1Fh             | ADCON1                                     | 9Fh             |                                            | 11Fh            |                                            | 19          |
|                                            | 20h             |                                            | A0h             |                                            | 120h            |                                            | 1.4         |
| General<br>Purpose<br>Register<br>96 Bytes |                 | General<br>Purpose<br>Register<br>80 Bytes | EFh             | General<br>Purpose<br>Register<br>80 Bytes | 16Fh            | General<br>Purpose<br>Register<br>80 Bytes | 1E          |
| 22 27.00                                   | J 7Fh           | accesses<br>70h-7Fh                        | F0h             | accesses<br>70h-7Fh                        | 170h<br>17Fh    | accesses<br>70h - 7Fh                      | 1F          |
| Bank 0                                     | - /             | Bank 1                                     |                 | Bank 2                                     |                 | Bank 3                                     |             |

Unimplemented data meNot a physical register.

Note 1: These registers are not implemented on the PIC16F876.

<sup>2:</sup> These registers are reserved, maintain these registers clear.

FIGURE 2-4: PIC16F874/873 REGISTER FILE MAP

|                                | File<br>Address            | A                                                                    | File<br>Address | ,                   | File<br>Address |                         | File<br>Addres |
|--------------------------------|----------------------------|----------------------------------------------------------------------|-----------------|---------------------|-----------------|-------------------------|----------------|
| Indirect addr.(*)              | 00h                        | Indirect addr.(*)                                                    | 80h             | Indirect addr.(*)   | 100h            | Indirect addr.(*)       | 180h           |
| TMR0                           | 01h                        | OPTION REG                                                           | 81h             | TMR0                | 101h            | OPTION REG              | 181h           |
| PCL                            | 02h                        | PCL                                                                  | 82h             | PCL                 | 102h            | PCL                     | 182            |
| STATUS                         | 03h                        | STATUS                                                               | 83h             | STATUS              | 103h            | STATUS                  | 1831           |
| FSR                            | 04h                        | FSR                                                                  | 84h             | FSR                 | 104h            | FSR                     | 184            |
| PORTA                          | 05h                        | TRISA                                                                | 85h             |                     | 105h            |                         | 1851           |
| PORTB                          | 06h                        | TRISB                                                                | 86h             | PORTB               | 106h            | TRISB                   | 186            |
| PORTC                          | 07h                        | TRISC                                                                | 87h             |                     | 107h            |                         | 187            |
| PORTD <sup>(1)</sup>           | 08h                        | TRISD <sup>(1)</sup>                                                 | 88h             |                     | 108h            |                         | 188            |
| PORTE <sup>(1)</sup>           | 09h                        | TRISE <sup>(1)</sup>                                                 | 89h             |                     | 109h            |                         | 189            |
| PCLATH                         | 0Ah                        | PCLATH                                                               | 8Ah             | PCLATH              | 10Ah            | PCLATH                  | 18A            |
| INTCON                         | 0Bh                        | INTCON                                                               | 8Bh             | INTCON              | 10Bh            | INTCON                  | 18B            |
| PIR1                           | 0Ch                        | PIE1                                                                 | 8Ch             | EEDATA              | 10Ch            | EECON1                  | 18C            |
| PIR2                           | 0Dh                        | PIE2                                                                 | 8Dh             | EEADR               | 10Dh            | EECON2                  | 180            |
| TMR1L                          | 0Eh                        | PCON                                                                 | 8Eh             | EEDATH              | 10Eh            | Reserved <sup>(2)</sup> | 18E            |
| TMR1H                          | 0Fh                        | 33.1                                                                 | 8Fh             | EEADRH              | 10Fh            | Reserved <sup>(2)</sup> | 18F            |
| T1CON                          | 10h                        |                                                                      | 90h             |                     | 110h            |                         | 190            |
| TMR2                           | 11h                        | SSPCON2                                                              | 91h             |                     |                 |                         |                |
| T2CON                          | 12h                        | PR2                                                                  | 92h             |                     |                 |                         |                |
| SSPBUF                         | 13h                        | SSPADD                                                               | 93h             |                     |                 |                         |                |
| SSPCON                         | 14h                        | SSPSTAT                                                              | 94h             |                     |                 |                         |                |
| CCPR1L                         | 15h                        |                                                                      | 95h             |                     |                 |                         |                |
| CCPR1H                         | 16h                        |                                                                      | 96h             |                     |                 |                         |                |
| CCP1CON                        | 17h                        |                                                                      | 97h             |                     |                 |                         |                |
| RCSTA                          | 18h                        | TXSTA                                                                | 98h             |                     |                 |                         |                |
| TXREG                          | 19h                        | SPBRG                                                                | 99h             |                     |                 |                         |                |
| RCREG                          | 1Ah                        |                                                                      | 9Ah             |                     |                 |                         |                |
| CCPR2L                         | 1Bh                        |                                                                      | 9Bh             |                     |                 |                         |                |
| CCPR2H                         | 1Ch                        |                                                                      | 9Ch             |                     |                 |                         |                |
| CCP2CON                        | 1Dh                        |                                                                      | 9Dh             |                     |                 |                         |                |
| ADRESH                         | 1Eh                        | ADRESL                                                               | 9Eh             |                     |                 |                         |                |
| ADCON0                         | 1Fh                        | ADCON1                                                               | 9Fh             |                     |                 |                         | ,              |
|                                | 20h                        |                                                                      | A0h             |                     | 120h            |                         | 1A0            |
| General<br>Purpose<br>Register |                            | General<br>Purpose<br>Register                                       |                 | accesses<br>20h-7Fh |                 | accesses<br>A0h - FFh   |                |
| 96 Bytes                       |                            | 96 Bytes                                                             |                 |                     | 16Fh<br>170h    |                         | 1EF<br>1F0     |
|                                | 7Fh                        |                                                                      | FFh             |                     | 17Fh            |                         | 1FF            |
| Bank 0                         |                            | Bank 1                                                               |                 | Bank 2              |                 | Bank 3                  |                |
| * Not a Note 1: These          | physical re<br>e registers | data memory loca<br>gister.<br>are not implemen<br>are reserved, mai | ted on the      | e PIC16F873.        |                 |                         |                |

#### 2.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers are registers used by the CPU and peripheral modules for controlling the desired operation of the device. These registers are implemented as static RAM. A list of these registers is given in Table 2-1. The Special Function Registers can be classified into two sets: core (CPU) and peripheral. Those registers associated with the core functions are described in detail in this section. Those related to the operation of the peripheral features are described in detail in the peripheral features section.

TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY

| Address              | Name    | Bit 7                | Bit 6          | Bit 5         | Bit 4          | Bit 3          | Bit 2           | Bit 1          | Bit 0    | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|----------------------|---------|----------------------|----------------|---------------|----------------|----------------|-----------------|----------------|----------|--------------------------|------------------------|
| Bank 0               | _       |                      |                |               |                |                |                 |                |          |                          |                        |
| 00h <sup>(3)</sup>   | INDF    | Addressin            | g this locatio | n uses conte  | ents of FSR to | address data   | a memory (no    | t a physical r | egister) | 0000 0000                | 27                     |
| 01h                  | TMR0    | Timer0 Mo            | dule Registe   | er            |                |                |                 |                |          | xxxx xxxx                | 47                     |
| 02h <sup>(3)</sup>   | PCL     | Program C            | Counter (PC)   | Least Signif  | icant Byte     |                |                 |                |          | 0000 0000                | 26                     |
| 03h <sup>(3)</sup>   | STATUS  | IRP                  | RP1            | RP0           | TO             | PD             | Z               | DC             | С        | 0001 1xxx                | 18                     |
| 04h <sup>(3)</sup>   | FSR     | Indirect Da          | ata Memory /   | Address Poir  | nter           |                |                 |                |          | xxxx xxxx                | 27                     |
| 05h                  | PORTA   | _                    | _              | PORTA Da      | ta Latch whei  | n written: POI | RTA pins wher   | n read         |          | 0x 0000                  | 29                     |
| 06h                  | PORTB   | PORTB D              | ata Latch wh   | en written: P | ORTB pins w    | hen read       |                 |                |          | xxxx xxxx                | 31                     |
| 07h                  | PORTC   | PORTC D              | ata Latch wh   | en written: P | ORTC pins v    | vhen read      |                 |                |          | xxxx xxxx                | 33                     |
| 08h <sup>(4)</sup>   | PORTD   | PORTD D              | ata Latch wh   | en written: P | ORTD pins v    | vhen read      |                 |                |          | xxxx xxxx                | 35                     |
| 09h <sup>(4)</sup>   | PORTE   | _                    | -              | _             | _              | _              | RE2             | RE1            | RE0      | xxx                      | 36                     |
| 0Ah <sup>(1,3)</sup> | PCLATH  | _                    | _              | _             | Write Buffer   | for the upper  | 5 bits of the f | Program Cou    | unter    | 0 0000                   | 26                     |
| 0Bh <sup>(3)</sup>   | INTCON  | GIE                  | PEIE           | T0IE          | INTE           | RBIE           | TOIF            | INTF           | RBIF     | 0000 000x                | 20                     |
| 0Ch                  | PIR1    | PSPIF <sup>(3)</sup> | ADIF           | RCIF          | TXIF           | SSPIF          | CCP1IF          | TMR2IF         | TMR1IF   | 0000 0000                | 22                     |
| 0Dh                  | PIR2    | _                    | (5)            | I             | EEIF           | BCLIF          | _               | _              | CCP2IF   | -r-0 00                  | 24                     |
| 0Eh                  | TMR1L   | Holding re           | gister for the | Least Signif  | icant Byte of  | the 16-bit TM  | IR1 Register    |                |          | xxxx xxxx                | 52                     |
| 0Fh                  | TMR1H   | Holding re           | gister for the | Most Signifi  | cant Byte of t | the 16-bit TM  | R1 Register     |                |          | xxxx xxxx                | 52                     |
| 10h                  | T1CON   | _                    | -              | T1CKPS1       | T1CKPS0        | T1OSCEN        | T1SYNC          | TMR1CS         | TMR10N   | 00 0000                  | 51                     |
| 11h                  | TMR2    | Timer2 Mo            | dule Registe   | er            |                |                |                 |                |          | 0000 0000                | 55                     |
| 12h                  | T2CON   | _                    | TOUTPS3        | TOUTPS2       | TOUTPS1        | TOUTPS0        | TMR2ON          | T2CKPS1        | T2CKPS0  | -000 0000                | 55                     |
| 13h                  | SSPBUF  | Synchrono            | ous Serial Po  | rt Receive B  | uffer/Transm   | it Register    |                 |                |          | xxxx xxxx                | 70, 73                 |
| 14h                  | SSPCON  | WCOL                 | SSPOV          | SSPEN         | CKP            | SSPM3          | SSPM2           | SSPM1          | SSPM0    | 0000 0000                | 67                     |
| 15h                  | CCPR1L  | Capture/C            | ompare/PWI     | M Register1   | (LSB)          |                |                 |                |          | xxxx xxxx                | 57                     |
| 16h                  | CCPR1H  | Capture/C            | ompare/PWI     | M Register1   | (MSB)          |                |                 |                |          | xxxx xxxx                | 57                     |
| 17h                  | CCP1CON | _                    | _              | CCP1X         | CCP1Y          | CCP1M3         | CCP1M2          | CCP1M1         | CCP1M0   | 00 0000                  | 58                     |
| 18h                  | RCSTA   | SPEN                 | RX9            | SREN          | CREN           | ADDEN          | FERR            | OERR           | RX9D     | 0000 000x                | 96                     |
| 19h                  | TXREG   | USART Tr             | ansmit Data    | Register      |                |                |                 |                |          | 0000 0000                | 99                     |
| 1Ah                  | RCREG   | USART R              | eceive Data    | Register      |                |                |                 |                |          | 0000 0000                | 101                    |
| 1Bh                  | CCPR2L  | Capture/C            | ompare/PWI     | M Register2   | (LSB)          |                |                 | <u></u>        |          | xxxx xxxx                | 57                     |
| 1Ch                  | CCPR2H  | Capture/C            | ompare/PWI     | M Register2   | (MSB)          |                |                 |                |          | xxxx xxxx                | 57                     |
| 1Dh                  | CCP2CON |                      | _              | CCP2X         | CCP2Y          | CCP2M3         | CCP2M2          | CCP2M1         | CCP2M0   | 00 0000                  | 58                     |
| 1Eh                  | ADRESH  | A/D Resul            | t Register Hi  | gh Byte       |                |                |                 |                |          | xxxx xxxx                | 116                    |
| 1Fh                  | ADCON0  | ADCS1                | ADCS0          | CHS2          | CHS1           | CHS0           | GO/DONE         | _              | ADON     | 0000 00-0                | 111                    |

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved.

Shaded locations are unimplemented, read as '0'.

Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter.

- 2: Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear.
- 3: These registers can be addressed from any bank.
- 4: PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'.
- $\textbf{5:} \ \ \mathsf{PIR2}\ \mathsf{<6}\ \mathsf{>}\ \mathsf{and}\ \mathsf{PIE2}\ \mathsf{<6}\ \mathsf{>}\ \mathsf{are}\ \mathsf{reserved}\ \mathsf{on}\ \mathsf{these}\ \mathsf{devices}; \ \mathsf{always}\ \mathsf{maintain}\ \mathsf{these}\ \mathsf{bits}\ \mathsf{clear}.$

**TABLE 2-1:** SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

| Address              | Name       | Bit 7                | Bit 6           | Bit 5                     | Bit 4          | Bit 3         | Bit 2             | Bit 1          | Bit 0    | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|----------------------|------------|----------------------|-----------------|---------------------------|----------------|---------------|-------------------|----------------|----------|--------------------------|------------------------|
| Bank 1               |            |                      |                 |                           |                |               |                   |                |          |                          |                        |
| 80h <sup>(3)</sup>   | INDF       | Addressin            | g this location | n uses conte              | ents of FSR to | address data  | a memory (no      | t a physical r | egister) | 0000 0000                | 27                     |
| 81h                  | OPTION_REG | RBPU                 | INTEDG          | T0CS                      | T0SE           | PSA           | PS2               | PS1            | PS0      | 1111 1111                | 19                     |
| 82h <sup>(3)</sup>   | PCL        | Program C            | Counter (PC)    | Least Signif              | icant Byte     |               |                   |                |          | 0000 0000                | 26                     |
| 83h <sup>(3)</sup>   | STATUS     | IRP                  | RP1             | RP0                       | TO             | PD            | Z                 | DC             | С        | 0001 1xxx                | 18                     |
| 84h <sup>(3)</sup>   | FSR        | Indirect Da          | ata Memory A    | Address Poir              | nter           |               |                   |                |          | xxxx xxxx                | 27                     |
| 85h                  | TRISA      | _                    | -               | PORTA Da                  | ta Direction F | Register      |                   |                |          | 11 1111                  | 29                     |
| 86h                  | TRISB      | PORTB Da             | ata Direction   | Register                  |                |               |                   |                |          | 1111 1111                | 31                     |
| 87h                  | TRISC      | PORTC D              | ata Direction   | Register                  |                |               |                   |                |          | 1111 1111                | 33                     |
| 88h <sup>(4)</sup>   | TRISD      | PORTD D              | ata Direction   | Register                  |                |               |                   |                |          | 1111 1111                | 35                     |
| 89h <sup>(4)</sup>   | TRISE      | IBF                  | OBF             | IBOV                      | PSPMODE        | _             | PORTE Data        | Direction Bi   | ts       | 0000 -111                | 37                     |
| 8Ah <sup>(1,3)</sup> | PCLATH     | _                    |                 | 1                         | Write Buffer   | for the upper | r 5 bits of the F | Program Cou    | ınter    | 0 0000                   | 26                     |
| 8Bh <sup>(3)</sup>   | INTCON     | GIE                  | PEIE            | TOIE                      | INTE           | RBIE          | TOIF              | INTF           | RBIF     | 0000 000x                | 20                     |
| 8Ch                  | PIE1       | PSPIE <sup>(2)</sup> | ADIE            | RCIE                      | TXIE           | SSPIE         | CCP1IE            | TMR2IE         | TMR1IE   | 0000 0000                | 21                     |
| 8Dh                  | PIE2       | _                    | (5)             | _                         | EEIE           | BCLIE         | _                 | _              | CCP2IE   | -r-0 00                  | 23                     |
| 8Eh                  | PCON       |                      | 1               | I                         | _              |               | _                 | POR            | BOR      | qq                       | 25                     |
| 8Fh                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 90h                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 91h                  | SSPCON2    | GCEN                 | ACKSTAT         | ACKDT                     | ACKEN          | RCEN          | PEN               | RSEN           | SEN      | 0000 0000                | 68                     |
| 92h                  | PR2        | Timer2 Pe            | riod Register   |                           |                |               |                   |                |          | 1111 1111                | 55                     |
| 93h                  | SSPADD     | Synchrono            | ous Serial Po   | rt (I <sup>2</sup> C mode | ) Address Re   | gister        |                   |                |          | 0000 0000                | 73, 74                 |
| 94h                  | SSPSTAT    | SMP                  | CKE             | $D/\overline{A}$          | Р              | S             | R/W               | UA             | BF       | 0000 0000                | 66                     |
| 95h                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 96h                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 97h                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 98h                  | TXSTA      | CSRC                 | TX9             | TXEN                      | SYNC           | _             | BRGH              | TRMT           | TX9D     | 0000 -010                | 95                     |
| 99h                  | SPBRG      | Baud Rate            | Generator F     | Register                  |                |               |                   |                |          | 0000 0000                | 97                     |
| 9Ah                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 9Bh                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          |                          | _                      |
| 9Ch                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          | _                        | _                      |
| 9Dh                  | _          | Unimplem             | ented           |                           |                |               |                   |                |          |                          |                        |
| 9Eh                  | ADRESL     | A/D Resul            | t Register Lo   | w Byte                    |                |               |                   |                |          | xxxx xxxx                | 116                    |
| 9Fh                  | ADCON1     | ADFM                 | _               | _                         | _              | PCFG3         | PCFG2             | PCFG1          | PCFG0    | 0 0000                   | 112                    |

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved.

Shaded locations are unimplemented, read as '0'.

Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter.

2: Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear.

3: These registers can be addressed from any bank.

4: PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'.

5: PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear.

TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

| Address               | Name       | Bit 7       | Bit 6           | Bit 5         | Bit 4          | Bit 3         | Bit 2             | Bit 1          | Bit 0    | Value on:<br>POR,<br>BOR | Details<br>on<br>page: |
|-----------------------|------------|-------------|-----------------|---------------|----------------|---------------|-------------------|----------------|----------|--------------------------|------------------------|
| Bank 2                |            |             |                 |               |                |               |                   |                |          |                          |                        |
| 100h <sup>(3)</sup>   | INDF       | Addressing  | g this location | n uses conte  | nts of FSR to  | address data  | a memory (no      | t a physical r | egister) | 0000 0000                | 27                     |
| 101h                  | TMR0       | Timer0 Mo   | dule Registe    | er            |                |               |                   |                |          | xxxx xxxx                | 47                     |
| 102h <sup>(3)</sup>   | PCL        | Program C   | Counter's (PC   | ) Least Sign  | ificant Byte   |               |                   |                |          | 0000 0000                | 26                     |
| 103h <sup>(3)</sup>   | STATUS     | IRP         | RP1             | RP0           | TO             | PD            | Z                 | DC             | С        | 0001 1xxx                | 18                     |
| 104h <sup>(3)</sup>   | FSR        | Indirect Da | ata Memory A    | Address Poir  | iter           |               |                   |                |          | xxxx xxxx                | 27                     |
| 105h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        | _                      |
| 106h                  | PORTB      | PORTB Da    | ata Latch wh    | en written: P | ORTB pins w    | hen read      |                   |                |          | xxxx xxxx                | 31                     |
| 107h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        |                        |
| 108h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        |                        |
| 109h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        | _                      |
| 10Ah <sup>(1,3)</sup> | PCLATH     | _           |                 | _             | Write Buffer   | for the upper | r 5 bits of the I | Program Cou    | unter    | 0 0000                   | 26                     |
| 10Bh <sup>(3)</sup>   | INTCON     | GIE         | PEIE            | T0IE          | INTE           | RBIE          | TOIF              | INTF           | RBIF     | 0000 000x                | 20                     |
| 10Ch                  | EEDATA     | EEPROM      | Data Registe    | er Low Byte   |                |               |                   |                |          | xxxx xxxx                | 41                     |
| 10Dh                  | EEADR      | EEPROM      | Address Reg     | gister Low By | /te            |               |                   |                |          | xxxx xxxx                | 41                     |
| 10Eh                  | EEDATH     | _           |                 | EEPROM D      | ata Register   | High Byte     |                   |                |          | xxxx xxxx                | 41                     |
| 10Fh                  | EEADRH     | _           | _               | _             | EEPROM A       | ddress Regis  | ter High Byte     |                |          | xxxx xxxx                | 41                     |
| Bank 3                |            |             |                 |               |                |               |                   |                |          |                          |                        |
| 180h <sup>(3)</sup>   | INDF       | Addressing  | g this location | n uses conte  | nts of FSR to  | address data  | a memory (no      | t a physical r | egister) | 0000 0000                | 27                     |
| 181h                  | OPTION_REG | RBPU        | INTEDG          | T0CS          | T0SE           | PSA           | PS2               | PS1            | PS0      | 1111 1111                | 19                     |
| 182h <sup>(3)</sup>   | PCL        | Program C   | Counter (PC)    | Least Signi   | ficant Byte    |               |                   |                |          | 0000 0000                | 26                     |
| 183h <sup>(3)</sup>   | STATUS     | IRP         | RP1             | RP0           | TO             | PD            | Z                 | DC             | С        | 0001 1xxx                | 18                     |
| 184h <sup>(3)</sup>   | FSR        | Indirect Da | ata Memory A    | Address Poir  | iter           |               |                   |                |          | xxxx xxxx                | 27                     |
| 185h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        | _                      |
| 186h                  | TRISB      | PORTB Da    | ata Direction   | Register      |                |               |                   |                |          | 1111 1111                | 31                     |
| 187h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          | _                        | _                      |
| 188h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          |                          | 1                      |
| 189h                  | _          | Unimplem    | ented           |               |                |               |                   |                |          |                          | 1                      |
| 18Ah <sup>(1,3)</sup> | PCLATH     |             | 1               | 1             | Write Buffer   | for the upper | r 5 bits of the I | Program Cou    | unter    | 0 0000                   | 26                     |
| 18Bh <sup>(3)</sup>   | INTCON     | GIE         | PEIE            | T0IE          | INTE           | RBIE          | T0IF              | INTF           | RBIF     | 0000 000x                | 20                     |
| 18Ch                  | EECON1     | EEPGD       | _               | _             | _              | WRERR         | WREN              | WR             | RD       | x x000                   | 41, 42                 |
| 18Dh                  | EECON2     | EEPROM      | Control Regi    | ster2 (not a  | physical regis | ster)         |                   |                |          |                          | 41                     |
| 18Eh                  | _          | Reserved    | maintain clea   | ar            |                |               |                   |                |          | 0000 0000                | _                      |
| 18Fh                  | _          | Reserved    | maintain clea   | ar            |                |               |                   |                |          | 0000 0000                | _                      |

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'.

Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter.

- 2: Bits PSPIE and PSPIF are reserved on PIC16F873/876 devices; always maintain these bits clear.
- 3: These registers can be addressed from any bank.
- 4: PORTD, PORTE, TRISD, and TRISE are not physically implemented on PIC16F873/876 devices; read as '0'.
- 5: PIR2<6> and PIE2<6> are reserved on these devices; always maintain these bits clear.

#### 2.2.2.1 STATUS Register

The STATUS register contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, as with any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the  $\overline{\text{TO}}$  and  $\overline{\text{PD}}$  bits are not writable, therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as 000u uluu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect the Z, C or DC bits from the STATUS register. For other instructions not affecting any status bits, see the "Instruction Set Summary."

Note: The C and DC bits operate as a borrow and digit borrow bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

#### REGISTER 2-1: STATUS REGISTER (ADDRESS 03h, 83h, 103h, 183h)

| R/W-0 | R/W-0 | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x |
|-------|-------|-------|-----|-----|-------|-------|-------|
| IRP   | RP1   | RP0   | TO  | PD  | Z     | DC    | С     |
| bit 7 |       |       |     |     |       |       | bit 0 |

bit 7 IRP: Register Bank Select bit (used for indirect addressing)

1 = Bank 2, 3 (100h - 1FFh)

0 = Bank 0, 1 (00h - FFh)

bit 6-5 **RP1:RP0**: Register Bank Select bits (used for direct addressing)

11 = Bank 3 (180h - 1FFh)

10 = Bank 2 (100h - 17Fh)

01 = Bank 1 (80h - FFh)

00 = Bank 0 (00h - 7Fh)

Each bank is 128 bytes

bit 4 TO: Time-out bit

1 = After power-up, CLRWDT instruction, or SLEEP instruction

0 = A WDT time-out occurred

bit 3 **PD**: Power-down bit

1 = After power-up or by the CLRWDT instruction

0 = By execution of the SLEEP instruction

bit 2 Z: Zero bit

1 = The result of an arithmetic or logic operation is zero

0 = The result of an arithmetic or logic operation is not zero

bit 1 DC: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)

(for borrow, the polarity is reversed)

1 = A carry-out from the 4th low order bit of the result occurred

0 = No carry-out from the 4th low order bit of the result

bit 0 C: Carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)

1 = A carry-out from the Most Significant bit of the result occurred

0 = No carry-out from the Most Significant bit of the result occurred

**Note:** For borrow, the polarity is reversed. A subtraction is executed by adding the two's

complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high, or low order bit of the source register.

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

#### 2.2.2.2 OPTION\_REG Register

The OPTION\_REG Register is a readable and writable register, which contains various control bits to configure the TMR0 prescaler/WDT postscaler (single assignable register known also as the prescaler), the External INT Interrupt, TMR0 and the weak pull-ups on PORTB.

To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer.

#### REGISTER 2-2: OPTION REG REGISTER (ADDRESS 81h, 181h)

| R/W-1 | R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|--------|-------|-------|-------|-------|-------|-------|
| RBPU  | INTEDG | T0CS  | T0SE  | PSA   | PS2   | PS1   | PS0   |
| bit 7 |        |       |       |       |       |       | bit 0 |

Note:

bit 7 RBPU: PORTB Pull-up Enable bit

1 = PORTB pull-ups are disabled

0 = PORTB pull-ups are enabled by individual port latch values

bit 6 **INTEDG**: Interrupt Edge Select bit

1 = Interrupt on rising edge of RB0/INT pin

0 = Interrupt on falling edge of RB0/INT pin

bit 5 TOCS: TMR0 Clock Source Select bit

1 = Transition on RA4/T0CKI pin

0 = Internal instruction cycle clock (CLKOUT)

bit 4 T0SE: TMR0 Source Edge Select bit

1 = Increment on high-to-low transition on RA4/T0CKI pin

0 = Increment on low-to-high transition on RA4/T0CKI pin

1:128

bit 3 **PSA**: Prescaler Assignment bit

111

1 = Prescaler is assigned to the WDT

0 = Prescaler is assigned to the Timer0 module

bit 2-0 **PS2:PS0**: Prescaler Rate Select bits

| Bit Value | TMR0 Rate | WDT Rate |
|-----------|-----------|----------|
| 000       | 1:2       | 1:1      |
| 001       | 1:4       | 1:2      |
| 010       | 1:8       | 1:4      |
| 011       | 1:16      | 1:8      |
| 100       | 1:32      | 1:16     |
| 101       | 1 : 64    | 1 : 32   |
| 110       | 1 : 128   | 1 : 64   |

1:256

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

**Note:** When using low voltage ICSP programming (LVP) and the pull-ups on PORTB are enabled, bit 3 in the TRISB register must be cleared to disable the pull-up on RB3 and ensure the proper operation of the device

#### 2.2.2.3 INTCON Register

The INTCON Register is a readable and writable register, which contains various enable and flag bits for the TMR0 register overflow, RB Port change and External RB0/INT pin interrupts.

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

#### REGISTER 2-3: INTCON REGISTER (ADDRESS 0Bh, 8Bh, 10Bh, 18Bh)

| R/W-0 | R/W-x |
|-------|-------|-------|-------|-------|-------|-------|-------|
| GIE   | PEIE  | T0IE  | INTE  | RBIE  | T0IF  | INTF  | RBIF  |
| bit 7 |       |       |       |       |       |       | bit 0 |

Note:

bit 7 GIE: Global Interrupt Enable bit

1 = Enables all unmasked interrupts

0 = Disables all interrupts

bit 6 **PEIE**: Peripheral Interrupt Enable bit

1 = Enables all unmasked peripheral interrupts

0 = Disables all peripheral interrupts

bit 5 **T0IE**: TMR0 Overflow Interrupt Enable bit

1 = Enables the TMR0 interrupt 0 = Disables the TMR0 interrupt

bit 4 INTE: RB0/INT External Interrupt Enable bit

1 = Enables the RB0/INT external interrupt

0 = Disables the RB0/INT external interrupt

bit 3 RBIE: RB Port Change Interrupt Enable bit

1 = Enables the RB port change interrupt

0 = Disables the RB port change interrupt

bit 2 **T0IF**: TMR0 Overflow Interrupt Flag bit

1 = TMR0 register has overflowed (must be cleared in software)

0 = TMR0 register did not overflow

bit 1 INTF: RB0/INT External Interrupt Flag bit

1 = The RB0/INT external interrupt occurred (must be cleared in software)

0 = The RB0/INT external interrupt did not occur

bit 0 RBIF: RB Port Change Interrupt Flag bit

1 = At least one of the RB7:RB4 pins changed state; a mismatch condition will continue to set the bit. Reading PORTB will end the mismatch condition and allow the bit to be cleared (must be cleared in software).

0 = None of the RB7:RB4 pins have changed state

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

#### 2.2.2.4 PIE1 Register

The PIE1 register contains the individual enable bits for the peripheral interrupts. **Note:** Bit PEIE (INTCON<6>) must be set to enable any peripheral interrupt.

#### REGISTER 2-4: PIE1 REGISTER (ADDRESS 8Ch)

| R/W-0                | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|----------------------|-------|-------|-------|-------|--------|--------|--------|
| PSPIE <sup>(1)</sup> | ADIE  | RCIE  | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE |
| bit 7                |       |       |       |       |        |        | bit 0  |

bit 7 **PSPIE**(1): Parallel Slave Port Read/Write Interrupt Enable bit

1 = Enables the PSP read/write interrupt

0 = Disables the PSP read/write interrupt

bit 6 ADIE: A/D Converter Interrupt Enable bit

1 = Enables the A/D converter interrupt

0 =Disables the A/D converter interrupt

bit 5 RCIE: USART Receive Interrupt Enable bit

1 =Enables the USART receive interrupt

0 = Disables the USART receive interrupt

bit 4 **TXIE**: USART Transmit Interrupt Enable bit

1 = Enables the USART transmit interrupt

0 = Disables the USART transmit interrupt

bit 3 SSPIE: Synchronous Serial Port Interrupt Enable bit

1 = Enables the SSP interrupt

0 = Disables the SSP interrupt

bit 2 CCP1IE: CCP1 Interrupt Enable bit

1 = Enables the CCP1 interrupt

0 = Disables the CCP1 interrupt

bit 1 TMR2IE: TMR2 to PR2 Match Interrupt Enable bit

1 = Enables the TMR2 to PR2 match interrupt

0 = Disables the TMR2 to PR2 match interrupt

bit 0 TMR1IE: TMR1 Overflow Interrupt Enable bit

1 = Enables the TMR1 overflow interrupt

0 = Disables the TMR1 overflow interrupt

Note 1: PSPIE is reserved on PIC16F873/876 devices; always maintain this bit clear.

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

#### 2.2.2.5 PIR1 Register

The PIR1 register contains the individual flag bits for the peripheral interrupts. Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt bits are clear prior to enabling an interrupt.

#### REGISTER 2-5: PIR1 REGISTER (ADDRESS 0Ch)

| R/W-0                | R/W-0 | R-0  | R-0  | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|----------------------|-------|------|------|-------|--------|--------|--------|
| PSPIF <sup>(1)</sup> | ADIF  | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF |
| bit 7                |       |      |      |       |        |        | bit 0  |

Note:

- bit 7 **PSPIF**<sup>(1)</sup>: Parallel Slave Port Read/Write Interrupt Flag bit
  - 1 = A read or a write operation has taken place (must be cleared in software)
  - 0 = No read or write has occurred
- bit 6 ADIF: A/D Converter Interrupt Flag bit
  - 1 = An A/D conversion completed
  - 0 = The A/D conversion is not complete
- bit 5 RCIF: USART Receive Interrupt Flag bit
  - 1 = The USART receive buffer is full 0 = The USART receive buffer is empty
- bit 4 TXIF: USART Transmit Interrupt Flag bit
  - 1 = The USART transmit buffer is empty
  - 0 = The USART transmit buffer is full
- bit 3 SSPIF: Synchronous Serial Port (SSP) Interrupt Flag
  - 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:
    - SPI
      - A transmission/reception has taken place.
    - I<sup>2</sup>C Slave
      - A transmission/reception has taken place.
    - I<sup>2</sup>C Master
      - A transmission/reception has taken place.
      - The initiated START condition was completed by the SSP module.
      - The initiated STOP condition was completed by the SSP module.
      - The initiated Restart condition was completed by the SSP module.
      - The initiated Acknowledge condition was completed by the SSP module.
      - A START condition occurred while the SSP module was idle (Multi-Master system).
      - A STOP condition occurred while the SSP module was idle (Multi-Master system).
  - 0 = No SSP interrupt condition has occurred.

#### bit 2 CCP1IF: CCP1 Interrupt Flag bit

#### Capture mode:

- 1 = A TMR1 register capture occurred (must be cleared in software)
- 0 = No TMR1 register capture occurred

#### Compare mode:

- 1 = A TMR1 register compare match occurred (must be cleared in software)
- 0 = No TMR1 register compare match occurred

#### PWM mode:

Unused in this mode

- bit 1 TMR2IF: TMR2 to PR2 Match Interrupt Flag bit
  - 1 = TMR2 to PR2 match occurred (must be cleared in software)
  - 0 = No TMR2 to PR2 match occurred
- bit 0 TMR1IF: TMR1 Overflow Interrupt Flag bit
  - 1 = TMR1 register overflowed (must be cleared in software)
  - 0 = TMR1 register did not overflow

Note 1: PSPIF is reserved on PIC16F873/876 devices; always maintain this bit clear.

| Legend |  |
|--------|--|
|--------|--|

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

#### 2.2.2.6 PIE2 Register

The PIE2 register contains the individual enable bits for the CCP2 peripheral interrupt, the SSP bus collision interrupt, and the EEPROM write operation interrupt.

#### REGISTER 2-6: PIE2 REGISTER (ADDRESS 8Dh)

| U-0   | R/W-0    | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0  |
|-------|----------|-----|-------|-------|-----|-----|--------|
| _     | Reserved | _   | EEIE  | BCLIE | _   | _   | CCP2IE |
| bit 7 |          |     |       |       |     |     | bit 0  |

bit 7 Unimplemented: Read as '0'

bit 6 Reserved: Always maintain this bit clear

bit 5 Unimplemented: Read as '0'

bit 4 **EEIE**: EEPROM Write Operation Interrupt Enable

1 = Enable EE Write Interrupt0 = Disable EE Write Interrupt

bit 3 BCLIE: Bus Collision Interrupt Enable

1 = Enable Bus Collision Interrupt

0 = Disable Bus Collision Interrupt

bit 2-1 Unimplemented: Read as '0'

bit 0 CCP2IE: CCP2 Interrupt Enable bit

1 = Enables the CCP2 interrupt

0 = Disables the CCP2 interrupt

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

#### 2.2.2.7 PIR2 Register

The PIR2 register contains the flag bits for the CCP2 interrupt, the SSP bus collision interrupt and the EEPROM write operation interrupt.

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

#### REGISTER 2-7: PIR2 REGISTER (ADDRESS 0Dh)

| U-0   | R/W-0    | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0  |
|-------|----------|-----|-------|-------|-----|-----|--------|
| _     | Reserved | _   | EEIF  | BCLIF | _   | 1   | CCP2IF |
| bit 7 |          |     |       |       |     |     | bit 0  |

bit 7 **Unimplemented:** Read as '0'

bit 6 Reserved: Always maintain this bit clear

bit 5 Unimplemented: Read as '0'

bit 4 **EEIF**: EEPROM Write Operation Interrupt Flag bit

1 = The write operation completed (must be cleared in software)
 0 = The write operation is not complete or has not been started

bit 3 BCLIF: Bus Collision Interrupt Flag bit

1 = A bus collision has occurred in the SSP, when configured for I2C Master mode

0 = No bus collision has occurred

bit 2-1 Unimplemented: Read as '0'

bit 0 CCP2IF: CCP2 Interrupt Flag bit

Capture mode:

1 = A TMR1 register capture occurred (must be cleared in software)

0 = No TMR1 register capture occurred

Compare mode:

1 = A TMR1 register compare match occurred (must be cleared in software)

0 = No TMR1 register compare match occurred

PWM mode: Unused

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'

#### 2.2.2.8 PCON Register

The Power Control (PCON) Register contains flag bits to allow differentiation between a Power-on Reset (POR), a Brown-out Reset (BOR), a Watchdog Reset (WDT), and an external  $\overline{\text{MCLR}}$  Reset.

Note: BOR is unknown on POR. It must be set by the user and checked on subsequent RESETS to see if BOR is clear, indicating a brown-out has occurred. The BOR status bit is a "don't care" and is not predictable if the brown-out circuit is disabled (by clearing the BODEN bit in the configuration word).

#### REGISTER 2-8: PCON REGISTER (ADDRESS 8Eh)

|   | U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-1 |
|---|-------|-----|-----|-----|-----|-----|-------|-------|
|   | _     | _   | _   | _   | _   | _   | POR   | BOR   |
| - | bit 7 |     |     |     |     |     |       | bit 0 |

bit 7-2

Dimplemented: Read as '0'

POR: Power-on Reset Status bit

1 = No Power-on Reset occurred

0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs)

bit 0 **BOR**: Brown-out Reset Status bit 1 = No Brown-out Reset occurred

0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs)

Legend:

R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'