



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Betalls                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 20MHz                                                                      |
| 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        | 7KB (4K x 14)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 128 x 8                                                                    |
| RAM Size                   | 192 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                  |
| Data Converters            | A/D 5x10b                                                                  |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 28-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f873at-i-so |
|                            |                                                                            |

Email: info@E-XFL.COM

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

#### **Pin Diagrams**





| Pin Name                                 | PDIP<br>Pin# | PLCC<br>Pin# | TQFP<br>Pin# | QFN<br>Pin# | I/O/P<br>Type     | Buffer<br>Type | Description                                                                                                                          |
|------------------------------------------|--------------|--------------|--------------|-------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
|                                          |              |              |              |             |                   |                | PORTC is a bidirectional I/O port.                                                                                                   |
| RC0/T1OSO/T1CKI<br>RC0<br>T1OSO<br>T1CKI | 15           | 16           | 32           | 34          | I/O<br>O<br>I     | ST             | Digital I/O.<br>Timer1 oscillator output.<br>Timer1 external clock input.                                                            |
| RC1/T1OSI/CCP2<br>RC1<br>T1OSI<br>CCP2   | 16           | 18           | 35           | 35          | I/O<br>I<br>I/O   | ST             | Digital I/O.<br>Timer1 oscillator input.<br>Capture2 input, Compare2 output, PWM2 output                                             |
| RC2/CCP1<br>RC2<br>CCP1                  | 17           | 19           | 36           | 36          | I/O<br>I/O        | ST             | Digital I/O.<br>Capture1 input, Compare1 output, PWM1 output                                                                         |
| RC3/SCK/SCL<br>RC3<br>SCK<br>SCL         | 18           | 20           | 37           | 37          | 1/0<br>1/0<br>1/0 | ST             | Digital I/O.<br>Synchronous serial clock input/output for SPI<br>mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C |
| RC4/SDI/SDA<br>RC4<br>SDI<br>SDA         | 23           | 25           | 42           | 42          | I/O<br>I<br>I/O   | ST             | mode.<br>Digital I/O.<br>SPI data in.<br>I <sup>2</sup> C data I/O.                                                                  |
| RC5/SDO<br>RC5<br>SDO                    | 24           | 26           | 43           | 43          | I/O<br>O          | ST             | Digital I/O.<br>SPI data out.                                                                                                        |
| RC6/TX/CK<br>RC6<br>TX<br>CK             | 25           | 27           | 44           | 44          | I/O<br>O<br>I/O   | ST             | Digital I/O.<br>USART asynchronous transmit.<br>USART1 synchronous clock.                                                            |
| RC7/RX/DT<br>RC7<br>RX<br>DT             | 26           | 29           | 1            | 1           | I/O<br>I<br>I/O   | ST             | Digital I/O.<br>USART asynchronous receive.<br>USART synchronous data.                                                               |

#### **TABLE 1-3:** PIC16F874A/877A PINOUT DESCRIPTION (CONTINUED)

— = 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.

#### 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 TO and 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 Section 15.0 "Instruction Set Summary".

| Note: | The <u>C</u> and <u>DC</u> bits operate as a borrow<br>and digit borrow bit, respectively, in sub- |
|-------|----------------------------------------------------------------------------------------------------|
|       | traction. See the SUBLW and SUBWF instructions for examples.                                       |

|         | 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   | •                                                                                                                                                  |                                |              | ed for indired | t addressing)     |               |              |                |
|         |                                                                                                                                                    | 2, 3 (100h-1f<br>), 1 (00h-FFI | ,            |                |                   |               |              |                |
| bit 6-5 | RP1:RP0:                                                                                                                                           | Register Ba                    | nk Select b  | its (used for  | direct addressi   | ng)           |              |                |
|         |                                                                                                                                                    | 3 (180h-1Fl                    | ,            |                |                   |               |              |                |
|         |                                                                                                                                                    | 2 (100h-17<br>1 (80h-FFh)      | ,            |                |                   |               |              |                |
|         |                                                                                                                                                    | 0 (00h-7Fh)                    |              |                |                   |               |              |                |
|         |                                                                                                                                                    | is 128 byte                    |              |                |                   |               |              |                |
| bit 4   | TO: Time-                                                                                                                                          | out bit                        |              |                |                   |               |              |                |
|         |                                                                                                                                                    |                                |              | iction or SLI  | EEP instruction   |               |              |                |
| 1.11.0  |                                                                                                                                                    | T time-out or                  | curred       |                |                   |               |              |                |
| bit 3   | PD: Power                                                                                                                                          |                                | with a GI DW |                |                   |               |              |                |
|         | -                                                                                                                                                  | ower-up or b<br>ocution of the | -            |                | JU                |               |              |                |
| bit 2   | Z: Zero bit                                                                                                                                        |                                |              |                |                   |               |              |                |
|         |                                                                                                                                                    | sult of an ar                  |              | •              |                   |               |              |                |
|         |                                                                                                                                                    |                                |              | •              | on is not zero    |               |              |                |
| bit 1   |                                                                                                                                                    |                                | •            |                | BLW, SUBWF ins    | tructions)    |              |                |
|         |                                                                                                                                                    | i, the polarity                |              |                | e result occurre  | <sup>ad</sup> |              |                |
|         | •                                                                                                                                                  | ry-out from t                  |              |                |                   | u             |              |                |
| bit 0   |                                                                                                                                                    | •                              |              |                | UBWF instruction  | ons)          |              |                |
|         |                                                                                                                                                    |                                |              |                | f the result occu |               |              |                |
|         | 0 = No carry-out from the Most Significant bit of the result occurred                                                                              |                                |              |                |                   |               |              |                |
|         | Note:                                                                                                                                              |                                |              |                | d. A subtraction  |               |              |                |
|         | complement of the second operand. For rotate (RRF, RLF) instructions, thi<br>loaded with either the high, or low order bit of the source register. |                                |              |                |                   |               |              | s, this dit is |
|         |                                                                                                                                                    | iouded with                    |              | nigh, or low   |                   | Source reg    | 10101.       |                |
|         | Legend:                                                                                                                                            |                                |              |                |                   |               |              |                |
|         | R = Reada                                                                                                                                          | ahle hit                       | W = V        | Vritable bit   | LI = Unimpl       | emented h     | it_read as ' | 0'             |

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

#### 2.2.2.7 PIR2 Register

The PIR2 register contains the flag bits for the CCP2 interrupt, the SSP bus collision interrupt, EEPROM write operation interrupt and the comparator 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  |
|-----------|-------|-----|-------|-------|-----|-----|--------|
| —         | CMIF  | _   | EEIF  | BCLIF | —   | —   | CCP2IF |
| <br>bit 7 |       |     |       |       |     |     | bit 0  |

| bit 7   | Unimplemented: Read as '0'                                                                                                                        |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6   | CMIF: Comparator Interrupt Flag bit                                                                                                               |
|         | 1 = The comparator input has changed (must be cleared in software)                                                                                |
|         | 0 = The comparator input has not changed                                                                                                          |
| 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 I <sup>2</sup> C 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:                                                                                                                                     |
|         | <ul> <li>1 = A TMR1 register compare match occurred (must be cleared in software)</li> <li>0 = No TMR1 register compare match occurred</li> </ul> |
|         | PWM mode:                                                                                                                                         |
|         | Unused.                                                                                                                                           |
|         |                                                                                                                                                   |

| 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.8 PCON Register

bit 1

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 MCLR Reset.

Note: BOR is unknown on Power-on Reset. 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 Unimplemented: 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    | l bit, read as '0' |
| - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown |

### 3.0 DATA EEPROM AND FLASH PROGRAM MEMORY

The data EEPROM and Flash program memory is readable and writable during normal operation (over the full VDD range). This memory is not directly mapped in the register file space. Instead, it is indirectly addressed through the Special Function Registers. There are six SFRs used to read and write this memory:

- EECON1
- EECON2
- EEDATA
- EEDATH
- EEADR
- EEADRH

When interfacing to the data memory block, EEDATA holds the 8-bit data for read/write and EEADR holds the address of the EEPROM location being accessed. These devices have 128 or 256 bytes of data EEPROM (depending on the device), with an address range from 00h to FFh. On devices with 128 bytes, addresses from 80h to FFh are unimplemented and will wraparound to the beginning of data EEPROM memory. When writing to unimplemented locations, the on-chip charge pump will be turned off.

When interfacing the program memory block, the EEDATA and EEDATH registers form a two-byte word that holds the 14-bit data for read/write and the EEADR and EEADRH registers form a two-byte word that holds the 13-bit address of the program memory location being accessed. These devices have 4 or 8K words of program Flash, with an address range from 0000h to 0FFFh for the PIC16F873A/874A and 0000h to 1FFFh for the PIC16F876A/877A. Addresses above the range of the respective device will wraparound to the beginning of program memory.

The EEPROM data memory allows single-byte read and write. The Flash program memory allows single-word reads and four-word block writes. Program memory write operations automatically perform an erase-before-write on blocks of four words. A byte write in data EEPROM memory automatically erases the location and writes the new data (erase-before-write).

The write time is controlled by an on-chip timer. The write/erase voltages are generated by an on-chip charge pump, rated to operate over the voltage range of the device for byte or word operations.

When the device is code-protected, the CPU may continue to read and write the data EEPROM memory. Depending on the settings of the write-protect bits, the device may or may not be able to write certain blocks of the program memory; however, reads of the program memory are allowed. When code-protected, the device programmer can no longer access data or program memory; this does NOT inhibit internal reads or writes.

### 3.1 EEADR and EEADRH

The EEADRH:EEADR register pair can address up to a maximum of 256 bytes of data EEPROM or up to a maximum of 8K words of program EEPROM. When selecting a data address value, only the LSByte of the address is written to the EEADR register. When selecting a program address value, the MSByte of the address is written to the EEADRH register and the LSByte is written to the EEADR register.

If the device contains less memory than the full address reach of the address register pair, the Most Significant bits of the registers are not implemented. For example, if the device has 128 bytes of data EEPROM, the Most Significant bit of EEADR is not implemented on access to data EEPROM.

### 3.2 EECON1 and EECON2 Registers

EECON1 is the control register for memory accesses.

Control bit, EEPGD, determines if the access will be a program or data memory access. When clear, as it is when reset, any subsequent operations will operate on the data memory. When set, any subsequent operations will operate on the program memory.

Control bits, RD and WR, initiate read and write or erase, respectively. These bits cannot be cleared, only set, in software. They are cleared in hardware at completion of the read or write operation. The inability to clear the WR bit in software prevents the accidental, premature termination of a write operation.

The WREN bit, when set, will allow a write or erase operation. On power-up, the WREN bit is clear. The WRERR bit is set when a write (or erase) operation is interrupted by a  $\overline{\text{MCLR}}$  or a WDT Time-out Reset during normal operation. In these situations, following Reset, the user can check the WRERR bit and rewrite the location. The data and address will be unchanged in the EEDATA and EEADR registers.

Interrupt flag bit, EEIF in the PIR2 register, is set when the write is complete. It must be cleared in software.

EECON2 is not a physical register. Reading EECON2 will read all '0's. The EECON2 register is used exclusively in the EEPROM write sequence.

Note: The self-programming mechanism for Flash program memory has been changed. On previous PIC16F87X devices, Flash programming was done in single-word erase/ write cycles. The newer PIC18F87XA devices use a four-word erase/write cycle. See Section 3.6 "Writing to Flash Program Memory" for more information.

| Name                   | Bit#  | Buffer                | Function                                                                                                                                          |
|------------------------|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT                | bit 0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software programmable weak pull-up.                                                        |
| RB1                    | bit 1 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB2                    | bit 2 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB3/PGM <sup>(3)</sup> | bit 3 | TTL                   | Input/output pin or programming pin in LVP mode. Internal software programmable weak pull-up.                                                     |
| RB4                    | bit 4 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB5                    | bit 5 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB6/PGC                | bit 6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or in-circuit debugger pin.<br>Internal software programmable weak pull-up. Serial programming clock. |
| RB7/PGD                | bit 7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or in-circuit debugger pin.<br>Internal software programmable weak pull-up. Serial programming data.  |

#### TABLE 4-3:PORTB FUNCTIONS

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

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

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

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

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

| Address   | Name       | Bit 7 | Bit 6      | Bit 5    | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value<br>POR, I |      | Valu<br>all o<br>Res | ther |
|-----------|------------|-------|------------|----------|--------|-------|-------|-------|-------|-----------------|------|----------------------|------|
| 06h, 106h | PORTB      | RB7   | RB6        | RB5      | RB4    | RB3   | RB2   | RB1   | RB0   | XXXX :          | xxxx | uuuu                 | uuuu |
| 86h, 186h | TRISB      | PORTB | Data Direc | tion Reg | jister |       |       |       |       | 1111 1          | 1111 | 1111                 | 1111 |
| 81h, 181h | OPTION_REG | RBPU  | INTEDG     | TOCS     | T0SE   | PSA   | PS2   | PS1   | PS0   | 1111 1          | 1111 | 1111                 | 1111 |
|           |            |       |            |          |        |       |       |       |       |                 |      |                      |      |

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

NOTES:

#### 9.3.1 REGISTERS

The MSSP module has four registers for SPI mode operation. These are:

- MSSP Control Register (SSPCON)
- MSSP Status Register (SSPSTAT)
- Serial Receive/Transmit Buffer Register (SSPBUF)
- MSSP Shift Register (SSPSR) Not directly accessible

SSPCON and SSPSTAT are the control and status registers in SPI mode operation. The SSPCON register is readable and writable. The lower six bits of the SSPSTAT are read-only. The upper two bits of the SSPSTAT are read/write. SSPSR is the shift register used for shifting data in or out. SSPBUF is the buffer register to which data bytes are written to or read from.

In receive operations, SSPSR and SSPBUF together create a double-buffered receiver. When SSPSR receives a complete byte, it is transferred to SSPBUF and the SSPIF interrupt is set.

During transmission, the SSPBUF is not doublebuffered. A write to SSPBUF will write to both SSPBUF and SSPSR.

#### REGISTER 9-1: SSPSTAT: MSSP STATUS REGISTER (SPI MODE) (ADDRESS 94h)

|       | R/W-0                    | R/W-0           | R-0             | R-0          | R-0           | R-0           | R-0          | R-0           |
|-------|--------------------------|-----------------|-----------------|--------------|---------------|---------------|--------------|---------------|
|       | SMP                      | CKE             | D/A             | Р            | S             | R/W           | UA           | BF            |
|       | bit 7                    |                 |                 |              |               |               |              | bit 0         |
| bit 7 | SMP: Sam                 | ple bit         |                 |              |               |               |              |               |
|       | SPI Master               |                 |                 |              |               |               |              |               |
|       |                          | ata sampled     |                 |              |               |               |              |               |
|       |                          | ata sampled     | at middle o     | r data outpu | tume          |               |              |               |
|       | SMP must                 | be cleared v    | when SPI is     | used in Slav | ve mode       |               |              |               |
| bit 6 |                          | Clock Select    |                 |              | o modo.       |               |              |               |
|       | 1 = Transm               | nit occurs on   | transition fr   | om active to | ldle clock s  | state         |              |               |
|       | 0 = Transm               | nit occurs on   | transition fr   | om Idle to a | ctive clock s | state         |              |               |
|       | Note:                    | Polarity of o   | clock state is  | s set by the | CKP bit (SS   | PCON1<4>      | ).           |               |
| bit 5 | D/A: Data/               | Address bit     |                 |              |               |               |              |               |
|       | Used in I <sup>2</sup> C | c mode only.    |                 |              |               |               |              |               |
| bit 4 | P: Stop bit              |                 |                 |              |               |               |              |               |
|       | Used in I <sup>2</sup> C | mode only.      | This bit is cle | ared when t  | he MSSP me    | odule is disa | bled, SSPEI  | N is cleared. |
| bit 3 | S: Start bit             |                 |                 |              |               |               |              |               |
|       | Used in I <sup>2</sup> C | c mode only.    |                 |              |               |               |              |               |
| bit 2 | R/W: Read                | I/Write bit inf | ormation        |              |               |               |              |               |
|       | Used in I <sup>2</sup> C | c mode only.    |                 |              |               |               |              |               |
| bit 1 | UA: Update               | e Address b     | it              |              |               |               |              |               |
|       | Used in I <sup>2</sup> C | c mode only.    |                 |              |               |               |              |               |
| bit 0 | BF: Buffer               | Full Status b   | oit (Receive    | mode only)   |               |               |              |               |
|       | 1 = Receiv               | e complete,     | SSPBUF is       | full         |               |               |              |               |
|       | 0 = Receiv               | e not comple    | ete, SSPBU      | F is empty   |               |               |              |               |
|       | Legend:                  |                 |                 |              |               |               |              |               |
|       | R = Reada                | ble bit         | W = W           | ritable bit  | U = Unim      | plemented     | bit, read as | '0'           |
|       | - n = Value              | at POR          | '1' = B         | it is set    | '0' = Bit i   | s cleared     | x = Bit is ι | Inknown       |

#### 9.4.6.1 I<sup>2</sup>C Master Mode Operation

The master device generates all of the serial clock pulses and the Start and Stop conditions. A transfer is ended with a Stop condition or with a Repeated Start condition. Since the Repeated Start condition is also the beginning of the next serial transfer, the I<sup>2</sup>C bus will not be released.

In Master Transmitter mode, serial data is output through SDA while SCL outputs the serial clock. The first byte transmitted contains the slave address of the receiving device (7 bits) and the Read/Write (R/W) bit. In this case, the R/W bit will be logic '0'. Serial data is transmitted 8 bits at a time. After each byte is transmitted, an Acknowledge bit is received. Start and Stop conditions are output to indicate the beginning and the end of a serial transfer.

In Master Receive mode, the first byte transmitted contains the slave address of the transmitting device (7 bits) and the R/W bit. In this case, the R/W bit will be logic '1'. Thus, the first byte transmitted is a 7-bit slave address followed by a '1' to indicate the receive bit. Serial data is received via SDA while SCL outputs the serial clock. Serial data is received 8 bits at a time. After each byte is received, an Acknowledge bit is transmitted. Start and Stop conditions indicate the beginning and end of transmission.

The baud rate generator used for the SPI mode operation is used to set the SCL clock frequency for either 100 kHz, 400 kHz or 1 MHz  $I^2C$  operation. See **Section 9.4.7 "Baud Rate Generator"** for more detail. A typical transmit sequence would go as follows:

- 1. The user generates a Start condition by setting the Start Enable bit, SEN (SSPCON2<0>).
- SSPIF is set. The MSSP module will wait the required Start time before any other operation takes place.
- 3. The user loads the SSPBUF with the slave address to transmit.
- 4. Address is shifted out the SDA pin until all 8 bits are transmitted.
- 5. The MSSP module shifts in the ACK bit from the slave device and writes its value into the SSPCON2 register (SSPCON2<6>).
- The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPIF bit.
- 7. The user loads the SSPBUF with eight bits of data.
- 8. Data is shifted out the SDA pin until all 8 bits are transmitted.
- The MSSP module shifts in the ACK bit from the slave device and writes its value into the SSPCON2 register (SSPCON2<6>).
- 10. The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPIF bit.
- 11. The user generates a Stop condition by setting the Stop Enable bit, PEN (SSPCON2<2>).
- 12. Interrupt is generated once the Stop condition is complete.



#### 9.4.12 ACKNOWLEDGE SEQUENCE TIMING

An Acknowledge sequence is enabled by setting the Acknowledge Sequence Enable bit. ACKEN (SSPCON2<4>). When this bit is set, the SCL pin is pulled low and the contents of the Acknowledge data bit are presented on the SDA pin. If the user wishes to generate an Acknowledge, then the ACKDT bit should be cleared. If not, the user should set the ACKDT bit before starting an Acknowledge sequence. The Baud Rate Generator then counts for one rollover period (TBRG) and the SCL pin is deasserted (pulled high). When the SCL pin is sampled high (clock arbitration), the Baud Rate Generator counts for TBRG. The SCL pin is then pulled low. Following this, the ACKEN bit is automatically cleared, the baud rate generator is turned off and the MSSP module then goes into Idle mode (Figure 9-23).

#### 9.4.12.1 WCOL Status Flag

If the user writes the SSPBUF when an Acknowledge sequence is in progress, then WCOL is set and the contents of the buffer are unchanged (the write doesn't occur).

#### 9.4.13 STOP CONDITION TIMING

A Stop bit is asserted on the SDA pin at the end of a receive/transmit by setting the Stop Sequence Enable bit, PEN (SSPCON2<2>). At the end of a receive/ transmit, the SCL line is held low after the falling edge of the ninth clock. When the PEN bit is set, the master will assert the SDA line low. When the SDA line is sampled low, the Baud Rate Generator is reloaded and counts down to 0. When the Baud Rate Generator times out, the SCL pin will be brought high and one TBRG (Baud Rate Generator rollover count) later, the SDA pin will be deasserted. When the SDA pin is sampled high while SCL is high, the P bit (SSPSTAT<4>) is set. A TBRG later, the PEN bit is cleared and the SSPIF bit is set (Figure 9-24).

#### 9.4.13.1 WCOL Status Flag

If the user writes the SSPBUF when a Stop sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write doesn't occur).

#### FIGURE 9-23: ACKNOWLEDGE SEQUENCE WAVEFORM



#### FIGURE 9-24: STOP CONDITION RECEIVE OR TRANSMIT MODE



| Address                                | Name   | Bit 7                | Bit 6     | Bit 5   | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |      | e on:<br>BOR | all c | ie on<br>other<br>sets |
|----------------------------------------|--------|----------------------|-----------|---------|-------|-------|--------|--------|--------|------|--------------|-------|------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh                 | INTCON | GIE                  | PEIE      | TMR0IE  | INTE  | RBIE  | TMR0IF | INTF   | R0IF   | 0000 | 000x         | 0000  | 000u                   |
| 0Ch                                    | PIR1   | PSPIF <sup>(1)</sup> | ADIF      | RCIF    | TXIF  | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 | 0000         | 0000  | 0000                   |
| 18h                                    | RCSTA  | SPEN                 | RX9       | SREN    | CREN  | ADDEN | FERR   | OERR   | RX9D   | 0000 | 000x         | 0000  | 000x                   |
| 19h                                    | TXREG  | USART Tr             | ansmit Re | egister |       |       |        |        |        | 0000 | 0000         | 0000  | 0000                   |
| 8Ch                                    | PIE1   | PSPIE <sup>(1)</sup> | ADIE      | RCIE    | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 | 0000         | 0000  | 0000                   |
| 98h                                    | TXSTA  | CSRC                 | TX9       | TXEN    | SYNC  | -     | BRGH   | TRMT   | TX9D   | 0000 | -010         | 0000  | -010                   |
| 99h SPBRG Baud Rate Generator Register |        |                      |           |         |       |       | 0000   | 0000   | 0000   | 0000 |              |       |                        |

Legend: x = unknown, - = unimplemented, read as '0'. Shaded cells are not used for synchronous slave transmission.

Note 1: Bits PSPIE and PSPIF are reserved on 28-pin devices; always maintain these bits clear.

#### 10.4.2 USART SYNCHRONOUS SLAVE RECEPTION

The operation of the Synchronous Master and Slave modes is identical, except in the case of the Sleep mode. Bit SREN is a "don't care" in Slave mode.

If receive is enabled by setting bit CREN prior to the SLEEP instruction, then a word may be received during Sleep. On completely receiving the word, the RSR register will transfer the data to the RCREG register and if enable bit RCIE bit is set, the interrupt generated will wake the chip from Sleep. If the global interrupt is enabled, the program will branch to the interrupt vector (0004h).

When setting up a Synchronous Slave Reception, follow these steps:

- Enable the synchronous master serial port by setting bits SYNC and SPEN and clearing bit CSRC.
- 2. If interrupts are desired, set enable bit RCIE.
- 3. If 9-bit reception is desired, set bit RX9.
- 4. To enable reception, set enable bit CREN.
- 5. Flag bit RCIF will be set when reception is complete and an interrupt will be generated if enable bit RCIE was set.
- Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 7. Read the 8-bit received data by reading the RCREG register.
- 8. If any error occurred, clear the error by clearing bit CREN.
- 9. If using interrupts, ensure that GIE and PEIE (bits 7 and 6) of the INTCON register are set.

| Address                | Name                               | Bit 7                | Bit 6    | Bit 5   | Bit 4 | Bit 3 | Bit 2  | Bit 1     | Bit 0     | Value on:<br>POR, BOR | Value on<br>all other<br>Resets |
|------------------------|------------------------------------|----------------------|----------|---------|-------|-------|--------|-----------|-----------|-----------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh | INTCON                             | GIE                  | PEIE     | TMR0IE  | INTE  | RBIE  | TMR0IF | INTF      | R0IF      | 0000 000x             | 0000 000u                       |
| 0Ch                    | PIR1                               | PSPIF <sup>(1)</sup> | ADIF     | RCIF    | TXIF  | SSPIF | CCP1IF | TMR2IF    | TMR1IF    | 0000 0000             | 0000 0000                       |
| 18h                    | RCSTA                              | SPEN                 | RX9      | SREN    | CREN  | ADDEN | FERR   | OERR      | RX9D      | 0000 000x             | x000 000x                       |
| 1Ah                    | RCREG                              | USART R              | eceive R | egister |       |       |        |           |           | 0000 0000             | 0000 0000                       |
| 8Ch                    | PIE1                               | PSPIE <sup>(1)</sup> | ADIE     | RCIE    | TXIE  | SSPIE | CCP1IE | TMR2IE    | TMR1IE    | 0000 0000             | 0000 0000                       |
| 98h                    | TXSTA                              | CSRC                 | TX9      | TXEN    | SYNC  | —     | BRGH   | TRMT      | TX9D      | 0000 -010             | 0000 -010                       |
| 99h                    | SPBRG Baud Rate Generator Register |                      |          |         |       |       |        | 0000 0000 | 0000 0000 |                       |                                 |

#### TABLE 10-11: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

Legend: x = unknown, - = unimplemented, read as '0'. Shaded cells are not used for synchronous slave reception.

Note 1: Bits PSPIE and PSPIF are reserved on 28-pin devices, always maintain these bits clear.

The ADRESH:ADRESL registers contain the 10-bit result of the A/D conversion. When the A/D conversion is complete, the result is loaded into this A/D Result register pair, the GO/DONE bit (ADCON0<2>) is cleared and the A/D interrupt flag bit ADIF is set. The block diagram of the A/D module is shown in Figure 11-1.

After the A/D module has been configured as desired, the selected channel must be acquired before the conversion is started. The analog input channels must have their corresponding TRIS bits selected as inputs.

To determine sample time, see **Section 11.1 "A/D Acquisition Requirements"**. After this acquisition time has elapsed, the A/D conversion can be started.

To do an A/D Conversion, follow these steps:

- 1. Configure the A/D module:
  - Configure analog pins/voltage reference and digital I/O (ADCON1)
  - Select A/D input channel (ADCON0)
  - Select A/D conversion clock (ADCON0)
  - Turn on A/D module (ADCON0)

- 2. Configure A/D interrupt (if desired):
  - Clear ADIF bit
  - Set ADIE bit
  - Set PEIE bit
  - · Set GIE bit
- 3. Wait the required acquisition time.
- 4. Start conversion:
  - Set GO/DONE bit (ADCON0)
- 5. Wait for A/D conversion to complete by either:
  - Polling for the GO/DONE bit to be cleared (interrupts disabled); OR
  - Waiting for the A/D interrupt
- 6. Read A/D Result register pair (ADRESH:ADRESL), clear bit ADIF if required.
- 7. For the next conversion, go to step 1 or step 2 as required. The A/D conversion time per bit is defined as TAD.



### FIGURE 11-1: A/D BLOCK DIAGRAM

|            | 14-6: INITIALIZATION CONDITIONS FOR ALL REGISTERS |     |      |     |                                    |                           |                                 |  |  |
|------------|---------------------------------------------------|-----|------|-----|------------------------------------|---------------------------|---------------------------------|--|--|
| Register   |                                                   | Dev | ices |     | Power-on Reset,<br>Brown-out Reset | MCLR Resets,<br>WDT Reset | Wake-up via WDT or<br>Interrupt |  |  |
| W          | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| INDF       | 73A                                               | 74A | 76A  | 77A | N/A                                | N/A                       | N/A                             |  |  |
| TMR0       | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| PCL        | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | PC + 1 <sup>(2)</sup>           |  |  |
| STATUS     | 73A                                               | 74A | 76A  | 77A | 0001 1xxx                          | 000q quuu <b>(3)</b>      | uuuq quuu <sup>(3)</sup>        |  |  |
| FSR        | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| PORTA      | 73A                                               | 74A | 76A  | 77A | 0x 0000                            | 0u 0000                   | uu uuuu                         |  |  |
| PORTB      | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| PORTC      | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| PORTD      | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| PORTE      | 73A                                               | 74A | 76A  | 77A | xxx                                | uuu                       | uuu                             |  |  |
| PCLATH     | 73A                                               | 74A | 76A  | 77A | 0 0000                             | 0 0000                    | u uuuu                          |  |  |
| INTCON     | 73A                                               | 74A | 76A  | 77A | 0000 000x                          | 0000 000u                 | uuuu uuuu <b>(1)</b>            |  |  |
|            | 73A                                               | 74A | 76A  | 77A | r000 0000                          | r000 0000                 | ruuu uuuu(1)                    |  |  |
| PIR1       | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu <b>(1)</b>            |  |  |
| PIR2       | 73A                                               | 74A | 76A  | 77A | -0-0 00                            | -0-0 00                   | -u-u uu <b>(1)</b>              |  |  |
| TMR1L      | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| TMR1H      | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| T1CON      | 73A                                               | 74A | 76A  | 77A | 00 0000                            | uu uuuu                   | uu uuuu                         |  |  |
| TMR2       | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu                       |  |  |
| T2CON      | 73A                                               | 74A | 76A  | 77A | -000 0000                          | -000 0000                 | -uuu uuuu                       |  |  |
| SSPBUF     | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| SSPCON     | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu                       |  |  |
| CCPR1L     | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| CCPR1H     | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| CCP1CON    | 73A                                               | 74A | 76A  | 77A | 00 0000                            | 00 0000                   | uu uuuu                         |  |  |
| RCSTA      | 73A                                               | 74A | 76A  | 77A | 0000 000x                          | 0000 000x                 | uuuu uuuu                       |  |  |
| TXREG      | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu                       |  |  |
| RCREG      | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu                       |  |  |
| CCPR2L     | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| CCPR2H     | 73A                                               | 74A | 76A  | 77A | xxxx xxxx                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| CCP2CON    | 73A                                               | 74A | 76A  | 77A | 0000 0000                          | 0000 0000                 | uuuu uuuu                       |  |  |
| ADRESH     | 73A                                               | 74A | 76A  | 77A | XXXX XXXX                          | uuuu uuuu                 | uuuu uuuu                       |  |  |
| ADCON0     | 73A                                               | 74A | 76A  | 77A | 0000 00-0                          | 0000 00-0                 | uuuu uu-u                       |  |  |
| OPTION_REG | 73A                                               | 74A | 76A  | 77A | 1111 1111                          | 1111 1111                 | uuuu uuuu                       |  |  |
| TRISA      | 73A                                               | 74A | 76A  | 77A | 11 1111                            | 11 1111                   | uu uuuu                         |  |  |
| TRISB      | 73A                                               | 74A | 76A  | 77A | 1111 1111                          | 1111 1111                 | uuuu uuuu                       |  |  |
| TRISC      | 73A                                               | 74A | 76A  | 77A | 1111 1111                          | 1111 1111                 | <u>uuuu</u> uuuu                |  |  |

#### TABLE 14-6: INITIALIZATION CONDITIONS FOR ALL REGISTERS

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition, r = reserved, maintain clear. Shaded cells indicate conditions do not apply for the designated device.

Note 1: One or more bits in INTCON, PIR1 and/or PIR2 will be affected (to cause wake-up).

- 2: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).
- 3: See Table 14-5 for Reset value for specific condition.

| CALL             | Call Subroutine                                                                                                                                                                                                                             |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                     |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                                                                          |
| Operation:       | $\begin{array}{l} (PC)+1 \rightarrow TOS, \\ k \rightarrow PC < 10:0>, \\ (PCLATH < 4:3>) \rightarrow PC < 12:11> \end{array}$                                                                                                              |
| Status Affected: | None                                                                                                                                                                                                                                        |
| Description:     | Call Subroutine. First, return<br>address (PC+1) is pushed onto<br>the stack. The eleven-bit<br>immediate address is loaded into<br>PC bits <10:0>. The upper bits of<br>the PC are loaded from PCLATH.<br>CALL is a two-cycle instruction. |

| CLRWDT                         | Clear Watchdog Timer                                                                                                                                                                 |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                        | [label] CLRWDT                                                                                                                                                                       |
| Operands:                      | None                                                                                                                                                                                 |
| Operation:<br>Status Affected: | $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow \overline{PD} \\ \overline{TO}, \ \overline{PD} \end{array}$ |
| Description:                   | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. Status bits,<br>TO and PD, are set.                                                     |

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

| COMF             | Complement f                                                                                                                                                   |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] COMF f,d                                                                                                                                               |  |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>d $\in [0,1]$                                                                                                                             |  |  |  |  |  |
| Operation:       | $(\overline{f}) \rightarrow (destination)$                                                                                                                     |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                              |  |  |  |  |  |
| Description:     | The contents of register 'f' are<br>complemented. If 'd' is '0', the<br>result is stored in W. If 'd' is '1',<br>the result is stored back in<br>register 'f'. |  |  |  |  |  |

| CLRW             | Clear W                                     | DECF             | Decrement f                                                                                                                                       |  |  |
|------------------|---------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:          | [label] CLRW                                | Syntax:          | [label] DECF f,d                                                                                                                                  |  |  |
| Operands:        | None                                        | Operands:        | $0 \le f \le 127$                                                                                                                                 |  |  |
| Operation:       | $00h \rightarrow (W)$                       |                  | d ∈ [0,1]                                                                                                                                         |  |  |
| ·                | $1 \rightarrow Z$                           | Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                               |  |  |
| Status Affected: | Z                                           | Status Affected: | Z                                                                                                                                                 |  |  |
| Description:     | W register is cleared. Zero bit (Z) is set. | Description:     | Decrement register 'f'. If 'd' is '0',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |  |  |

#### 17.2 DC Characteristics: PIC16F873A/874A/876A/877A (Industrial, Extended) PIC16LF873A/874A/876A/877A (Industrial)

| DC CHARACTERISTICS |       |                                         |                    |      |          |       |                                                                                                                     |  |
|--------------------|-------|-----------------------------------------|--------------------|------|----------|-------|---------------------------------------------------------------------------------------------------------------------|--|
| Param<br>No.       | Sym   | Characteristic                          | Min                | Тур† | Max      | Units | Conditions                                                                                                          |  |
|                    | VIL   | Input Low Voltage                       |                    |      |          |       |                                                                                                                     |  |
|                    |       | I/O ports:                              |                    |      |          |       |                                                                                                                     |  |
| D030               |       | with TTL buffer                         | Vss                | —    | 0.15 Vdd | V     | For entire VDD range                                                                                                |  |
| D030A              |       |                                         | Vss                | —    | 0.8V     | V     | $4.5V \le V\text{DD} \le 5.5V$                                                                                      |  |
| D031               |       | with Schmitt Trigger buffer             | Vss                | —    | 0.2 Vdd  | V     |                                                                                                                     |  |
| D032               |       | MCLR, OSC1 (in RC mode)                 | Vss                | —    | 0.2 Vdd  | V     |                                                                                                                     |  |
| D033               |       | OSC1 (in XT and LP modes)               | Vss                | —    | 0.3V     | V     | (Note 1)                                                                                                            |  |
|                    |       | OSC1 (in HS mode)                       | Vss                | —    | 0.3 Vdd  | V     |                                                                                                                     |  |
|                    |       | Ports RC3 and RC4:                      |                    | —    |          |       |                                                                                                                     |  |
| D034               |       | with Schmitt Trigger buffer             | Vss                | —    | 0.3 Vdd  | V     | For entire VDD range                                                                                                |  |
| D034A              |       | with SMBus                              | -0.5               | —    | 0.6      | V     | For VDD = 4.5 to 5.5V                                                                                               |  |
|                    | VIH   | Input High Voltage                      |                    |      | -        |       |                                                                                                                     |  |
|                    |       | I/O ports:                              |                    | —    |          |       |                                                                                                                     |  |
| D040               |       | with TTL buffer                         | 2.0                | —    | Vdd      | V     | $4.5V \leq V\text{DD} \leq 5.5V$                                                                                    |  |
| D040A              |       |                                         | 0.25 VDD<br>+ 0.8V |      | Vdd      | V     | For entire VDD range                                                                                                |  |
| D041               |       | with Schmitt Trigger buffer             | 0.8 Vdd            | —    | Vdd      | V     | For entire VDD range                                                                                                |  |
| D042               |       | MCLR                                    | 0.8 Vdd            | —    | Vdd      | V     |                                                                                                                     |  |
| D042A              |       | OSC1 (in XT and LP modes)               | 1.6V               | —    | Vdd      | V     | (Note 1)                                                                                                            |  |
|                    |       | OSC1 (in HS mode)                       | 0.7 Vdd            | —    | Vdd      | V     |                                                                                                                     |  |
| D043               |       | OSC1 (in RC mode)                       | 0.9 Vdd            | —    | Vdd      | V     |                                                                                                                     |  |
|                    |       | Ports RC3 and RC4:                      |                    |      |          |       |                                                                                                                     |  |
| D044               |       | with Schmitt Trigger buffer             | 0.7 Vdd            | —    | Vdd      | V     | For entire VDD range                                                                                                |  |
| D044A              |       | with SMBus                              | 1.4                | —    | 5.5      | V     | For VDD = 4.5 to 5.5V                                                                                               |  |
| D070               | Ipurb | PORTB Weak Pull-up Current              | 50                 | 250  | 400      | μA    | VDD = 5V, VPIN = VSS,<br>-40°C TO +85°C                                                                             |  |
|                    | lı∟   | Input Leakage Current <sup>(2, 3)</sup> |                    |      |          |       |                                                                                                                     |  |
| D060               |       | I/O ports                               |                    | —    | ±1       | μA    | $\label{eq:VSS} \begin{split} VSS &\leq V \text{PIN} \leq V \text{DD}, \\ \text{pin at high-impedance} \end{split}$ |  |
| D061               |       | MCLR, RA4/T0CKI                         | _                  | —    | ±5       | μA    | $Vss \leq V \text{PIN} \leq V \text{DD}$                                                                            |  |
| D063               |       | OSC1                                    | —                  | —    | ±5       | μA    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration                                                         |  |

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

Note 1: In RC oscillator configuration, the OSC1/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC16F87XA be driven with external clock in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as current sourced by the pin.

### 40-Lead Plastic Dual In-line (P) - 600 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 |       |       |  |
|----------------------------|-------|---------|-------|-------|-------------|-------|-------|--|
| Dimensio                   | MIN   | NOM     | MAX   | MIN   | NOM         | MAX   |       |  |
| Number of Pins             | n     |         | 40    |       |             | 40    |       |  |
| Pitch                      | р     |         | .100  |       |             | 2.54  |       |  |
| Top to Seating Plane       | А     | .160    | .175  | .190  | 4.06        | 4.45  | 4.83  |  |
| Molded Package Thickness   | A2    | .140    | .150  | .160  | 3.56        | 3.81  | 4.06  |  |
| Base to Seating Plane      | A1    | .015    |       |       | 0.38        |       |       |  |
| Shoulder to Shoulder Width | E     | .595    | .600  | .625  | 15.11       | 15.24 | 15.88 |  |
| Molded Package Width       | E1    | .530    | .545  | .560  | 13.46       | 13.84 | 14.22 |  |
| Overall Length             | D     | 2.045   | 2.058 | 2.065 | 51.94       | 52.26 | 52.45 |  |
| Tip to Seating Plane       | L     | .120    | .130  | .135  | 3.05        | 3.30  | 3.43  |  |
| Lead Thickness             | С     | .008    | .012  | .015  | 0.20        | 0.29  | 0.38  |  |
| Upper Lead Width           | B1    | .030    | .050  | .070  | 0.76        | 1.27  | 1.78  |  |
| Lower Lead Width           | В     | .014    | .018  | .022  | 0.36        | 0.46  | 0.56  |  |
| Overall Row Spacing §      | eB    | .620    | .650  | .680  | 15.75       | 16.51 | 17.27 |  |
| Mold Draft Angle Top       | α     | 5       | 10    | 15    | 5           | 10    | 15    |  |
| Mold Draft Angle Bottom    | β     | 5       | 10    | 15    | 5           | 10    | 15    |  |

\* Controlling Parameter § Significant Characteristic

Notes:

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

.010" (0.254mm) per side. JEDEC Equivalent: MO-011

Drawing No. C04-016

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

\* Controlling Parameter § Significant Characteristic

Notes:

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

.010" (0.254mm) per side. JEDEC Equivalent: MO-095

Drawing No. C04-070