



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

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| 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              | 33                                                                        |
| 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) | 4V ~ 5.5V                                                                 |
| Data Converters            | A/D 8x10b                                                                 |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                        |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                  |
| Supplier Device Package    | 40-PDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f877-04e-p |
|                            |                                                                           |

Email: info@E-XFL.COM

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

#### FIGURE 2-4: PIC16F874/873 REGISTER FILE MAP

| ,                                                                                                                                                                                                                                                          | File<br>Address | A                              | File<br>ddress | /                   | File<br>Address |                         | File<br>Addres |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|----------------|---------------------|-----------------|-------------------------|----------------|
| Indirect addr. <sup>(*)</sup>                                                                                                                                                                                                                              | 00h             | Indirect addr.(*)              | 80h            | Indirect addr.(*)   | 100h            | Indirect addr.(*)       | 180h           |
| TMR0                                                                                                                                                                                                                                                       | 01h             | OPTION_REG                     | 81h            | TMR0                | 101h            | OPTION_REG              | 181h           |
| PCL                                                                                                                                                                                                                                                        | 02h             | PCL                            | 82h            | PCL                 | 102h            | PCL                     | 182h           |
| STATUS                                                                                                                                                                                                                                                     | 03h             | STATUS                         | 83h            | STATUS              | 103h            | STATUS                  | 183h           |
| FSR                                                                                                                                                                                                                                                        | 04h             | FSR                            | 84h            | FSR                 | 104h            | FSR                     | 184h           |
| PORTA                                                                                                                                                                                                                                                      | 05h             | TRISA                          | 85h            |                     | 105h            |                         | 185h           |
| PORTB                                                                                                                                                                                                                                                      | 06h             | TRISB                          | 86h            | PORTB               | 106h            | TRISB                   | 186h           |
| PORTC                                                                                                                                                                                                                                                      | 07h             | TRISC                          | 87h            |                     | 107h            |                         | 187h           |
| PORTD <sup>(1)</sup>                                                                                                                                                                                                                                       | 08h             | TRISD <sup>(1)</sup>           | 88h            |                     | 108h            |                         | 188h           |
| PORTE <sup>(1)</sup>                                                                                                                                                                                                                                       | 09h             | TRISE <sup>(1)</sup>           | 89h            |                     | 109h            |                         | 189h           |
| PCLATH                                                                                                                                                                                                                                                     | 0Ah             | PCLATH                         | 8Ah            | PCLATH              | 10Ah            | PCLATH                  | 18Ah           |
| INTCON                                                                                                                                                                                                                                                     | 0Bh             | INTCON                         | 8Bh            | INTCON              | 10Bh            | INTCON                  | 18Bh           |
| PIR1                                                                                                                                                                                                                                                       | 0Ch             | PIE1                           | 8Ch            | EEDATA              | 10Ch            | EECON1                  | 18Cł           |
| PIR2                                                                                                                                                                                                                                                       | 0Dh             | PIE2                           | 8Dh            | EEADR               | 10Dh            | EECON2                  | 18Dł           |
| TMR1L                                                                                                                                                                                                                                                      | 0Eh             | PCON                           | 8Eh            | EEDATH              | 10Eh            | Reserved <sup>(2)</sup> | 18Eh           |
| TMR1H                                                                                                                                                                                                                                                      | 0Fh             |                                | 8Fh            | EEADRH              | 10Fh            | Reserved <sup>(2)</sup> | 18Fh           |
| T1CON                                                                                                                                                                                                                                                      | 10h             |                                | 90h            |                     | 110h            |                         | 190h           |
| TMR2                                                                                                                                                                                                                                                       | 11h             | SSPCON2                        | 91h            |                     |                 |                         |                |
| T2CON                                                                                                                                                                                                                                                      | 12h             | PR2                            | 92h            |                     |                 |                         |                |
| SSPBUF                                                                                                                                                                                                                                                     | 13h             | SSPADD                         | 93h            |                     |                 |                         |                |
| SSPCON                                                                                                                                                                                                                                                     | 14h             | SSPSTAT                        | 94h            |                     |                 |                         |                |
| CCPR1L                                                                                                                                                                                                                                                     | 15h             |                                | 95h            |                     |                 |                         |                |
| CCPR1H                                                                                                                                                                                                                                                     | 16h             |                                | 96h            |                     |                 |                         |                |
| CCP1CON                                                                                                                                                                                                                                                    | 17h             |                                | 97h            |                     |                 |                         |                |
| RCSTA                                                                                                                                                                                                                                                      | 18h             | TXSTA                          | 98h            |                     |                 |                         |                |
| TXREG                                                                                                                                                                                                                                                      | 19h             | SPBRG                          | 99h            |                     |                 |                         |                |
| RCREG                                                                                                                                                                                                                                                      | 1Ah             |                                | 9Ah            |                     |                 |                         |                |
| CCPR2L                                                                                                                                                                                                                                                     | 1Bh             |                                | 9Bh            |                     |                 |                         |                |
| CCPR2H                                                                                                                                                                                                                                                     | 1Ch             |                                | 9Ch            |                     |                 |                         |                |
| CCP2CON                                                                                                                                                                                                                                                    | 1Dh             |                                | 9Dh            |                     |                 |                         |                |
| ADRESH                                                                                                                                                                                                                                                     | 1Eh             | ADRESL                         | 9Eh            |                     |                 |                         |                |
| ADCON0                                                                                                                                                                                                                                                     | 1Fh             | ADCON1                         | 9Fh            |                     | 1206            |                         | 1A0h           |
|                                                                                                                                                                                                                                                            | 20h             |                                | A0h            |                     | 120h            |                         |                |
| General<br>Purpose<br>Register                                                                                                                                                                                                                             |                 | General<br>Purpose<br>Register |                | accesses<br>20h-7Fh |                 | accesses<br>A0h - FFh   |                |
| 96 Bytes                                                                                                                                                                                                                                                   |                 | 96 Bytes                       |                | 2011 11 11          | 16Fh<br>170h    |                         | 1EFt<br>1F0h   |
|                                                                                                                                                                                                                                                            | 754             |                                |                |                     | 1756            |                         | 4              |
| Bank 0                                                                                                                                                                                                                                                     | J 7Fh           | Bank 1                         | FFh            | Bank 2              | 17Fh            | Bank 3                  | 1FFł           |
| <ul> <li>Unimplemented data memory locations, read as '0'.</li> <li>* Not a physical register.</li> <li>Note 1: These registers are not implemented on the PIC16F873.</li> <li>2: These registers are reserved, maintain these registers clear.</li> </ul> |                 |                                |                |                     |                 |                         |                |

#### 2.2.2.2 OPTION\_REG Register

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

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

#### **R/W-1** R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 RBPU INTEDG T0CS TOSE PSA PS2 PS1 PS0 bit 7 bit 0 **RBPU:** PORTB Pull-up Enable bit bit 7 1 = PORTB pull-ups are disabled 0 = PORTB pull-ups are enabled by individual port latch values bit 6 **INTEDG:** Interrupt Edge Select bit 1 = Interrupt on rising edge of RB0/INT pin 0 = Interrupt on falling edge of RB0/INT pin bit 5 TOCS: TMR0 Clock Source Select bit 1 = Transition on RA4/T0CKI pin 0 = Internal instruction cycle clock (CLKOUT) bit 4 TOSE: TMR0 Source Edge Select bit 1 = Increment on high-to-low transition on RA4/T0CKI pin 0 = Increment on low-to-high transition on RA4/T0CKI pin bit 3 PSA: Prescaler Assignment bit 1 = Prescaler is assigned to the WDT 0 = Prescaler is assigned to the Timer0 module bit 2-0 PS2:PS0: Prescaler Rate Select bits Bit Value TMR0 Rate WDT Rate 000 1:1 1:2 1:2 001 1:4 010 1:4 1:8 011 1:8 1:16 1:16 100 1:32 101 1:32 1:64 110 1:128 1:64 111 1:128 1:256 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

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

#### **REGISTER 2-2: OPTION\_REG REGISTER (ADDRESS 81h, 181h)**

#### 3.4 **PORTD and TRISD Registers**

PORTD and TRISD are not implemented on the PIC16F873 or PIC16F876.

PORTD is an 8-bit port with Schmitt Trigger input buffers. Each pin is individually configureable as an input or output.

PORTD can be configured as an 8-bit wide microprocessor port (parallel slave port) by setting control bit PSPMODE (TRISE<4>). In this mode, the input buffers are TTL.

#### FIGURE 3-7: PORTD BLOCK DIAGRAM (IN I/O PORT MODE)



| Name     | Bit# | Buffer Type           | Function                                           |
|----------|------|-----------------------|----------------------------------------------------|
| RD0/PSP0 | bit0 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit0. |
| RD1/PSP1 | bit1 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit1. |
| RD2/PSP2 | bit2 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit2. |
| RD3/PSP3 | bit3 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit3. |
| RD4/PSP4 | bit4 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit4. |
| RD5/PSP5 | bit5 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit5. |
| RD6/PSP6 | bit6 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit6. |
| RD7/PSP7 | bit7 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit7. |

#### TABLE 3-7: PORTD FUNCTIONS

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

Note 1: Input buffers are Schmitt Triggers when in I/O mode and TTL buffers when in Parallel Slave Port mode.

#### TABLE 3-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD

| 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 |
|---------|-------|-------|-------------------------------|-------|---------|-------|---------|------------|-----------|--------------------------|---------------------------------|
| 08h     | PORTD | RD7   | RD6                           | RD5   | RD4     | RD3   | RD2     | RD1        | RD0       | xxxx xxxx                | uuuu uuuu                       |
| 88h     | TRISD | PORT  | PORTD Data Direction Register |       |         |       |         |            |           | 1111 1111                |                                 |
| 89h     | TRISE | IBF   | OBF                           | IBOV  | PSPMODE | _     | PORTE I | Data Direc | tion Bits | 0000 -111                | 0000 -111                       |

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

#### TRISE REGISTER (ADDRESS 89h) R/W-1 R-0 R-0 R/W-0 R/W-0 U-0 R/W-1 R/W-1 IBF OBF **IBOV PSPMODE** Bit2 Bit1 Bit0 bit 7 bit 0 Parallel Slave Port Status/Control Bits: bit 7 IBF: Input Buffer Full Status bit 1 = A word has been received and is waiting to be read by the CPU 0 = No word has been received bit 6 **OBF**: Output Buffer Full Status bit 1 = The output buffer still holds a previously written word 0 = The output buffer has been read bit 5 **IBOV**: Input Buffer Overflow Detect bit (in Microprocessor mode) 1 = A write occurred when a previously input word has not been read (must be cleared in software) 0 = No overflow occurred bit 4 PSPMODE: Parallel Slave Port Mode Select bit 1 = PORTD functions in Parallel Slave Port mode 0 = PORTD functions in general purpose I/O mode Unimplemented: Read as '0' bit 3 **PORTE Data Direction Bits:** Bit2: Direction Control bit for pin RE2/CS/AN7 bit 2 1 = Input0 = OutputBit1: Direction Control bit for pin RE1/WR/AN6 bit 1 1 = Input 0 = Output Bit0: Direction Control bit for pin RE0/RD/AN5 bit 0 1 = Input 0 = Output Legend:

W = Writable bit

'1' = Bit is set

U = Unimplemented bit, read as '0'

x = Bit is unknown

'0' = Bit is cleared

R = Readable bit

- n = Value at POR

**REGISTER 3-1:** 

#### 5.2 Using Timer0 with an External Clock

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of TOCKI with the internal phase clocks is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks. Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device.

#### 5.3 Prescaler

There is only one prescaler available, which is mutually exclusively shared between the Timer0 module and the Watchdog Timer. A prescaler assignment for the

**REGISTER 5-1: OPTION REG REGISTER** 

DANA

Timer0 module means that there is no prescaler for the Watchdog Timer, and vice-versa. This prescaler is not readable or writable (see Figure 5-1).

The PSA and PS2:PS0 bits (OPTION\_REG<3:0>) determine the prescaler assignment and prescale ratio.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g. CLRF1, MOVWF1, BSF 1, x....etc.) will clear the prescaler. When assigned to WDT, a CLRWDT instruction will clear the prescaler along with the Watchdog Timer. The prescaler is not readable or writable.

Note: Writing to TMR0, when the prescaler is assigned to Timer0, will clear the prescaler count, but will not change the prescaler assignment.

|                                                                                                                                                                                                                                                                                                 | R/W-1                                                                                                                      | R/W-1                                                       | R/W-1                                                                     | R/W-1         | R/W-1          | R/W-1     | R/W-1          | R/W-1  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------|---------------|----------------|-----------|----------------|--------|--|
|                                                                                                                                                                                                                                                                                                 | RBPU                                                                                                                       | INTEDG                                                      | T0CS                                                                      | TOSE          | PSA            | PS2       | PS1            | PS0    |  |
|                                                                                                                                                                                                                                                                                                 | bit 7                                                                                                                      |                                                             |                                                                           |               |                |           |                | bit 0  |  |
|                                                                                                                                                                                                                                                                                                 |                                                                                                                            |                                                             |                                                                           |               |                |           |                |        |  |
| bit 7                                                                                                                                                                                                                                                                                           | RBPU                                                                                                                       |                                                             |                                                                           |               |                |           |                |        |  |
| bit 6                                                                                                                                                                                                                                                                                           | INTEDG                                                                                                                     |                                                             |                                                                           |               |                |           |                |        |  |
| bit 5                                                                                                                                                                                                                                                                                           | <b>TOCS</b> : TMR0 Clock Source Select bit<br>1 = Transition on T0CKI pin<br>0 = Internal instruction cycle clock (CLKOUT) |                                                             |                                                                           |               |                |           |                |        |  |
| bit 4                                                                                                                                                                                                                                                                                           | 1 = Increm                                                                                                                 | R0 Source Ed<br>nent on high-t<br>nent on low-to            | o-low trans                                                               | sition on TOC | •              |           |                |        |  |
| bit 3                                                                                                                                                                                                                                                                                           | 1 = Presca                                                                                                                 | caler Assign<br>aler is assigne<br>aler is assigne          | ed to the W                                                               |               | e              |           |                |        |  |
| bit 2-0                                                                                                                                                                                                                                                                                         | PS2:PS0:                                                                                                                   | Prescaler Ra                                                | ite Select b                                                              | oits          |                |           |                |        |  |
|                                                                                                                                                                                                                                                                                                 | Bit Value                                                                                                                  | TMR0 Rate                                                   | WDT Rat                                                                   | e             |                |           |                |        |  |
|                                                                                                                                                                                                                                                                                                 | 000<br>001<br>010<br>011<br>100<br>101<br>110<br>111                                                                       | 1:2<br>1:4<br>1:8<br>1:16<br>1:32<br>1:64<br>1:128<br>1:256 | 1 : 1<br>1 : 2<br>1 : 4<br>1 : 8<br>1 : 16<br>1 : 32<br>1 : 64<br>1 : 128 | -             |                |           |                |        |  |
|                                                                                                                                                                                                                                                                                                 | Legend:                                                                                                                    |                                                             |                                                                           |               |                |           |                |        |  |
|                                                                                                                                                                                                                                                                                                 | R = Reada                                                                                                                  | able bit                                                    | VV = V                                                                    | Vritable bit  | U = Unimple    | emented b | it, read as '( | )'     |  |
|                                                                                                                                                                                                                                                                                                 | - n = Value                                                                                                                | e at POR                                                    | '1' = E                                                                   | Bit is set    | '0' = Bit is c | leared    | x = Bit is ur  | nknown |  |
|                                                                                                                                                                                                                                                                                                 |                                                                                                                            |                                                             |                                                                           |               |                |           |                |        |  |
| To avoid an unintended device RESET, the instruction sequence shown in the PIC <sup>®</sup> MCU Mid-Range Fam-<br>ily Reference Manual (DS33023) must be executed when changing the prescaler assignment from Timer0<br>to the WDT. This sequence must be followed even if the WDT is disabled. |                                                                                                                            |                                                             |                                                                           |               |                |           |                |        |  |

Note:

| REGISTER 0-1: | CUPICON                                                                                                            | REGIST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |             | ON REGIS     | SIER (ADDI     | (E33: 1/1   | vidnj        |        |  |
|---------------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|----------------|-------------|--------------|--------|--|
|               | U-0                                                                                                                | U-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W-0       | R/W-0        | R/W-0          | R/W-0       | R/W-0        | R/W-0  |  |
|               | —                                                                                                                  | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CCPxX       | CCPxY        | CCPxM3         | CCPxM2      | CCPxM1       | CCPxM0 |  |
|               | bit 7                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |                |             |              | bit 0  |  |
|               |                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |                |             |              |        |  |
| bit 7-6       | Unimplem                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |                |             |              |        |  |
| bit 5-4       |                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Least Sign  | ificant bits |                |             |              |        |  |
|               | <u>Capture m</u><br>Unused                                                                                         | ode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |              |                |             |              |        |  |
|               | <u>Compare n</u><br>Unused                                                                                         | node:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |              |                |             |              |        |  |
|               | <u>PWM mode</u><br>These bits                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | LSbs of the | e PWM duty   | cycle. The eig | ght MSbs ar | e found in C | CPRxL. |  |
| bit 3-0       | CCPxM3:C                                                                                                           | CPxM0: C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CPx Mode S  | Select bits  |                |             |              |        |  |
|               | 0100 = Ca<br>0101 = Ca<br>0110 = Ca<br>0111 = Ca<br>1000 = Co<br>1001 = Co<br>1010 = Co<br>una<br>1011 = Co<br>res | <pre>CCPxM3:CCPxM0: CCPx Mode Select bits<br/>0000 = Capture/Compare/PWM disabled (resets CCPx module)<br/>0100 = Capture mode, every falling edge<br/>0101 = Capture mode, every rising edge<br/>0110 = Capture mode, every 4th rising edge<br/>0111 = Capture mode, every 16th rising edge<br/>1000 = Compare mode, set output on match (CCPxIF bit is set)<br/>1001 = Compare mode, clear output on match (CCPxIF bit is set)<br/>1010 = Compare mode, generate software interrupt on match (CCPxIF bit is set, CCPx pin is<br/>unaffected)<br/>1011 = Compare mode, trigger special event (CCPxIF bit is set, CCPx pin is unaffected); CCP1<br/>resets TMR1; CCP2 resets TMR1 and starts an A/D conversion (if A/D module is<br/>enabled)<br/>11xx = PWM mode</pre> |             |              |                |             |              |        |  |
|               | Legend:                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |                |             |              |        |  |
|               | R = Reada                                                                                                          | ble bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | VV = V      | Vritable bit | U = Unim       | plemented l | bit, read as | ʻ0'    |  |

'1' = Bit is set

- n = Value at POR

## REGISTER 8-1: CCP1CON REGISTER/CCP2CON REGISTER (ADDRESS: 17h/1Dh)

x = Bit is unknown

'0' = Bit is cleared



#### FIGURE 9-7: I<sup>2</sup>C WAVEFORMS FOR TRANSMISSION (7-BIT ADDRESS)

#### 9.2.2 GENERAL CALL ADDRESS SUPPORT

The addressing procedure for the  $I^2C$  bus is such that the first byte after the START condition usually determines which device will be the slave addressed by the master. The exception is the general call address, which can address all devices. When this address is used, all devices should, in theory, respond with an acknowledge.

The general call address is one of eight addresses reserved for specific purposes by the I<sup>2</sup>C protocol. It consists of all 0's with R/W = 0.

The general call address is recognized when the General Call Enable bit (GCEN) is enabled (SSPCON2<7> is set). Following a START bit detect, 8 bits are shifted into SSPSR and the address is compared against SSPADD. It is also compared to the general call address and fixed in hardware.

If the general call address matches, the SSPSR is transferred to the SSPBUF, the BF flag is set (eighth bit), and on the falling edge of the ninth bit (ACK bit), the SSPIF flag is set.

When the interrupt is serviced, the source for the interrupt can be checked by reading the contents of the SSPBUF to determine if the address was device specific, or a general call address.

In 10-bit mode, the SSPADD is required to be updated for the second half of the address to match, and the UA bit is set (SSPSTAT<1>). If the general call address is sampled when GCEN is set, while the slave is configured in 10-bit address mode, then the second half of the address is not necessary, the UA bit will not be set, and the slave will begin receiving data after the Acknowledge (Figure 9-8).



#### FIGURE 9-8: SLAVE MODE GENERAL CALL ADDRESS SEQUENCE (7 OR 10-BIT MODE)

### 9.2.7 I<sup>2</sup>C MASTER MODE SUPPORT

Master mode is enabled by setting and clearing the appropriate SSPM bits in SSPCON and by setting the SSPEN bit. Once Master mode is enabled, the user has six options:

- Assert a START condition on SDA and SCL.
- Assert a Repeated START condition on SDA and SCL.
- Write to the SSPBUF register initiating transmission of data/address.
- Generate a STOP condition on SDA and SCL.
- Configure the I<sup>2</sup>C port to receive data.
- Generate an Acknowledge condition at the end of a received byte of data.
- Note: The MSSP Module, when configured in I<sup>2</sup>C Master mode, does not allow queueing of events. For instance, the user is not allowed to initiate a START condition and immediately write the SSPBUF register to initiate transmission before the START condition is complete. In this case, the SSPBUF will not be written to and the WCOL bit will be set, indicating that a write to the SSPBUF did not occur.

#### 9.2.7.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  $l^2C$  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 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 SPI mode operation is now used to set the SCL clock frequency for either 100 kHz, 400 kHz, or 1 MHz I<sup>2</sup>C operation. The baud rate generator reload value is contained in the lower 7 bits of the SSPADD register. The baud rate generator will automatically begin counting on a write to the SSPBUF. Once the given operation is complete (i.e., transmission of the last data bit is followed by ACK), the internal clock will automatically stop counting and the SCL pin will remain in its last state.

A typical transmit sequence would go as follows:

- a) User generates a START condition by setting the START enable bit (SEN) in SSPCON2.
- b) SSPIF is set. The module will wait the required start time before any other operation takes place.
- c) User loads SSPBUF with address to transmit.
- d) Address is shifted out the SDA pin until all 8 bits are transmitted.
- e) MSSP module shifts in the ACK bit from the slave device and writes its value into the SSPCON2 register (SSPCON2<6>).
- f) MSSP module generates an interrupt at the end of the ninth clock cycle by setting SSPIF.
- g) User loads SSPBUF with eight bits of data.
- h) DATA is shifted out the SDA pin until all 8 bits are transmitted.
- MSSP module shifts in the ACK bit from the slave device, and writes its value into the SSPCON2 register (SSPCON2<6>).
- MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPIF bit.
- k) User generates a STOP condition by setting the STOP enable bit, PEN, in SSPCON2.
- I) Interrupt is generated once the STOP condition is complete.

#### 9.2.8 BAUD RATE GENERATOR

In  $I^2C$  Master mode, the reload value for the BRG is located in the lower 7 bits of the SSPADD register (Figure 9-10). When the BRG is loaded with this value, the BRG counts down to 0 and stops until another reload has taken place. The BRG count is decremented twice per instruction cycle (Tcr), on the Q2 and Q4 clock.

In I<sup>2</sup>C Master mode, the BRG is reloaded automatically. If clock arbitration is taking place, the BRG will be reloaded when the SCL pin is sampled high (Figure 9-11).

Note: Baud Rate = Fosc / (4 \* (SSPADD + 1))

FIGURE 9-10:

#### BAUD RATE GENERATOR BLOCK DIAGRAM



#### 9.2.14 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 de-asserted. 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-17).

Whenever the firmware decides to take control of the bus, it will first determine if the bus is busy by checking the S and P bits in the SSPSTAT register. If the bus is busy, then the CPU can be interrupted (notified) when a STOP bit is detected (i.e., bus is free).

#### 9.2.14.1 WCOL Status Flag

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





#### 9.2.18.1 Bus Collision During a START Condition

During a START condition, a bus collision occurs if:

- a) SDA or SCL are sampled low at the beginning of the START condition (Figure 9-20).
- b) SCL is sampled low before SDA is asserted low (Figure 9-21).

During a START condition, both the SDA and the SCL pins are monitored. If either the SDA pin <u>or</u> the SCL pin is already low, then these events all occur:

- the START condition is aborted,
- and the BCLIF flag is set,
- <u>and</u> the SSP module is reset to its IDLE state (Figure 9-20).

The START condition begins with the SDA and SCL pins de-asserted. When the SDA pin is sampled high, the baud rate generator is loaded from SSPADD<6:0> and counts down to 0. If the SCL pin is sampled low while SDA is high, a bus collision occurs, because it is assumed that another master is attempting to drive a data '1' during the START condition.

If the SDA pin is sampled low during this count, the BRG is reset and the SDA line is asserted early (Figure 9-22). If, however, a '1' is sampled on the SDA pin, the SDA pin is asserted low at the end of the BRG count. The baud rate generator is then reloaded and counts down to 0. During this time, if the SCL pins are sampled as '0', a bus collision does not occur. At the end of the BRG count, the SCL pin is asserted low.

Note: The reason that bus collision is not a factor during a START condition is that no two bus masters can assert a START condition at the exact same time. Therefore, one master will always assert SDA before the other. This condition does not cause a bus collision, because the two masters must be allowed to arbitrate the first address following the START condition. If the address is the same, arbitration must be allowed to continue into the data portion, Repeated START, or STOP conditions.





|       | SPEN<br>bit 7                  | RX9                                                                  |                   |               |                |              |                |           |
|-------|--------------------------------|----------------------------------------------------------------------|-------------------|---------------|----------------|--------------|----------------|-----------|
|       | hit 7                          |                                                                      | SREN              | CREN          | ADDEN          | FERR         | OERR           | RX9D      |
|       |                                |                                                                      |                   |               |                |              |                | bit C     |
| bit 7 | 1 = Serial p                   | ial Port Ena<br>port enabled                                         | l (configures     | RC7/RX/D      | T and RC6/T    | X/CK pins a  | as serial port | pins)     |
| bit 6 | 1 = Selects                    | Receive Ena<br>9-bit recep<br>8-bit recep                            | tion              |               |                |              |                |           |
| bit 5 | SREN: Sin                      | gle Receive                                                          | Enable bit        |               |                |              |                |           |
|       | Asynchron<br>Don't care        | ous mode:                                                            |                   |               |                |              |                |           |
|       | 1 = Enable<br>0 = Disable      | <u>us mode - n</u><br>s single rec<br>es single rec<br>cleared after | eive              | s complete.   |                |              |                |           |
|       | <u>Synchrono</u><br>Don't care | <u>us mode - s</u>                                                   | lave:             |               |                |              |                |           |
| bit 4 | CREN: Cor                      | ntinuous Re                                                          | ceive Enabl       | e bit         |                |              |                |           |
|       |                                | <u>ous mode:</u><br>s continuou<br>es continuou                      |                   |               |                |              |                |           |
|       |                                |                                                                      |                   | til enable bi | t CREN is cle  | eared (CRE   | N overrides    | SREN)     |
| bit 3 | ADDEN: A                       | ddress Dete                                                          | ect Enable b      | it            |                |              |                |           |
|       | 1 = Enable<br>RSR<8            | s address d<br>⊳ is set                                              |                   | ables interru | ipt and load o |              |                |           |
| bit 2 | FERR: Fra                      | ming Error b<br>g error (can                                         | pit               |               | RCREG regi     |              |                | 1 9       |
| bit 1 |                                | -                                                                    | bit<br>be cleared | by clearing   | bit CREN)      |              |                |           |
| bit 0 | <b>RX9D:</b> 9th               | bit of Rece                                                          | ived Data (c      | an be parity  | bit, but mus   | t be calcula | ted by user    | firmware) |
|       | Legend:                        |                                                                      |                   |               |                |              |                |           |
|       | R = Reada                      | ble bit                                                              | W = W             | /ritable bit  | U = Unim       | plemented    | bit, read as   | ʻ0'       |

'1' = Bit is set

'0' = Bit is cleared

### REGISTER 10-2: RCSTA: RECEIVE STATUS AND CONTROL REGISTER (ADDRESS 18h)

- n = Value at POR

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).
- 2. 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.
- 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D.
- 7. 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.

### 11.5 A/D Operation During SLEEP

The A/D module can operate during SLEEP mode. This requires that the A/D clock source be set to RC (ADCS1:ADCS0 = 11). When the RC clock source is selected, the A/D module waits one instruction cycle before starting the conversion. This allows the SLEEP instruction to be executed, which eliminates all digital switching noise from the conversion. When the conversion is completed, the GO/DONE bit will be cleared and the result loaded into the ADRES register. If the A/D interrupt is enabled, the device will wake-up from SLEEP. If the A/D interrupt is not enabled, the ADON bit will remain set.

When the A/D clock source is another clock option (not RC), a SLEEP instruction will cause the present conversion to be aborted and the A/D module to be turned off, though the ADON bit will remain set.

Turning off the A/D places the A/D module in its lowest current consumption state.

| Note: | For the A/D module to operate in SLEEP,   |
|-------|-------------------------------------------|
|       | the A/D clock source must be set to RC    |
|       | (ADCS1:ADCS0 = 11). To allow the con-     |
|       | version to occur during SLEEP, ensure the |
|       | SLEEP instruction immediately follows the |
|       | instruction that sets the GO/DONE bit.    |

#### 11.6 Effects of a RESET

A device RESET forces all registers to their RESET state. This forces the A/D module to be turned off, and any conversion is aborted. All A/D input pins are configured as analog inputs.

The value that is in the ADRESH:ADRESL registers is not modified for a Power-on Reset. The ADRESH:ADRESL registers will contain unknown data after a Power-on Reset.

| Address               | Name   | Bit 7                | Bit 6      | Bit 5                                                                   | Bit 4   | Bit 3 | Bit 2    | Bit 1       | Bit 0  | Value on<br>POR,<br>BOR | V <u>alue o</u> n<br>MCLR,<br>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                         |
| 1Eh                   | ADRESH | A/D Resul            | t Register | High By                                                                 | te      |       |          |             |        | xxxx xxxx               | uuuu uuuu                         |
| 9Eh                   | ADRESL | A/D Resul            | t Register | Low Byt                                                                 | e       |       |          |             |        | xxxx xxxx               | uuuu uuuu                         |
| 1Fh                   | ADCON0 | ADCS1                | ADCS0      | CHS2                                                                    | CHS1    | CHS0  | GO/DONE  | —           | ADON   | 0000 00-0               | 0000 00-0                         |
| 9Fh                   | ADCON1 | ADFM                 | —          | _                                                                       | —       | PCFG3 | PCFG2    | PCFG1       | PCFG0  | 0- 0000                 | 0- 0000                           |
| 85h                   | TRISA  | —                    | —          | PORTA Data Direction Register                                           |         |       |          |             |        | 11 1111                 | 11 1111                           |
| 05h                   | PORTA  |                      | _          | <ul> <li>PORTA Data Latch when written: PORTA pins when read</li> </ul> |         |       |          |             | ad     | 0x 0000                 | 0u 0000                           |
| 89h <sup>(1)</sup>    | TRISE  | IBF                  | OBF        | IBOV                                                                    | PSPMODE | _     | PORTE Da | ta Directio | n bits | 0000 -111               | 0000 -111                         |
| 09h <sup>(1)</sup>    | PORTE  | —                    | —          |                                                                         | _       | —     | RE2      | RE1         | RE0    | xxx                     | uuu                               |

### TABLE 11-2: REGISTERS/BITS ASSOCIATED WITH A/D

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used for A/D conversion.

**Note 1:** These registers/bits are not available on the 28-pin devices.



### FIGURE 12-7: TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD): CASE 2



### FIGURE 12-8: SLOW RISE TIME (MCLR TIED TO VDD)



| MOVF             | Move f                                                                                                                                                                                                                                                                            |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] MOVF f,d                                                                                                                                                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in [0,1] \end{array}$                                                                                                                                                                                                                       |
| Operation:       | (f) $\rightarrow$ (destination)                                                                                                                                                                                                                                                   |
| Status Affected: | Z                                                                                                                                                                                                                                                                                 |
| Description:     | The contents of register f are<br>moved to a destination dependant<br>upon the status of d. If $d = 0$ ,<br>destination is W register. If $d = 1$ ,<br>the destination is file register f itself.<br>d = 1 is useful to test a file register,<br>since status flag Z is affected. |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |

| MOVLW            | Move Literal to W                                                                          |
|------------------|--------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                   |
| Operands:        | $0 \leq k \leq 255$                                                                        |
| Operation:       | $k \rightarrow (W)$                                                                        |
| Status Affected: | None                                                                                       |
| Description:     | The eight bit literal 'k' is loaded into W register. The don't cares will assemble as 0's. |

| RETFIE           | Return from Interrupt                      |
|------------------|--------------------------------------------|
| Syntax:          | [label] RETFIE                             |
| Operands:        | None                                       |
| Operation:       | $TOS \rightarrow PC, \\ 1 \rightarrow GIE$ |
| Status Affected: | None                                       |

| MOVWF            | Move W to f                                |
|------------------|--------------------------------------------|
| Syntax:          | [ <i>label</i> ] MOVWF f                   |
| Operands:        | $0 \leq f \leq 127$                        |
| Operation:       | $(W) \rightarrow (f)$                      |
| Status Affected: | None                                       |
| Description:     | Move data from W register to register 'f'. |

| RETLW            | Return with Literal in W                                                                                                                                                            |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            |  |  |  |  |
| Operands:        | $0 \leq k \leq 255$                                                                                                                                                                 |  |  |  |  |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                                                                        |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                |  |  |  |  |
| Description:     | The W register is loaded with the<br>eight bit literal 'k'. The program<br>counter is loaded from the top of<br>the stack (the return address).<br>This is a two-cycle instruction. |  |  |  |  |

#### 15.2 DC Characteristics: PIC16F873/874/876/877-04 (Commercial, Industrial) PIC16F873/874/876/877-20 (Commercial, Industrial) PIC16LF873/874/876/877-04 (Commercial, Industrial)

| DC CHA       | RACTE | RISTICS                                 | Operating         | i temp | erature | -40°C<br>0°C | hs (unless otherwise stated)<br>$S \le TA \le +85^{\circ}C$ for industrial<br>$S \le TA \le +70^{\circ}C$ for commercial<br>is described in DC specification |
|--------------|-------|-----------------------------------------|-------------------|--------|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param<br>No. | Sym   | Characteristic                          | Min               | Тур†   | Max     | Units        | Conditions                                                                                                                                                   |
|              | VIL   | Input Low Voltage                       |                   |        |         |              |                                                                                                                                                              |
|              |       | I/O ports                               |                   |        |         |              |                                                                                                                                                              |
| D030         |       | with TTL buffer                         | Vss               | —      | 0.15Vdd | V            | For entire VDD range                                                                                                                                         |
| D030A        |       |                                         | Vss               | —      | 0.8V    | V            | $4.5V \le VDD \le 5.5V$                                                                                                                                      |
| D031         |       | with Schmitt Trigger buffer             | Vss               | —      | 0.2Vdd  | V            |                                                                                                                                                              |
| D032         |       | MCLR, OSC1 (in RC mode)                 | Vss               | —      | 0.2Vdd  | V            |                                                                                                                                                              |
| D033         |       | OSC1 (in XT, HS and LP)                 | Vss               | —      | 0.3Vdd  | V            | (Note 1)                                                                                                                                                     |
|              |       | Ports RC3 and RC4                       |                   | —      |         |              |                                                                                                                                                              |
| D034         |       | with Schmitt Trigger buffer             | Vss               | —      | 0.3Vdd  | V            | For entire VDD range                                                                                                                                         |
| D034A        |       | with SMBus                              | -0.5              | —      | 0.6     | V            | for VDD = 4.5 to 5.5V                                                                                                                                        |
|              | Vih   | Input High Voltage                      |                   |        | r       |              | 1                                                                                                                                                            |
|              |       | I/O ports                               |                   | —      |         |              |                                                                                                                                                              |
| D040         |       | with TTL buffer                         | 2.0               | —      | Vdd     | -            | $4.5V \leq VDD \leq 5.5V$                                                                                                                                    |
| D040A        |       |                                         | 0.25VDD<br>+ 0.8V | _      | Vdd     | V            | For entire VDD range                                                                                                                                         |
| D041         |       | with Schmitt Trigger buffer             | 0.8Vdd            | —      | Vdd     | V            | For entire VDD range                                                                                                                                         |
| D042         |       | MCLR                                    | 0.8Vdd            | —      | Vdd     | V            |                                                                                                                                                              |
| D042A        |       | OSC1 (XT, HS and LP)                    | 0.7Vdd            | —      | Vdd     | V            | (Note 1)                                                                                                                                                     |
| D043         |       | OSC1 (in RC mode)<br>Ports RC3 and RC4  | 0.9Vdd            |        | Vdd     | V            |                                                                                                                                                              |
| D044         |       | with Schmitt Trigger buffer             | 0.7Vdd            | —      | 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°С то +85°С                                                                                                                      |
|              | lı∟   | Input Leakage Current <sup>(2, 3)</sup> |                   | •      |         |              |                                                                                                                                                              |
| D060         |       | I/O ports                               | —                 | —      | ±1      | μΑ           | $Vss \le VPIN \le VDD$ ,<br>Pin at hi-impedance                                                                                                              |
| D061         |       | MCLR, RA4/T0CKI                         | _                 | _      | ±5      | uΑ           | $Vss \leq VPIN \leq VDD$                                                                                                                                     |
| D063         |       | OSC1                                    | —                 | _      | ±5      | •            | $Vss \le VPIN \le VDD$ , XT, HS<br>and LP osc configuration                                                                                                  |

These parameters are characterized but not tested.

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

Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16F87X 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.



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

| Param<br>No. | Symbol       | Charac                                 | teristic            | Min        | Тур† | Мах         | Units | Conditions |
|--------------|--------------|----------------------------------------|---------------------|------------|------|-------------|-------|------------|
| 10*          | TosH2ckL     | OSC1 $\uparrow$ to CLKOUT $\downarrow$ |                     | —          | 75   | 200         | ns    | (Note 1)   |
| 11*          | TosH2ck<br>H | OSC1↑ to CLKOUT↑                       |                     | -          | 75   | 200         | ns    | (Note 1)   |
| 12*          | TckR         | CLKOUT rise time                       |                     | —          | 35   | 100         | ns    | (Note 1)   |
| 13*          | TckF         | CLKOUT fall time                       |                     | —          | 35   | 100         | ns    | (Note 1)   |
| 14*          | TckL2ioV     | CLKOUT $\downarrow$ to Port out vali   | d                   | —          | _    | 0.5TCY + 20 | ns    | (Note 1)   |
| 15*          | TioV2ckH     | Port in valid before CLKO              | TT ↑                | Tosc + 200 | _    | —           | ns    | (Note 1)   |
| 16*          | TckH2iol     | Port in hold after CLKOUT              | · ↑                 | 0          | _    | —           | ns    | (Note 1)   |
| 17*          | TosH2ioV     | OSC1↑ (Q1 cycle) to<br>Port out valid  |                     |            | 100  | 255         | ns    |            |
| 18*          | TosH2iol     | OSC1↑ (Q2 cycle) to                    | Standard (F)        | 100        | _    | —           | ns    |            |
|              |              | Port input invalid (I/O in hold time)  | Extended (LF)       | 200        | _    | —           | ns    |            |
| 19*          | TioV2osH     | Port input valid to OSC1↑              | (I/O in setup time) | 0          | _    | —           | ns    |            |
| 20*          | TioR         | Port output rise time                  | Standard (F)        | —          | 10   | 40          | ns    |            |
|              |              |                                        | Extended (LF)       | —          | _    | 145         | ns    |            |
| 21*          | TioF         | Port output fall time                  | Standard (F)        | —          | 10   | 40          | ns    |            |
|              |              |                                        | Extended (LF)       | —          |      | 145         | ns    |            |
| 22††*        | Tinp         | INT pin high or low time               | •                   | Тсү        | —    | —           | ns    |            |
| 23††*        | Trbp         | RB7:RB4 change INT high                | n or low time       | TCY        |      | —           | ns    |            |

\* These parameters are characterized but not tested.

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

these parameters are asynchronous events not related to any internal clock edges.

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





FIGURE 16-8: AVERAGE FOSC vs. VDD FOR VARIOUS VALUES OF R (RC MODE, C = 100 pF,  $25^{\circ}$ C)



DS30292D-page 180

| Master Mode Operation                            |     |
|--------------------------------------------------|-----|
| Master Mode START Condition                      |     |
| Master Mode Transmission                         |     |
| Master Mode Transmit Sequence                    |     |
| Multi-Master Communication                       |     |
| Multi-master Mode                                |     |
| Operation                                        |     |
| Repeat START Condition Timing                    |     |
| Slave Mode                                       |     |
| Block Diagram                                    |     |
| Slave Reception                                  | 74  |
| Slave Transmission                               |     |
| SSPBUF                                           | 73  |
| STOP Condition Receive or Transmit Timing .      |     |
| STOP Condition Timing                            |     |
| Waveforms for 7-bit Reception                    |     |
| Waveforms for 7-bit Transmission                 | 76  |
| I <sup>2</sup> C Module Address Register, SSPADD | 73  |
| I <sup>2</sup> C Slave Mode                      |     |
| ICEPIC In-Circuit Emulator                       |     |
| ID Locations                                     |     |
| In-Circuit Serial Programming (ICSP)             |     |
|                                                  |     |
| INDF Register                                    |     |
| Indirect Addressing                              |     |
| FSR Register                                     |     |
| Instruction Format                               |     |
| Instruction Set                                  |     |
| ADDLW                                            |     |
| ADDWF                                            |     |
| ANDLW                                            |     |
| ANDWF                                            |     |
| BCF                                              |     |
| BSF                                              |     |
| BTFSC                                            |     |
| BTFSS                                            |     |
| CALL                                             |     |
| CLRF                                             |     |
| CLRW<br>CLRWDT                                   |     |
|                                                  |     |
| COMF<br>DECF                                     |     |
| DECF<br>DECFSZ                                   |     |
|                                                  |     |
|                                                  |     |
| INCFINCFSZ                                       |     |
| INCESZ                                           |     |
| IORUW                                            |     |
| MOVF                                             |     |
| MOVE                                             |     |
| MOVEW                                            | -   |
| NOP                                              |     |
| RETFIE                                           |     |
| RETLW                                            | -   |
| RETURN                                           |     |
| RETORN                                           |     |
| RLF<br>RRF                                       |     |
| SLEEP                                            |     |
| SLEEP<br>SUBLW                                   |     |
| SUBLW                                            |     |
| SUBWF                                            |     |
| XORLW                                            |     |
| XORUV                                            |     |
| Summary Table                                    |     |
| Summary rable                                    | 130 |

| INT Interrupt (RB0/INT). See Interrupt Sources                                                                                                                         |                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                        | 47                                                                                                    |
|                                                                                                                                                                        |                                                                                                       |
| INTCON Register                                                                                                                                                        |                                                                                                       |
| GIE Bit                                                                                                                                                                |                                                                                                       |
| INTE Bit                                                                                                                                                               |                                                                                                       |
| INTF Bit                                                                                                                                                               |                                                                                                       |
| PEIE Bit                                                                                                                                                               |                                                                                                       |
| RBIE Bit                                                                                                                                                               |                                                                                                       |
| RBIF Bit2                                                                                                                                                              | · ·                                                                                                   |
| TOIE Bit                                                                                                                                                               |                                                                                                       |
| TOIF Bit                                                                                                                                                               |                                                                                                       |
| Inter-Integrated Circuit (I <sup>2</sup> C)                                                                                                                            |                                                                                                       |
| Internal Sampling Switch (Rss) Impedence                                                                                                                               |                                                                                                       |
| Interrupt Sources119                                                                                                                                                   |                                                                                                       |
| Block Diagram                                                                                                                                                          |                                                                                                       |
| Interrupt-on-Change (RB7:RB4)                                                                                                                                          |                                                                                                       |
| RB0/INT Pin, External7, 8                                                                                                                                              | 3, 130                                                                                                |
| TMR0 Overflow                                                                                                                                                          | . 130                                                                                                 |
| USART Receive/Transmit Complete                                                                                                                                        | 95                                                                                                    |
| Interrupts                                                                                                                                                             |                                                                                                       |
| Bus Collision Interrupt                                                                                                                                                | 24                                                                                                    |
| Synchronous Serial Port Interrupt                                                                                                                                      |                                                                                                       |
| Interrupts, Context Saving During                                                                                                                                      |                                                                                                       |
| Interrupts, Enable Bits                                                                                                                                                |                                                                                                       |
| Global Interrupt Enable (GIE Bit)20                                                                                                                                    | ). 129                                                                                                |
| Interrupt-on-Change (RB7:RB4) Enable                                                                                                                                   | , -                                                                                                   |
| (RBIE Bit)                                                                                                                                                             | 130                                                                                                   |
| Interrupt-on-Change (RB7:RB4) Enable                                                                                                                                   | 100                                                                                                   |
| (RBIE Bit)                                                                                                                                                             | 20                                                                                                    |
| Peripheral Interrupt Enable (PEIE Bit)                                                                                                                                 |                                                                                                       |
| RB0/INT Enable (INTE Bit)                                                                                                                                              |                                                                                                       |
|                                                                                                                                                                        |                                                                                                       |
| TMR0 Overflow Enable (T0IE Bit)                                                                                                                                        | 20                                                                                                    |
| Interrupts, Flag Bits                                                                                                                                                  |                                                                                                       |
| Interrupt-on-Change (RB7:RB4) Flag                                                                                                                                     | 400                                                                                                   |
|                                                                                                                                                                        |                                                                                                       |
| (RBIF Bit)                                                                                                                                                             | . 130                                                                                                 |
| Interrupt-on-Change (RB7:RB4) Flag                                                                                                                                     |                                                                                                       |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2                                                                                                                      | 20, 31                                                                                                |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)                                                                                           | 20, 31<br>20                                                                                          |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2                                                                                                                      | 20, 31<br>20                                                                                          |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20                                                        | 20, 31<br>20                                                                                          |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20                                                        | 20, 31<br>20<br>), 130                                                                                |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20                                                        | 20, 31<br>20<br>), 130                                                                                |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20<br><b>K</b><br>KEELOQ Evaluation and Programming Tools | 20, 31<br>20<br>), 130                                                                                |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20<br>K<br>KEELOQ Evaluation and Programming Tools        | 20, 31<br>20<br>), 130<br>146                                                                         |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)2<br>RB0/INT Flag (INTF Bit)<br>TMR0 Overflow Flag (T0IF Bit)20<br>K<br>KEELOQ Evaluation and Programming Tools        | 20, 31<br>20<br>), 130<br>146                                                                         |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146                                                                         |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26                                                                   |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>7, 8                                                           |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>7, 8<br>5, 126                                                 |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>7, 8<br>5, 126                                                 |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>0, 130<br>146<br>26<br>7, 8<br>5, 126<br>5, 126                                       |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>0, 130<br>146<br>26<br>7, 8<br>5, 126<br>5, 126                                       |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>7, 8<br>5, 126<br>5, 126<br>5, 126<br>12<br>11                 |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>7, 8<br>5, 126<br>5, 126<br>5, 126<br>12<br>11                 |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>5, 126<br>5, 126<br>5, 126<br>12<br>11<br>143                  |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>5, 126<br>5, 126<br>5, 126<br>12<br>11<br>143                  |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>26<br>26<br>126<br>12<br>11<br>143<br>145                      |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>26<br>26<br>12<br>126<br>126<br>126<br>144                     |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>), 130<br>146<br>26<br>26<br>26<br>12<br>126<br>126<br>127<br>144<br>143              |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>0, 130<br>146<br>26<br>26<br>26<br>12<br>126<br>126<br>127<br>144<br>143<br>144       |
| Interrupt-on-Change (RB7:RB4) Flag<br>(RBIF Bit)                                                                                                                       | 20, 31<br>20<br>0, 130<br>146<br>26<br>26<br>26<br>12<br>146<br>145<br>145<br>144<br>143<br>144<br>89 |

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

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

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

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

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

#### Trademarks

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

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

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

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

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

GestIC and ULPP are registered trademarks of Microchip Technology Germany II GmbH & Co. & KG, a subsidiary of Microchip Technology Inc., in other countries.

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

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

Printed on recycled paper.

ISBN: 9781620769294

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