



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

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

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

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                    |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                           |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                       |
| Number of I/O              | 22                                                                          |
| Program Memory Size        | 14KB (8K x 14)                                                              |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 256 x 8                                                                     |
| RAM Size                   | 368 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                   |
| Data Converters            | A/D 5x10b                                                                   |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Through Hole                                                                |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                     |
| Supplier Device Package    | 28-SPDIP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf876-04i-sp |

#### **Pin Diagrams**



#### **Table of Contents**

| 1.0              | Device Overview                                                             | 5   |
|------------------|-----------------------------------------------------------------------------|-----|
| 2.0              | Memory Organization                                                         | 11  |
| 3.0              | I/O Ports                                                                   |     |
| 4.0              | Data EEPROM and FLASH Program Memory                                        | 41  |
| 5.0              | Timer0 Module                                                               | 47  |
| 6.0              | Timer1 Module                                                               | 51  |
| 7.0              | Timer2 Module                                                               | 55  |
| 8.0              | Capture/Compare/PWM Modules                                                 | 57  |
| 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 |
| 12.0             | Special Features of the CPU                                                 | 119 |
| 13.0             | Instruction Set Summary                                                     | 135 |
| 14.0             | Development Support                                                         | 143 |
|                  | Electrical Characteristics                                                  |     |
|                  | DC and AC Characteristics Graphs and Tables                                 |     |
| 17.0             | Packaging Information                                                       | 189 |
|                  | endix A: Revision History                                                   |     |
| Appe             | endix B: Device Differences                                                 | 197 |
| Appe             | endix C: Conversion Considerations                                          | 198 |
|                  | (                                                                           |     |
|                  | ine Support                                                                 |     |
|                  | der Response                                                                | 208 |
| PIC <sub>1</sub> | 6F87X Product Identification System                                         | 209 |

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

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

| RCO/T1CKI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Pin Name        | DIP<br>Pin# | PLCC<br>Pin# | QFP<br>Pin# | I/O/P<br>Type | Buffer<br>Type        | Description                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|--------------|-------------|---------------|-----------------------|----------------------------------------------|
| RC1/T10SI/CCP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |             |              |             |               |                       | PORTC is a bi-directional I/O port.          |
| RC2/CCP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RC0/T1OSO/T1CKI | 15          | 16           | 32          | I/O           | ST                    | ·                                            |
| RC3/SCK/SCL   18   20   37   1/0   ST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RC1/T1OSI/CCP2  | 16          | 18           | 35          | I/O           | ST                    |                                              |
| RC4/SDI/SDA   23   25   42   1/0   ST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RC2/CCP1        | 17          | 19           | 36          | I/O           | ST                    |                                              |
| RC5/SDO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RC3/SCK/SCL     | 18          | 20           | 37          | I/O           | ST                    |                                              |
| RC6/TX/CK         25         27         44         I/O         ST         RC6 can also be the USART Asynchronous Transmit or Synchronous Clock.           RC7/RX/DT         26         29         1         I/O         ST         RC7 can also be the USART Asynchronous Receive or Synchronous Data.           RD0/PSP0         19         21         38         I/O         ST/TTL(3)         PORTD is a bi-directional I/O port or parallel slave port when interfacing to a microprocessor bus.           RD1/PSP1         20         22         39         I/O         ST/TTL(3)         PORTD is a bi-directional I/O port or parallel slave port when interfacing to a microprocessor bus.           RD1/PSP1         20         22         39         I/O         ST/TTL(3)           RD2/PSP2         21         23         40         I/O         ST/TTL(3)           RD4/PSP4         27         30         2         I/O         ST/TTL(3)           RD6/PSP5         28         31         3         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 can also be write control for the parallel slave port, or analog input5.           RE1/WR/AN | RC4/SDI/SDA     | 23          | 25           | 42          | I/O           | ST                    |                                              |
| 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                    | •                                            |
| 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)         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.           NC         —         1,17,28,         12,13,         —         Positive supply for logic and I/O pins.                                                              |                 |             |              |             |               |                       |                                              |
| 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 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                | 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)         ST/TTL(3)         RD6/PSP6         29         32         4         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                               | 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 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                                                  | RD2/PSP2        | 21          | 23           | 40          | I/O           | ST/TTL <sup>(3)</sup> |                                              |
| 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         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                                                                                                                                                                         | 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)         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 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/CS/AN7  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.  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.  These pins are not internally connected. These pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RD6/PSP6        | 29          | 32           | 4           | I/O           |                       |                                              |
| 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, 12,13, 12,13, 13, 12,13, 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 input5.  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, — 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 <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  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, 12,13, 12,13, 13, 14,13, 14,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, 12,13, 12,13, 12,13, 12,13, 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.      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | NC              | _           |              |             |               | _                     | · · · · · · · · · · · · · · · · · · ·        |

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.

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

TABLE 5-1: REGISTERS ASSOCIATED WITH TIMERO

| Address               | Name       | Bit 7  | Bit 6      | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-----------------------|------------|--------|------------|---------|-------|-------|-------|-------|-------|--------------------------|---------------------------------|
| 01h,101h              | TMR0       | Timer0 | Module's F | Registe | -     |       |       |       |       | xxxx xxxx                | uuuu uuuu                       |
| 0Bh,8Bh,<br>10Bh,18Bh | INTCON     | GIE    | PEIE       | TOIE    | INTE  | RBIE  | TOIF  | INTF  | RBIF  | 0000 000x                | 0000 000u                       |
| 81h,181h              | OPTION_REG | RBPU   | INTEDG     | T0CS    | T0SE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                | 1111 1111                       |

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

#### 7.1 Timer2 Prescaler and Postscaler

The prescaler and postscaler counters are cleared when any of the following occurs:

- a write to the TMR2 register
- a write to the T2CON register
- any device RESET (POR, MCLR Reset, WDT Reset, or BOR)

TMR2 is not cleared when T2CON is written.

### 7.2 Output of TMR2

The output of TMR2 (before the postscaler) is fed to the SSP module, which optionally uses it to generate shift clock

#### TABLE 7-1: REGISTERS ASSOCIATED WITH TIMER2 AS A TIMER/COUNTER

| Address               | Name                       | Bit 7                | Bit 6          | Bit 5   | Bit 4     | Bit 3     | Bit 2  | Bit 1   | Bit 0   | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-----------------------|----------------------------|----------------------|----------------|---------|-----------|-----------|--------|---------|---------|--------------------------|---------------------------------|
| 0Bh,8Bh,<br>10Bh,18Bh | INTCON                     | GIE                  | PEIE           | TOIE    | INTE      | RBIE      | T0IF   | INTF    | RBIF    | 0000 000x                | 0000 000u                       |
| 0Ch                   | PIR1                       | PSPIF <sup>(1)</sup> | ADIF           | RCIF    | TXIF      | SSPIF     | CCP1IF | TMR2IF  | TMR1IF  | 0000 0000                | 0000 0000                       |
| 8Ch                   | PIE1                       | PSPIE <sup>(1)</sup> | ADIE           | RCIE    | TXIE      | SSPIE     | CCP1IE | TMR2IE  | TMR1IE  | 0000 0000                | 0000 0000                       |
| 11h                   | TMR2                       | Timer2 Mod           | dule's Registe |         | 0000 0000 | 0000 0000 |        |         |         |                          |                                 |
| 12h                   | T2CON                      | _                    | TOUTPS3        | TOUTPS2 | TOUTPS1   | TOUTPS0   | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000                | -000 0000                       |
| 92h                   | PR2 Timer2 Period Register |                      |                |         |           |           |        |         |         |                          | 1111 1111                       |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Timer2 module. **Note 1:** Bits PSPIE and PSPIF are reserved on the PIC16F873/876; always maintain these bits clear.

#### 9.1.1 MASTER MODE

The master can initiate the data transfer at any time because it controls the SCK. The master determines when the slave (Processor 2, Figure 9-5) is to broadcast data by the software protocol.

In Master mode, the data is transmitted/received as soon as the SSPBUF register is written to. If the SPI module is only going to receive, the SDO output could be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPBUF register as if a normal received byte (interrupts and status bits appropriately set). This could be useful in receiver applications as a "line activity monitor".

The clock polarity is selected by appropriately programming bit CKP (SSPCON<4>). This then, would give waveforms for SPI communication as shown in

Figure 9-6, Figure 9-8 and Figure 9-9, where the MSb is transmitted first. In Master mode, the SPI clock rate (bit rate) is user programmable to be one of the following:

- Fosc/4 (or Tcy)
- Fosc/16 (or 4 Tcy)
- Fosc/64 (or 16 Tcy)
- Timer2 output/2

This allows a maximum bit clock frequency (at 20 MHz) of 5.0 MHz.

Figure 9-6 shows the waveforms for Master mode. When CKE = 1, the SDO data is valid before there is a clock edge on SCK. The change of the input sample is shown based on the state of the SMP bit. The time when the SSPBUF is loaded with the received data is shown.





TABLE 9-1: REGISTERS ASSOCIATED WITH SPI OPERATION

| Address                | Name    | Bit 7                | Bit 6      | Bit 5      | Bit 4    | Bit 3     | Bit 2       | Bit 1  | Bit 0  | Value on:<br>POR, BOR | Value on:<br>MCLR, WDT |
|------------------------|---------|----------------------|------------|------------|----------|-----------|-------------|--------|--------|-----------------------|------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh | INTCON  | GIE                  | PEIE       | TOIE       | INTE     | RBIE      | TOIF        | INTF   | RBIF   | 0000 000x             | 0000 000u              |
| 0Ch                    | PIR1    | PSPIF <sup>(1)</sup> | ADIF       | RCIF       | TXIF     | SSPIF     | CCP1IF      | TMR2IF | TMR1IF | 0000 0000             | 0000 0000              |
| 8Ch                    | PIE1    | PSPIE <sup>(1)</sup> | ADIE       | RCIE       | TXIE     | SSPIE     | CCP1IE      | TMR2IE | TMR1IE | 0000 0000             | 0000 0000              |
| 13h                    | SSPBUF  | Synchrono            | ous Serial | Port Recei | ive Buff | er/Transm | it Register |        |        | xxxx xxxx             | uuuu uuuu              |
| 14h                    | SSPCON  | WCOL                 | SSPOV      | SSPEN      | CKP      | SSPM3     | SSPM2       | SSPM1  | SSPM0  | 0000 0000             | 0000 0000              |
| 94h                    | SSPSTAT | SMP                  | CKE        | D/A        | Р        | S         | R/W         | UA     | BF     | 0000 0000             | 0000 0000              |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the SSP in SPI mode.

Note 1: These bits are reserved on PCI16F873/876 devices; always maintain these bits clear.

#### 9.2.5 MASTER MODE

Master mode of operation is supported by interrupt generation on the detection of the START and STOP conditions. The STOP (P) and START (S) bits are cleared from a RESET, or when the MSSP module is disabled. Control of the I<sup>2</sup>C bus may be taken when the P bit is set, or the bus is idle, with both the S and P bits clear

In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.

The following events will cause the SSP Interrupt Flag bit, SSPIF, to be set (an SSP interrupt will occur if enabled):

- · START condition
- STOP condition
- Data transfer byte transmitted/received
- · Acknowledge transmit
- · Repeated START

FIGURE 9-9: SSP BLOCK DIAGRAM (I<sup>2</sup>C MASTER MODE)



#### 9.2.6 MULTI-MASTER MODE

In Multi-Master mode, the interrupt generation on the detection of the START and STOP conditions allows the determination of when the bus is free. The STOP (P) and START (S) bits are cleared from a RESET or when the MSSP module is disabled. Control of the I<sup>2</sup>C bus may be taken when bit P (SSPSTAT<4>) is set, or the bus is idle with both the S and P bits clear. When the bus is busy, enabling the SSP Interrupt will generate the interrupt when the STOP condition occurs.

In Multi-Master operation, the SDA line must be monitored for arbitration to see if the signal level is the expected output level. This check is performed in hardware, with the result placed in the BCLIF bit.

The states where arbitration can be lost are:

- · Address Transfer
- · Data Transfer
- · A START Condition
- A Repeated START Condition
- · An Acknowledge Condition



## 9.3 Connection Considerations for I<sup>2</sup>C Bus

For standard-mode  $I^2C$  bus devices, the values of resistors  $R_p$  and  $R_s$  in Figure 9-27 depend on the following parameters:

- · Supply voltage
- · Bus capacitance
- Number of connected devices (input current + leakage current)

The supply voltage limits the minimum value of resistor  $R_p$ , due to the specified minimum sink current of 3 mA at Vol max = 0.4V, for the specified output stages. For

example, with a supply voltage of VDD =  $5V\pm10\%$  and VOL max = 0.4V at 3 mA,  $R_p$  min = (5.5-0.4)/0.003 = 1.7 k $\Omega$ . VDD as a function of  $R_p$  is shown in Figure 9-27. The desired noise margin of 0.1VDD for the low level limits the maximum value of  $R_s$ . Series resistors are optional and used to improve ESD susceptibility.

The bus capacitance is the total capacitance of wire, connections, and pins. This capacitance limits the maximum value of  $R_p$  due to the specified rise time (Figure 9-27).

The SMP bit is the slew rate control enabled bit. This bit is in the SSPSTAT register, and controls the slew rate of the I/O pins when in I<sup>2</sup>C mode (master or slave).

#### FIGURE 9-27: SAMPLE DEVICE CONFIGURATION FOR I<sup>2</sup>C BUS



**Note:** I<sup>2</sup>C devices with input levels related to VDD must have one common supply line to which the pull-up resistor is also connected.

# 10.0 ADDRESSABLE UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (USART)

The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules. (USART is also known as a Serial Communications Interface or SCI.) The USART can be configured as a full duplex asynchronous system that can communicate with peripheral devices such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral devices such as A/D or D/A integrated circuits, serial EEPROMs etc.

The USART can be configured in the following modes:

- · Asynchronous (full duplex)
- Synchronous Master (half duplex)
- Synchronous Slave (half duplex)

Bit SPEN (RCSTA<7>) and bits TRISC<7:6> have to be set in order to configure pins RC6/TX/CK and RC7/RX/DT as the Universal Synchronous Asynchronous Receiver Transmitter.

The USART module also has a multi-processor communication capability using 9-bit address detection.

#### REGISTER 10-1: TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS 98h)

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R-1  | R/W-0 |
|-------|-------|-------|-------|-----|-------|------|-------|
| CSRC  | TX9   | TXEN  | SYNC  | _   | BRGH  | TRMT | TX9D  |
| bit 7 |       |       |       |     |       |      | bit 0 |

bit 7 CSRC: Clock Source Select bit

Asynchronous mode:

Don't care

Synchronous mode:

1 = Master mode (clock generated internally from BRG)

0 = Slave mode (clock from external source)

bit 6 TX9: 9-bit Transmit Enable bit

1 =Selects 9-bit transmission

0 = Selects 8-bit transmission

bit 5 TXEN: Transmit Enable bit

1 = Transmit enabled

0 = Transmit disabled

Note: SREN/CREN overrides TXEN in SYNC mode.

bit 4 SYNC: USART Mode Select bit

1 = Synchronous mode

0 = Asynchronous mode

bit 3 Unimplemented: Read as '0'

bit 2 BRGH: High Baud Rate Select bit

Asynchronous mode:

1 = High speed

0 = Low speed

Synchronous mode:

Unused in this mode

bit 1 TRMT: Transmit Shift Register Status bit

1 = TSR empty

0 = TSR full

bit 0 **TX9D:** 9th bit of Transmit Data, can be parity bit

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

## 10.3 USART Synchronous Master Mode

In Synchronous Master mode, the data is transmitted in a half-duplex manner (i.e., transmission and reception do not occur at the same time). When transmitting data, the reception is inhibited and vice versa. Synchronous mode is entered by setting bit SYNC (TXSTA<4>). In addition, enable bit SPEN (RCSTA<7>) is set in order to configure the RC6/TX/CK and RC7/RX/DT I/O pins to CK (clock) and DT (data) lines, respectively. The Master mode indicates that the processor transmits the master clock on the CK line. The Master mode is entered by setting bit CSRC (TXSTA<7>).

## 10.3.1 USART SYNCHRONOUS MASTER TRANSMISSION

The USART transmitter block diagram is shown in Figure 10-6. The heart of the transmitter is the transmit (serial) shift register (TSR). The shift register obtains its data from the read/write transmit buffer register TXREG. The TXREG register is loaded with data in software. The TSR register is not loaded until the last bit has been transmitted from the previous load. As soon as the last bit is transmitted, the TSR is loaded with new data from the TXREG (if available). Once the TXREG register transfers the data to the TSR register (occurs in one Tcycle), the TXREG is empty and interrupt bit TXIF (PIR1<4>) is set. The interrupt can be enabled/disabled by setting/clearing enable bit TXIE (PIE1<4>). Flag bit TXIF will be set, regardless of the state of enable bit TXIE and cannot be cleared in software. It will reset only when new data is loaded into the TXREG register. While flag bit TXIF indicates the status of the TXREG register, another bit TRMT (TXSTA<1>) shows the status of the TSR register. TRMT is a read only bit which is set when the TSR is empty. No interrupt logic is tied to this bit, so the user has to poll this bit in order to determine if the TSR register is empty. The TSR is not mapped in data memory, so it is not available to the user.

Transmission is enabled by setting enable bit TXEN (TXSTA<5>). The actual transmission will not occur until the TXREG register has been loaded with data. The first data bit will be shifted out on the next available rising edge of the clock on the CK line. Data out is stable around the falling edge of the synchronous clock (Figure 10-9). The transmission can also be started by first loading the TXREG register and then setting bit TXEN (Figure 10-10). This is advantageous when slow baud rates are selected, since the BRG is kept in RESET when bits TXEN, CREN and SREN are clear. Setting enable bit TXEN will start the BRG, creating a shift clock immediately. Normally, when transmission is first started, the TSR register is empty, so a transfer to the TXREG register will result in an immediate transfer to TSR, resulting in an empty TXREG. Back-to-back transfers are possible.

Clearing enable bit TXEN during a transmission will cause the transmission to be aborted and will reset the transmitter. The DT and CK pins will revert to hiimpedance. If either bit CREN or bit SREN is set during a transmission, the transmission is aborted and the DT pin reverts to a hi-impedance state (for a reception). The CK pin will remain an output if bit CSRC is set (internal clock). The transmitter logic, however, is not reset, although it is disconnected from the pins. In order to reset the transmitter, the user has to clear bit TXEN. If bit SREN is set (to interrupt an on-going transmission and receive a single word), then after the single word is received, bit SREN will be cleared and the serial port will revert back to transmitting, since bit TXEN is still set. The DT line will immediately switch from hiimpedance Receive mode to transmit and start driving. To avoid this, bit TXEN should be cleared.

In order to select 9-bit transmission, the TX9 (TXSTA<6>) bit should be set and the ninth bit should be written to bit TX9D (TXSTA<0>). The ninth bit must be written before writing the 8-bit data to the TXREG register. This is because a data write to the TXREG can result in an immediate transfer of the data to the TSR register (if the TSR is empty). If the TSR was empty and the TXREG was written before writing the "new" TX9D, the "present" value of bit TX9D is loaded.

Steps to follow when setting up a Synchronous Master Transmission:

- 1. Initialize the SPBRG register for the appropriate baud rate (Section 10.1).
- Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 3. If interrupts are desired, set enable bit TXIE.
- 4. If 9-bit transmission is desired, set bit TX9.
- 5. Enable the transmission by setting bit TXEN.
- If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D.
- Start transmission by loading data to the TXREG register.
- 8. If using interrupts, ensure that GIE and PEIE (bits 7 and 6) of the INTCON register are set.

TABLE 13-2: PIC16F87X INSTRUCTION SET

| Mnemonic, |      | Description                  | Cycles  |        | 14-Bit ( | Opcode | )    | Status   | Notes  |
|-----------|------|------------------------------|---------|--------|----------|--------|------|----------|--------|
| Opera     | ands | Description                  | Cycles  | MSb    |          |        | LSb  | Affected | 140103 |
|           |      | BYTE-ORIENTED FILE REGIS     | TER OPE | RATIO  | NS       |        |      |          |        |
| ADDWF     | f, d | Add W and f                  | 1       | 00     | 0111     | dfff   | ffff | C,DC,Z   | 1,2    |
| ANDWF     | f, d | AND W with f                 | 1       | 0.0    | 0101     | dfff   | ffff | Z        | 1,2    |
| CLRF      | f    | Clear f                      | 1       | 00     | 0001     | lfff   | ffff | Z        | 2      |
| CLRW      | -    | Clear W                      | 1       | 00     | 0001     | 0xxx   | xxxx | Z        |        |
| COMF      | f, d | Complement f                 | 1       | 0.0    | 1001     | dfff   | ffff | Z        | 1,2    |
| DECF      | f, d | Decrement f                  | 1       | 00     | 0011     | dfff   | ffff | Z        | 1,2    |
| DECFSZ    | f, d | Decrement f, Skip if 0       | 1(2)    | 00     | 1011     | dfff   | ffff |          | 1,2,3  |
| INCF      | f, d | Increment f                  | 1       | 00     | 1010     | dfff   | ffff | Z        | 1,2    |
| INCFSZ    | f, d | Increment f, Skip if 0       | 1(2)    | 00     | 1111     | dfff   | ffff |          | 1,2,3  |
| IORWF     | f, d | Inclusive OR W with f        | 1       | 00     | 0100     | dfff   | ffff | Z        | 1,2    |
| MOVF      | f, d | Move f                       | 1       | 00     | 1000     | dfff   | ffff | Z        | 1,2    |
| MOVWF     | f    | Move W to f                  | 1       | 00     | 0000     | lfff   | ffff |          |        |
| NOP       | -    | No Operation                 | 1       | 0.0    | 0000     | 0xx0   | 0000 |          |        |
| RLF       | f, d | Rotate Left f through Carry  | 1       | 0.0    | 1101     | dfff   | ffff | С        | 1,2    |
| RRF       | f, d | Rotate Right f through Carry | 1       | 0.0    | 1100     | dfff   | ffff | С        | 1,2    |
| SUBWF     | f, d | Subtract W from f            | 1       | 00     | 0010     | dfff   | ffff | C,DC,Z   | 1,2    |
| SWAPF     | f, d | Swap nibbles in f            | 1       | 0.0    | 1110     | dfff   | ffff | -, -,    | 1,2    |
| XORWF     | f, d | Exclusive OR W with f        | 1       | 00     | 0110     | dfff   | ffff | Z        | 1,2    |
|           |      | BIT-ORIENTED FILE REGIST     | ER OPER | RATION | NS       |        |      |          |        |
| BCF       | f, b | Bit Clear f                  | 1       | 01     | 00bb     | bfff   | ffff |          | 1,2    |
| BSF       | f, b | Bit Set f                    | 1       | 01     | 01bb     | bfff   | ffff |          | 1,2    |
| BTFSC     | f, b | Bit Test f, Skip if Clear    | 1 (2)   | 01     | 10bb     | bfff   | ffff |          | 3      |
| BTFSS     | f, b | Bit Test f, Skip if Set      | 1 (2)   | 01     | 11bb     | bfff   | ffff |          | 3      |
|           |      | LITERAL AND CONTROL          | OPERATI | ONS    |          |        |      |          |        |
| ADDLW     | k    | Add literal and W            | 1       | 11     | 111x     | kkkk   | kkkk | C,DC,Z   |        |
| ANDLW     | k    | AND literal with W           | 1       | 11     | 1001     | kkkk   | kkkk | Z        |        |
| CALL      | k    | Call subroutine              | 2       | 10     | 0kkk     | kkkk   | kkkk |          |        |
| CLRWDT    | -    | Clear Watchdog Timer         | 1       | 00     | 0000     | 0110   | 0100 | TO,PD    |        |
| GOTO      | k    | Go to address                | 2       | 10     | 1kkk     | kkkk   | kkkk |          |        |
| IORLW     | k    | Inclusive OR literal with W  | 1       | 11     | 1000     | kkkk   | kkkk | Z        |        |
| MOVLW     | k    | Move literal to W            | 1       | 11     | 00xx     | kkkk   | kkkk |          |        |
| RETFIE    | -    | Return from interrupt        | 2       | 0.0    | 0000     | 0000   | 1001 |          |        |
| RETLW     | k    | Return with literal in W     | 2       | 11     | 01xx     | kkkk   | kkkk |          |        |
| RETURN    | -    | Return from Subroutine       | 2       | 0.0    | 0000     | 0000   | 1000 |          |        |
| SLEEP     | -    | Go into standby mode         | 1       | 0.0    | 0000     | 0110   | 0011 | TO,PD    |        |
| SUBLW     | k    | Subtract W from literal      | 1       | 11     | 110x     | kkkk   | kkkk | C,DC,Z   |        |
| XORLW     | k    | Exclusive OR literal with W  | 1       | 11     | 1010     | kkkk   | kkkk | Z        |        |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

**Note:** Additional information on the mid-range instruction set is available in the PIC<sup>®</sup> MCU Mid-Range Family Reference Manual (DS33023).

<sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module.

<sup>3:</sup> If Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

TABLE 14-1: DEVELOPMENT TOOLS FROM MICROCHIP

© 1998-2013 Microchip Technology Inc.

**NOTES:** 

TABLE 15-9: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Param<br>No. | Sym     | Characte               | eristic      | Min        | Max  | Units | Conditions                                  |
|--------------|---------|------------------------|--------------|------------|------|-------|---------------------------------------------|
| 100          | Thigh   | Clock high time        | 100 kHz mode | 4.0        | _    | μ\$   | Device must operate at a minimum of 1.5 MHz |
|              |         |                        | 400 kHz mode | 0.6        | _    | μS    | Device must operate at a minimum of 10 MHz  |
|              |         |                        | SSP Module   | 0.5Tcy     | _    |       |                                             |
| 101          | Tlow    | Clock low time         | 100 kHz mode | 4.7        | _    | μS    | Device must operate at a minimum of 1.5 MHz |
|              |         |                        | 400 kHz mode | 1.3        | _    | μS    | Device must operate at a minimum of 10 MHz  |
|              |         |                        | SSP Module   | 0.5TcY     | _    |       |                                             |
| 102          | Tr      | SDA and SCL rise       | 100 kHz mode | _          | 1000 | ns    |                                             |
|              |         | time                   | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10 to 400 pF     |
| 103          | Tf      | SDA and SCL fall time  | 100 kHz mode | _          | 300  | ns    |                                             |
|              |         |                        | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10 to 400 pF     |
| 90           | Tsu:sta | START condition        | 100 kHz mode | 4.7        | _    | μS    | Only relevant for Repeated                  |
|              |         | setup time             | 400 kHz mode | 0.6        | _    | μS    | START condition                             |
| 91           | Thd:sta | START condition hold   | 100 kHz mode | 4.0        | _    | μS    | After this period, the first clock          |
|              |         | time                   | 400 kHz mode | 0.6        | _    | μS    | pulse is generated                          |
| 106          | Thd:dat | Data input hold time   | 100 kHz mode | 0          | _    | ns    |                                             |
|              |         |                        | 400 kHz mode | 0          | 0.9  | μS    |                                             |
| 107          | Tsu:dat | Data input setup time  | 100 kHz mode | 250        |      | ns    | (Note 2)                                    |
|              |         |                        | 400 kHz mode | 100        |      | ns    |                                             |
| 92           | Tsu:sto | STOP condition setup   | 100 kHz mode | 4.7        | _    | μS    |                                             |
|              |         | time                   | 400 kHz mode | 0.6        | _    | μS    |                                             |
| 109          | Taa     | Output valid from      | 100 kHz mode | _          | 3500 | ns    | (Note 1)                                    |
|              |         | clock                  | 400 kHz mode | _          | _    | ns    |                                             |
| 110          | Tbuf    | Bus free time          | 100 kHz mode | 4.7        | _    | μS    | Time the bus must be free                   |
|              |         |                        | 400 kHz mode | 1.3        | _    | μS    | before a new transmission can start         |
| - <u>-</u> - | Cb      | Bus capacitive loading |              |            | 400  | pF    |                                             |

Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

<sup>2:</sup> A fast mode (400 kHz) I<sup>2</sup>C bus device can be used in a standard mode (100 kHz) I<sup>2</sup>C bus system, but the requirement that Tsu:dat ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line TR max.+ Tsu:dat = 1000 + 250 = 1250 ns (according to the standard mode I<sup>2</sup>C bus specification) before the SCL line is released.

FIGURE 15-21: A/D CONVERSION TIMING



TABLE 15-13: A/D CONVERSION REQUIREMENTS

| Param<br>No. | Sym  | Characteristic                                    |                                   | Min      | Тур†     | Max | Units | Conditions                                                                                                                                                                                                  |
|--------------|------|---------------------------------------------------|-----------------------------------|----------|----------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 130          | TAD  | A/D clock period                                  | clock period Standard( <b>F</b> ) |          | _        |     | μS    | Tosc based, VREF ≥ 3.0V                                                                                                                                                                                     |
|              |      |                                                   | Extended( <b>LF</b> )             | 3.0      | _        | _   | μS    | Tosc based, VREF ≥ 2.0V                                                                                                                                                                                     |
|              |      |                                                   | Standard(F)                       | 2.0      | 4.0      | 6.0 | μS    | A/D RC mode                                                                                                                                                                                                 |
|              |      |                                                   | Extended( <b>LF</b> )             | 3.0      | 6.0      | 9.0 | μS    | A/D RC mode                                                                                                                                                                                                 |
| 131          | TCNV | Conversion time (not including S/H time) (Note 1) |                                   |          | _        | 12  | TAD   |                                                                                                                                                                                                             |
| 132          | TACQ | Acquisition time                                  |                                   | (Note 2) | 40       | _   | μS    |                                                                                                                                                                                                             |
|              |      |                                                   |                                   | 10*      |          | Ι   | μS    | The minimum time is the amplifier settling time. This may be used if the "new" input voltage has not changed by more than 1 LSb (i.e., 20.0 mV @ 5.12V) from the last sampled voltage (as stated on CHOLD). |
| 134          | TGO  | Q4 to A/D clock start                             |                                   | _        | Tosc/2 § | _   | _     | If the A/D clock source is selected as RC, a time of Tcy is added before the A/D clock starts. This allows the SLEEP instruction to be executed.                                                            |

<sup>\*</sup> These parameters are characterized but not tested.

Note 1: ADRES register may be read on the following TcY cycle.

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

<sup>§</sup> This specification ensured by design.

<sup>2:</sup> See Section 11.1 for minimum conditions.

## 28-Lead Skinny Plastic Dual In-line (SP) - 300 mil (PDIP)

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



|                            | Units  | INCHES* |       |       | MILLIMETERS |       |       |
|----------------------------|--------|---------|-------|-------|-------------|-------|-------|
| Dimension                  | Limits | MIN     | NOM   | MAX   | MIN         | NOM   | MAX   |
| Number of Pins             | n      |         | 28    |       |             | 28    |       |
| Pitch                      | р      |         | .100  |       |             | 2.54  |       |
| Top to Seating Plane       | Α      | .140    | .150  | .160  | 3.56        | 3.81  | 4.06  |
| Molded Package Thickness   | A2     | .125    | .130  | .135  | 3.18        | 3.30  | 3.43  |
| Base to Seating Plane      | A1     | .015    |       |       | 0.38        |       |       |
| Shoulder to Shoulder Width | Е      | .300    | .310  | .325  | 7.62        | 7.87  | 8.26  |
| Molded Package Width       | E1     | .275    | .285  | .295  | 6.99        | 7.24  | 7.49  |
| Overall Length             | D      | 1.345   | 1.365 | 1.385 | 34.16       | 34.67 | 35.18 |
| Tip to Seating Plane       | L      | .125    | .130  | .135  | 3.18        | 3.30  | 3.43  |
| Lead Thickness             | С      | .008    | .012  | .015  | 0.20        | 0.29  | 0.38  |
| Upper Lead Width           | B1     | .040    | .053  | .065  | 1.02        | 1.33  | 1.65  |
| Lower Lead Width           | В      | .016    | .019  | .022  | 0.41        | 0.48  | 0.56  |
| Overall Row Spacing §      | eB     | .320    | .350  | .430  | 8.13        | 8.89  | 10.92 |
| Mold Draft Angle Top       | α      | 5       | 10    | 15    | 5           | 10    | 15    |
| Mold Draft Angle Bottom    | β      | 5       | 10    | 15    | 5           | 10    | 15    |

Dimension D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed

Drawing No. C04-070

<sup>\*</sup> Controlling Parameter § Significant Characteristic

Notes:

<sup>.010&</sup>quot; (0.254mm) per side. JEDEC Equivalent: MO-095

| Bus Collision During a Repeated                       |
|-------------------------------------------------------|
| START Condition (Case 1)92                            |
| Bus Collision During a Repeated                       |
| START Condition (Case2)92                             |
| Bus Collision During a START                          |
| Condition (SCL = 0)91                                 |
| Bus Collision During a STOP Condition93               |
| Bus Collision for Transmit and Acknowledge            |
| Capture/Compare/PWM166                                |
| CLKOUT and I/O                                        |
| I <sup>2</sup> C Bus Data                             |
| I <sup>2</sup> C Bus START/STOP bits                  |
| I <sup>2</sup> C Master Mode First START Bit Timing80 |
| I <sup>2</sup> C Master Mode Reception Timing         |
| I <sup>2</sup> C Master Mode Transmission Timing      |
| Master Mode Transmit Clock Arbitration                |
|                                                       |
| Power-up Timer                                        |
| Repeat START Condition81                              |
| RESET                                                 |
| SPI Master Mode70                                     |
| SPI Slave Mode (CKE = 1)71                            |
| SPI Slave Mode Timing (CKE = 0)71                     |
| Start-up Timer164                                     |
| STOP Condition Receive or Transmit87                  |
| Time-out Sequence on Power-up127, 128                 |
| Timer0165                                             |
| Timer1165                                             |
| USART Asynchronous Master Transmission 100            |
| USART Asynchronous Reception102                       |
| USART Synchronous Receive173                          |
| USART Synchronous Reception108                        |
| USART Synchronous Transmission 106, 173               |
| USART, Asynchronous Reception104                      |
| Wake-up from SLEEP via Interrupt                      |
| Watchdog Timer164                                     |
| TMR017                                                |
| TMR0 Register15                                       |
| TMR1CS bit51                                          |
| TMR1H17                                               |
| TMR1H Register15                                      |
| TMR1L17                                               |
| TMR1L Register15                                      |
| TMR1ON bit51                                          |
| TMR2                                                  |
| TMR2 Register15                                       |
| TMR2ON bit                                            |
| TOUTPS0 bit                                           |
| TOUTPS0 bit                                           |
| TOUTPS1 bit                                           |
|                                                       |
| TOUTPS3 bit                                           |
| TRISA Register                                        |
| TRISB Register                                        |
| TRISC Register                                        |
| TRISD Register                                        |
| TRISE Register                                        |
| IBF Bit                                               |
| IBOV Bit                                              |
| OBF Bit                                               |
| PSPMODE Bit35, 36, 37, 38                             |
| TXREG17                                               |
|                                                       |

| TXSTA Register                                          |       |
|---------------------------------------------------------|-------|
| BRGH Bit                                                | 95    |
| CSRC Bit                                                | 95    |
| SYNC Bit                                                | 95    |
| TRMT Bit                                                | 95    |
| TX9 Bit                                                 | 95    |
| TX9D Bit                                                | 95    |
| TXEN Bit                                                | 95    |
| U                                                       |       |
| UA                                                      | 66    |
| Universal Synchronous Asynchronous Receiver             | 00    |
| Transmitter. See USART                                  |       |
| Update Address, UA                                      | 66    |
| USART                                                   |       |
| Address Detect Enable (ADDEN Bit)                       |       |
|                                                         |       |
| Asynchronous Mode                                       |       |
| Asynchronous Receive                                    |       |
| Associated Registers                                    |       |
| Block Diagram                                           |       |
| Asynchronous Receive (9-bit Mode)                       |       |
| Associated Registers                                    |       |
| Block Diagram                                           |       |
| Timing Diagram                                          | 104   |
| Asynchronous Receive with Address Detect.               |       |
| SeeAsynchronous Receive (9-bit Mode                     | ∍).   |
| Asynchronous Reception                                  |       |
| Asynchronous Transmitter                                | 99    |
| Baud Rate Generator (BRG)                               | 97    |
| Baud Rate Formula                                       | 97    |
| Baud Rates, Asynchronous Mode (BRGH=0                   | 0) 98 |
| High Baud Rate Select (BRGH Bit)                        |       |
| Sampling                                                |       |
| Clock Source Select (CSRC Bit)                          | 95    |
| Continuous Receive Enable (CREN Bit)                    |       |
| Framing Error (FERR Bit)                                |       |
| Mode Select (SYNC Bit)                                  |       |
| Overrun Error (OERR Bit)                                | 96    |
| RC6/TX/CK Pin                                           |       |
| RC7/RX/DT Pin                                           |       |
| RCSTA Register                                          |       |
| Receive Data, 9th bit (RX9D Bit)                        |       |
| Receive Enable, 9-bit (RX9 Bit)                         |       |
| Serial Port Enable (SPEN Bit)                           | 05 06 |
| Single Receive Enable (SREN Bit)                        |       |
|                                                         |       |
| Synchronous Master Mode<br>Synchronous Master Reception |       |
|                                                         |       |
| Associated Registers                                    |       |
| Synchronous Master Transmission                         |       |
| Associated Registers                                    |       |
| Synchronous Slave Mode                                  |       |
| Synchronous Slave Reception                             |       |
| Associated Registers                                    |       |
| Synchronous Slave Transmit                              |       |
| Associated Registers                                    |       |
| Transmit Block Diagram                                  |       |
| Transmit Data, 9th Bit (TX9D)                           |       |
| Transmit Enable (TXEN Bit)                              |       |
| Transmit Enable, Nine-bit (TX9 Bit)                     |       |
| Transmit Shift Register Status (TRMT Bit)               |       |
| TXSTA Register                                          | 95    |