



#### 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                      | 10MHz                                                                      |
| Connectivity               | I²C, SPI, UART/USART                                                       |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 22                                                                         |
| Program Memory Size        | 14KB (8K x 14)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 368 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                  |
| Data Converters            | A/D 5x10b                                                                  |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 28-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf876a-i-ss |
|                            |                                                                            |

Email: info@E-XFL.COM

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

### 3.6 Writing to Flash Program Memory

Flash program memory may only be written to if the destination address is in a segment of memory that is not write-protected, as defined in bits WRT1:WRT0 of the device configuration word (Register 14-1). Flash program memory must be written in four-word blocks. A block consists of four words with sequential addresses, with a lower boundary defined by an address, where EEADR<1:0> = 00. At the same time, all block writes to program memory are done as erase and write operations. The write operation is edge-aligned and cannot occur across boundaries.

To write program data, it must first be loaded into the buffer registers (see Figure 3-1). This is accomplished by first writing the destination address to EEADR and EEADRH and then writing the data to EEDATA and EEDATH. After the address and data have been set up, then the following sequence of events must be executed:

- 1. Set the EEPGD control bit (EECON1<7>).
- 2. Write 55h, then AAh, to EECON2 (Flash programming sequence).
- 3. Set the WR control bit (EECON1<1>).

All four buffer register locations **MUST** be written to with correct data. If only one, two or three words are being written to in the block of four words, then a read from the program memory location(s) not being written to must be performed. This takes the data from the program location(s) not being written and loads it into the EEDATA and EEDATH registers. Then the sequence of events to transfer data to the buffer registers must be executed. To transfer data from the buffer registers to the program memory, the EEADR and EEADRH must point to the last location in the four-word block (EEADR<1:0> = 11). Then the following sequence of events must be executed:

- 1. Set the EEPGD control bit (EECON1<7>).
- 2. Write 55h, then AAh, to EECON2 (Flash programming sequence).
- Set control bit WR (EECON1<1>) to begin the write operation.

The user must follow the same specific sequence to initiate the write for each word in the program block, writing each program word in sequence (00, 01, 10, 11). When the write is performed on the last word (EEADR<1:0> = 11), the block of four words are automatically erased and the contents of the buffer registers are written into the program memory.

After the "BSF EECON1, WR" instruction, the processor requires two cycles to set up the erase/write operation. The user must place two NOP instructions after the WR bit is set. Since data is being written to buffer registers, the writing of the first three words of the block appears to occur immediately. The processor will halt internal operations for the typical 4 ms, only during the cycle in which the erase takes place (i.e., the last word of the four-word block). This is not Sleep mode as the clocks and peripherals will continue to run. After the write cycle, the processor will resume operation with the third instruction after the EECON1 write instruction. If the sequence is performed to any other location, the action is ignored.



### 3.7 Protection Against Spurious Write

There are conditions when the device should not write to the data EEPROM or Flash program memory. To protect against spurious writes, various mechanisms have been built-in. On power-up, WREN is cleared. Also, the Power-up Timer (72 ms duration) prevents an EEPROM write.

The write initiate sequence and the WREN bit together help prevent an accidental write during brown-out, power glitch or software malfunction.

#### 3.8 Operation During Code-Protect

When the data EEPROM is code-protected, the microcontroller can read and write to the EEPROM normally. However, all external access to the EEPROM is disabled. External write access to the program memory is also disabled.

When program memory is code-protected, the microcontroller can read and write to program memory normally, as well as execute instructions. Writes by the device may be selectively inhibited to regions of the memory depending on the setting of bits WR1:WR0 of the configuration word (see **Section 14.1 "Configuration Bits"** for additional information). External access to the memory is also disabled.

## TABLE 3-1:REGISTERS/BITS ASSOCIATED WITH DATA EEPROM AND<br/>FLASH PROGRAM MEMORIES

| Address | Name   | Bit 7  | Bit 6     | Bit 5     | Bit 4     | Bit 3        | Bit 2     | Bit 1        | Bit 0  | Value on<br>Power-on<br>Reset | Value on<br>all other<br>Resets |
|---------|--------|--------|-----------|-----------|-----------|--------------|-----------|--------------|--------|-------------------------------|---------------------------------|
| 10Ch    | EEDATA | EEPROM | 1/Flash D | ata Regis | ster Low  |              | XXXX XXXX | uuuu uuuu    |        |                               |                                 |
| 10Dh    | EEADR  | EEPRON | 1/Flash A | ddress R  | egister L | ow Byte      |           |              |        | xxxx xxxx                     | uuuu uuuu                       |
| 10Eh    | EEDATH | _      | _         | EEPRO     | M/Flash [ |              | xxxx xxxx | 0 q000       |        |                               |                                 |
| 10Fh    | EEADRH | _      | _         | _         | EEPRO     | M/Flash Ad   | dress Reg | ister High B | yte    | xxxx xxxx                     |                                 |
| 18Ch    | EECON1 | EEPGD  | _         | —         | —         | WRERR        | WREN      | WR           | RD     | x x000                        | 0 q000                          |
| 18Dh    | EECON2 | EEPROM | 1 Control | Register  | 2 (not a  | physical reg | gister)   |              |        |                               |                                 |
| 0Dh     | PIR2   |        | CMIF      | —         | EEIF      | BCLIF        | —         | _            | CCP2IF | -0-0 00                       | -0-0 00                         |
| 8Dh     | PIE2   | _      | CMIE      | _         | EEIE      | BCLIE        | _         | _            | CCP2IE | -0-0 00                       | -0-0 00                         |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends upon condition. Shaded cells are not used by data EEPROM or Flash program memory.

### 8.2 Compare Mode

In Compare mode, the 16-bit CCPR1 register value is constantly compared against the TMR1 register pair value. When a match occurs, the RC2/CCP1 pin is:

- Driven high
- Driven low
- Remains unchanged

The action on the pin is based on the value of control bits, CCP1M3:CCP1M0 (CCP1CON<3:0>). At the same time, interrupt flag bit CCP1IF is set.

#### FIGURE 8-2: COMPARE MODE OPERATION BLOCK DIAGRAM



### 8.2.1 CCP PIN CONFIGURATION

The user must configure the RC2/CCP1 pin as an output by clearing the TRISC<2> bit.

| Note: | Clearing the CCP1CON register will force |
|-------|------------------------------------------|
|       | the RC2/CCP1 compare output latch to     |
|       | the default low level. This is not the   |
|       | PORTC I/O data latch.                    |

#### 8.2.2 TIMER1 MODE SELECTION

Timer1 must be running in Timer mode, or Synchronized Counter mode, if the CCP module is using the compare feature. In Asynchronous Counter mode, the compare operation may not work.

#### 8.2.3 SOFTWARE INTERRUPT MODE

When Generate Software Interrupt mode is chosen, the CCP1 pin is not affected. The CCPIF bit is set, causing a CCP interrupt (if enabled).

#### 8.2.4 SPECIAL EVENT TRIGGER

In this mode, an internal hardware trigger is generated which may be used to initiate an action.

The special event trigger output of CCP1 resets the TMR1 register pair. This allows the CCPR1 register to effectively be a 16-bit programmable period register for Timer1.

The special event trigger output of CCP2 resets the TMR1 register pair and starts an A/D conversion (if the A/D module is enabled).



|                        | =       |                      |                                      | •           |           |         |        |         |         | _             |      |       |                        |
|------------------------|---------|----------------------|--------------------------------------|-------------|-----------|---------|--------|---------|---------|---------------|------|-------|------------------------|
| Address                | Name    | Bit 7                | Bit 6                                | Bit 5       | Bit 4     | Bit 3   | Bit 2  | Bit 1   | Bit 0   | Value<br>POR, |      | all o | ie on<br>other<br>sets |
| 0Bh,8Bh,<br>10Bh, 18Bh | INTCON  | GIE                  | PEIE                                 | TMR0IE      | INTE      | RBIE    | TMR0IF | INTF    | RBIF    | 0000          | 000x | 0000  | 000u                   |
| 0Ch                    | PIR1    | PSPIF <sup>(1)</sup> | ADIF                                 | RCIF        | TXIF      | SSPIF   | CCP1IF | TMR2IF  | TMR1IF  | 0000          | 0000 | 0000  | 0000                   |
| 0Dh                    | PIR2    | _                    | _                                    | _           | _         | _       | _      | _       | CCP2IF  |               | 0    |       | 0                      |
| 8Ch                    | PIE1    | PSPIE <sup>(1)</sup> | ADIE                                 | RCIE        | TXIE      | SSPIE   | CCP1IE | TMR2IE  | TMR1IE  | 0000          | 0000 | 0000  | 0000                   |
| 8Dh                    | PIE2    | —                    | —                                    | _           | —         | _       | —      | —       | CCP2IE  |               | 0    |       | 0                      |
| 87h                    | TRISC   | PORTC D              | PORTC Data Direction Register        |             |           |         |        |         |         |               |      |       | 1111                   |
| 11h                    | TMR2    | Timer2 M             | odule's Reg                          | ister       |           |         |        |         |         | 0000          | 0000 | 0000  | 0000                   |
| 92h                    | PR2     | Timer2 M             | odule's Peri                         | od Register |           |         |        |         |         | 1111          | 1111 | 1111  | 1111                   |
| 12h                    | T2CON   | _                    | TOUTPS3                              | TOUTPS2     | TOUTPS1   | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000          | 0000 | -000  | 0000                   |
| 15h                    | CCPR1L  | Capture/C            | Compare/PV                           | VM Registe  | r 1 (LSB) |         |        |         |         | xxxx          | xxxx | uuuu  | uuuu                   |
| 16h                    | CCPR1H  | Capture/C            | Compare/PV                           | VM Registe  | r 1 (MSB) |         |        |         |         | xxxx          | xxxx | uuuu  | uuuu                   |
| 17h                    | CCP1CON | _                    | _                                    | CCP1X       | CCP1Y     | CCP1M3  | CCP1M2 | CCP1M1  | CCP1M0  | 00            | 0000 | 00    | 0000                   |
| 1Bh                    | CCPR2L  | Capture/C            | Capture/Compare/PWM Register 2 (LSB) |             |           |         |        |         |         |               |      | uuuu  | uuuu                   |
| 1Ch                    | CCPR2H  | Capture/C            | Compare/PV                           | VM Registe  | r 2 (MSB) |         |        |         |         | xxxx          | xxxx | uuuu  | uuuu                   |
| 1Dh                    | CCP2CON | _                    | —                                    | CCP2X       | CCP2Y     | CCP2M3  | CCP2M2 | CCP2M1  | CCP2M0  | 00            | 0000 | 00    | 0000                   |

TABLE 8-5: REGISTERS ASSOCIATED WITH PWM AND TIMER2

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

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



#### 9.4.6 MASTER MODE

Master mode is enabled by setting and clearing the appropriate SSPM bits in SSPCON and by setting the SSPEN bit. In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.

Master mode of operation is supported by interrupt generation on the detection of the Start and Stop conditions. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the  $I^2C$  bus may be taken when the P bit is set or the bus is Idle, with both the S and P bits clear.

In Firmware Controlled Master mode, user code conducts all  $I^2C$  bus operations based on Start and Stop bit conditions.

Once Master mode is enabled, the user has six options.

- 1. Assert a Start condition on SDA and SCL.
- 2. Assert a Repeated Start condition on SDA and SCL.
- 3. Write to the SSPBUF register, initiating transmission of data/address.
- 4. Configure the I<sup>2</sup>C port to receive data.
- 5. Generate an Acknowledge condition at the end of a received byte of data.
- 6. Generate a Stop condition on SDA and SCL.

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

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

- · Start condition
- Stop condition
- Data transfer byte transmitted/received
- Acknowledge transmit
- Repeated Start



© 2001-2013 Microchip Technology Inc.

NOTES:

#### 10.1 USART Baud Rate Generator (BRG)

The BRG supports both the Asynchronous and Synchronous modes of the USART. It is a dedicated 8-bit baud rate generator. The SPBRG register controls the period of a free running 8-bit timer. In Asynchronous mode, bit BRGH (TXSTA<2>) also controls the baud rate. In Synchronous mode, bit BRGH is ignored. Table 10-1 shows the formula for computation of the baud rate for different USART modes which only apply in Master mode (internal clock).

Given the desired baud rate and FOSC, the nearest integer value for the SPBRG register can be calculated using the formula in Table 10-1. From this, the error in baud rate can be determined. It may be advantageous to use the high baud rate (BRGH = 1) even for slower baud clocks. This is because the FOSC/(16 (X + 1)) equation can reduce the baud rate error in some cases.

Writing a new value to the SPBRG register causes the BRG timer to be reset (or cleared). This ensures the BRG does not wait for a timer overflow before outputting the new baud rate.

#### 10.1.1 SAMPLING

The data on the RC7/RX/DT pin is sampled three times by a majority detect circuit to determine if a high or a low level is present at the RX pin.

#### TABLE 10-1: BAUD RATE FORMULA

| SYNC | BRGH = 0 (Low Speed)                         | BRGH = 1 (High Speed)           |  |  |  |  |  |
|------|----------------------------------------------|---------------------------------|--|--|--|--|--|
| 0    | (Asynchronous) Baud Rate = Fosc/(64 (X + 1)) | Baud Rate = $FOSC/(16 (X + 1))$ |  |  |  |  |  |
| 1    | (Synchronous) Baud Rate = FOSC/(4 (X + 1))   | N/A                             |  |  |  |  |  |

**Legend:** X = value in SPBRG (0 to 255)

### TABLE 10-2: REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR

| Address | Name                                  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BO | all     | ue on<br>other<br>sets |
|---------|---------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|---------------------|---------|------------------------|
| 98h     | TXSTA                                 | CSRC  | TX9   | TXEN  | SYNC  | _     | BRGH  | TRMT  | TX9D  | 0000 -01            | .0 0000 | -010                   |
| 18h     | RCSTA                                 | SPEN  | RX9   | SREN  | CREN  | ADDEN | FERR  | OERR  | RX9D  | 0000 000            | x 0000  | 000x                   |
| 99h     | 9h SPBRG Baud Rate Generator Register |       |       |       |       |       |       |       |       | 0000 000            | 0 0000  | 0000                   |

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

#### 10.3.2 USART SYNCHRONOUS MASTER RECEPTION

Once Synchronous mode is selected, reception is enabled by setting either enable bit, SREN (RCSTA<5>), or enable bit, CREN (RCSTA<4>). Data is sampled on the RC7/RX/DT pin on the falling edge of the clock. If enable bit SREN is set, then only a single word is received. If enable bit CREN is set, the reception is continuous until CREN is cleared. If both bits are set, CREN takes precedence. After clocking the last bit, the received data in the Receive Shift Register (RSR) is transferred to the RCREG register (if it is empty). When the transfer is complete, interrupt flag bit, RCIF (PIR1<5>), is set. The actual interrupt can be enabled/ disabled by setting/clearing enable bit, RCIE (PIE1<5>). Flag bit RCIF is a read-only bit which is reset by the hardware. In this case, it is reset when the RCREG register has been read and is empty. The RCREG is a double-buffered register (i.e., it is a twodeep FIFO). It is possible for two bytes of data to be received and transferred to the RCREG FIFO and a third byte to begin shifting into the RSR register. On the clocking of the last bit of the third byte, if the RCREG register is still full, then Overrun Error bit, OERR (RCSTA<1>), is set. The word in the RSR will be lost. The RCREG register can be read twice to retrieve the two bytes in the FIFO. Bit OERR has to be cleared in software (by clearing bit CREN). If bit OERR is set, transfers from the RSR to the RCREG are inhibited so it is essential to clear bit OERR if it is set. The ninth receive bit is buffered the same way as the receive

data. Reading the RCREG register will load bit RX9D with a new value, therefore, it is essential for the user to read the RCSTA register before reading RCREG in order not to lose the old RX9D information.

When setting up a Synchronous Master Reception:

- 1. Initialize the SPBRG register for the appropriate baud rate (Section 10.1 "USART Baud Rate Generator (BRG)").
- 2. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 3. Ensure bits CREN and SREN are clear.
- 4. If interrupts are desired, then set enable bit RCIE.
- 5. If 9-bit reception is desired, then set bit RX9.
- 6. If a single reception is required, set bit SREN. For continuous reception, set bit CREN.
- Interrupt flag bit RCIF will be set when reception is complete and an interrupt will be generated if enable bit RCIE was set.
- 8. Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 9. Read the 8-bit received data by reading the RCREG register.
- 10. If any error occurred, clear the error by clearing bit CREN.
- 11. If using interrupts, ensure that GIE and PEIE (bits 7 and 6) of the INTCON register are set.

| - <b>3</b> . KL |                                                           |                                                                                                     |                                                                                                          |                                                                                                                                                                                                  |                                                                                                                                                                                              |                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name            | Bit 7                                                     | Bit 6                                                                                               | Bit 5                                                                                                    | Bit 4                                                                                                                                                                                            | Bit 3                                                                                                                                                                                        | Bit 2                                                                                                                                                                                                                                                       | Bit 1                                                                                                                                                                                                                                                | Bit 0                                                                                                                                                                                                                                                                         | Value on:<br>POR, BOR                                                                                                                                                                                                                                                                                      | Value on<br>all other<br>Resets                                                                                                                                                                                                                                                                                                                                                                        |
| INTCON          | GIE                                                       | PEIE                                                                                                | TMR0IE                                                                                                   | INTE                                                                                                                                                                                             | RBIE                                                                                                                                                                                         | TMR0IF                                                                                                                                                                                                                                                      | INTF                                                                                                                                                                                                                                                 | R0IF                                                                                                                                                                                                                                                                          | 0000 000x                                                                                                                                                                                                                                                                                                  | 0000 000u                                                                                                                                                                                                                                                                                                                                                                                              |
| PIR1            | PSPIF <sup>(1)</sup>                                      | ADIF                                                                                                | RCIF                                                                                                     | TXIF                                                                                                                                                                                             | SSPIF                                                                                                                                                                                        | CCP1IF                                                                                                                                                                                                                                                      | TMR2IF                                                                                                                                                                                                                                               | TMR1IF                                                                                                                                                                                                                                                                        | 0000 0000                                                                                                                                                                                                                                                                                                  | 0000 0000                                                                                                                                                                                                                                                                                                                                                                                              |
| RCSTA           | SPEN                                                      | RX9                                                                                                 | SREN                                                                                                     | CREN                                                                                                                                                                                             |                                                                                                                                                                                              | FERR                                                                                                                                                                                                                                                        | OERR                                                                                                                                                                                                                                                 | RX9D                                                                                                                                                                                                                                                                          | 0000 -00x                                                                                                                                                                                                                                                                                                  | 0000 -00x                                                                                                                                                                                                                                                                                                                                                                                              |
| RCREG           | USART Re                                                  | eceive Re                                                                                           | gister                                                                                                   |                                                                                                                                                                                                  |                                                                                                                                                                                              |                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                               | 0000 0000                                                                                                                                                                                                                                                                                                  | 0000 0000                                                                                                                                                                                                                                                                                                                                                                                              |
| PIE1            | PSPIE <sup>(1)</sup>                                      | ADIE                                                                                                | RCIE                                                                                                     | TXIE                                                                                                                                                                                             | SSPIE                                                                                                                                                                                        | CCP1IE                                                                                                                                                                                                                                                      | TMR2IE                                                                                                                                                                                                                                               | TMR1IE                                                                                                                                                                                                                                                                        | 0000 0000                                                                                                                                                                                                                                                                                                  | 0000 0000                                                                                                                                                                                                                                                                                                                                                                                              |
| TXSTA           | CSRC                                                      | TX9                                                                                                 | TXEN                                                                                                     | SYNC                                                                                                                                                                                             |                                                                                                                                                                                              | BRGH                                                                                                                                                                                                                                                        | TRMT                                                                                                                                                                                                                                                 | TX9D                                                                                                                                                                                                                                                                          | 0000 -010                                                                                                                                                                                                                                                                                                  | 0000 -010                                                                                                                                                                                                                                                                                                                                                                                              |
| SPBRG           | Baud Rate                                                 | Generato                                                                                            | or Register                                                                                              | r                                                                                                                                                                                                |                                                                                                                                                                                              |                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                               | 0000 0000                                                                                                                                                                                                                                                                                                  | 0000 0000                                                                                                                                                                                                                                                                                                                                                                                              |
|                 | Name<br>INTCON<br>PIR1<br>RCSTA<br>RCREG<br>PIE1<br>TXSTA | NameBit 7INTCONGIEPIR1PSPIF <sup>(1)</sup> RCSTASPENRCREGUSART RePIE1PSPIE <sup>(1)</sup> TXSTACSRC | NameBit 7Bit 6INTCONGIEPEIEPIR1PSPIF(1)ADIFRCSTASPENRX9RCREGUSART Receive RePIE1PSPIE(1)ADIETXSTACSRCTX9 | NameBit 7Bit 6Bit 5INTCONGIEPEIETMR0IEPIR1PSPIF <sup>(1)</sup> ADIFRCIFRCSTASPENRX9SRENRCREGUSART Receive RegisterPIE1PSPIE <sup>(1)</sup> ADIEPIE1PSPIE <sup>(1)</sup> ADIERCIETXSTACSRCTX9TXEN | NameBit 7Bit 6Bit 5Bit 4INTCONGIEPEIETMROIEINTEPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFRCSTASPENRX9SRENCRENRCREGUSART Receive RegisterFIE1PSPIE <sup>(1)</sup> ADIERCIETXIETXSTACSRCTX9TXENSYNC | NameBit 7Bit 6Bit 5Bit 4Bit 3INTCONGIEPEIETMROIEINTERBIEPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFSSPIFRCSTASPENRX9SRENCREN—RCREGUSART Receive RegisterFIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIEPIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIETXSTACSRCTX9TXENSYNC— | NameBit 7Bit 6Bit 5Bit 4Bit 3Bit 2INTCONGIEPEIETMR0IEINTERBIETMR0IFPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFSSPIFCCP1IFRCSTASPENRX9SRENCREN—FERRRCREGUSART Receive RegisterFFFFPIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIECCP1IETXSTACSRCTX9TXENSYNC—BRGH | NameBit 7Bit 6Bit 5Bit 4Bit 3Bit 2Bit 1INTCONGIEPEIETMROIEINTERBIETMROIFINTFPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFSSPIFCCP1IFTMR2IFRCSTASPENRX9SRENCREN—FERROERRRCREGUSART Receive RegisterFIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIECCP1IETMR2IETXSTACSRCTX9TXENSYNC—BRGHTRMT | NameBit 7Bit 6Bit 5Bit 4Bit 3Bit 2Bit 1Bit 0INTCONGIEPEIETMROIEINTERBIETMROIFINTFROIFPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFSSPIFCCP1IFTMR2IFTMR1IFRCSTASPENRX9SRENCREN—FERROERRRX9DRCREGUSART Receive RegisterFIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIECCP1IETMR2IETMR1IETXSTACSRCTX9TXENSYNC—BRGHTRMTTX9D | NameBit 7Bit 6Bit 5Bit 4Bit 3Bit 2Bit 1Bit 0Value on:<br>POR, BORINTCONGIEPEIETMROIEINTERBIETMROIFINTFROIF0000000xPIR1PSPIF <sup>(1)</sup> ADIFRCIFTXIFSSPIFCCP1IFTMR2IFTMR1IF00000000RCSTASPENRX9SRENCREN—FERROERRRX9D0000-00xRCREGUSART Receive RegisterSSPIECCP1IETMR2IETMR1IE00000000PIE1PSPIE <sup>(1)</sup> ADIERCIETXIESSPIECCP1IETMR2IETMR1IE00000000TXSTACSRCTX9TXENSYNC—BRGHTRMTTX9D0000-010 |

#### TABLE 10-9: REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER RECEPTION

Legend: x = unknown, - = unimplemented, read as '0'. Shaded cells are not used for synchronous master reception. Note 1: Bits PSPIE and PSPIF are reserved on 28-pin devices; always maintain these bits clear.

NOTES:





| <b>TABLE 13-1</b> : | REGISTERS ASSOCIATED WITH COMPARATOR VOLTAGE REFERENCE |
|---------------------|--------------------------------------------------------|
|---------------------|--------------------------------------------------------|

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR | Value on<br>all other<br>Resets |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------|---------------------------------|
| 9Dh     | CVRCON | CVREN | CVROE | CVRR  |       | CVR3  | CVR2  | CVR1  | CVR0  | 000- 0000       | 000- 0000                       |
| 9Ch     | CMCON  | C2OUT | C10UT | C2INV | C1INV | CIS   | CM2   | CM1   | CM0   | 0000 0111       | 0000 0111                       |

**Legend:** x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used with the comparator voltage reference.

### 14.0 SPECIAL FEATURES OF THE CPU

All PIC16F87XA devices have a host of features intended to maximize system reliability, minimize cost through elimination of external components, provide power saving operating modes and offer code protection. These are:

- Oscillator Selection
- Reset
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- Sleep
- Code Protection
- ID Locations
- In-Circuit Serial Programming
- Low-Voltage In-Circuit Serial Programming
- In-Circuit Debugger

PIC16F87XA devices have a Watchdog Timer which can be shut-off only through configuration bits. It runs off its own RC oscillator for added reliability.

There are two timers that offer necessary delays on power-up. One is the Oscillator Start-up Timer (OST), intended to keep the chip in Reset until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed delay of 72 ms (nominal) on power-up only. It is designed to keep the part in Reset while the power supply stabilizes. With these two timers on-chip, most applications need no external Reset circuitry. Sleep mode is designed to offer a very low current power-down mode. The user can wake-up from Sleep through external Reset, Watchdog Timer wake-up or through an interrupt.

Several oscillator options are also made available to allow the part to fit the application. The RC oscillator option saves system cost while the LP crystal option saves power. A set of configuration bits is used to select various options.

Additional information on special features is available in the PIC<sup>®</sup> Mid-Range MCU Family Reference Manual (DS33023).

### 14.1 Configuration Bits

The configuration bits can be programmed (read as '0'), or left unprogrammed (read as '1') to select various device configurations. The erased or unprogrammed value of the Configuration Word register is 3FFFh. These bits are mapped in program memory location 2007h.

It is important to note that address 2007h is beyond the user program memory space which can be accessed only during programming.



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



#### FIGURE 14-9: SLOW RISE TIME (MCLR TIED TO VDD VIA RC NETWORK)



| TABLE 15-2: PIC16 | F87XA INSTRUCTION SET |
|-------------------|-----------------------|
|-------------------|-----------------------|

| Mnem    | ionic, | Description                                    | Cycles        |       | 14-Bit | Opcode | e    | Status   | Notes |
|---------|--------|------------------------------------------------|---------------|-------|--------|--------|------|----------|-------|
| Oper    | ands   | Description                                    | Cycles        | MSb   |        |        | LSb  | Affected | Notes |
|         |        | BYTE-ORIENTED FILE                             | EREGISTER OPE | RATIC | NS     |        |      |          |       |
| ADDWF   | f, d   | Add W and f                                    | 1             | 00    | 0111   | dfff   | ffff | C,DC,Z   | 1,2   |
| ANDWF   | f, d   | AND W with f                                   | 1             | 00    | 0101   | dfff   | ffff | Z        | 1,2   |
| CLRF    | f      | Clear f                                        | 1             | 00    | 0001   | lfff   | ffff | Z        | 2     |
| CLRW    | -      | Clear W                                        | 1             | 00    | 0001   | 0xxx   | xxxx | Z        |       |
| COMF    | f, d   | Complement f                                   | 1             | 00    | 1001   | dfff   | ffff | Z        | 1,2   |
| DECF    | f, d   | Decrement f                                    | 1             | 00    | 0011   | dfff   | ffff | Z        | 1,2   |
| DECFSZ  | f, d   | Decrement f, Skip if 0                         | 1(2)          | 00    | 1011   | dfff   | ffff |          | 1,2,3 |
| INCF    | f, d   | Increment f                                    | 1             | 00    | 1010   | dfff   | ffff | Z        | 1,2   |
| INCFSZ  | f, d   | Increment f, Skip if 0                         | 1(2)          | 00    | 1111   | dfff   | ffff |          | 1,2,3 |
| IORWF   | f, d   | Inclusive OR W with f                          | 1             | 00    | 0100   | dfff   | ffff | Z        | 1,2   |
| MOVF    | f, d   | Move f                                         | 1             | 00    | 1000   | dfff   | ffff | Z        | 1,2   |
| MOVWF   | f      | Move W to f                                    | 1             | 00    | 0000   | lfff   | ffff |          |       |
| NOP     | -      | No Operation                                   | 1             | 00    | 0000   | 0xx0   | 0000 |          |       |
| RLF     | f, d   | Rotate Left f through Carry                    | 1             | 00    | 1101   | dfff   | ffff | С        | 1,2   |
| RRF     | f, d   | Rotate Right f through Carry                   | 1             | 00    | 1100   | dfff   | ffff | С        | 1,2   |
| SUBWF   | f, d   | Subtract W from f                              | 1             | 00    | 0010   | dfff   | ffff | C,DC,Z   | 1,2   |
| SWAPF   | f, d   | Swap nibbles in f                              | 1             | 00    | 1110   | dfff   | ffff |          | 1,2   |
| XORWF   | f, d   | Exclusive OR W with f                          | 1             | 00    | 0110   | dfff   | ffff | Z        | 1,2   |
|         |        | BIT-ORIENTED FILE                              |               | ATIO  | NS     |        |      |          |       |
| BCF     | f, b   | Bit Clear f                                    | 1             | 01    | 00bb   | bfff   | ffff |          | 1,2   |
| BSF     | f, b   | Bit Set f                                      | 1             | 01    |        | bfff   |      |          | 1,2   |
| BTFSC   | f, b   | Bit Test f, Skip if Clear                      | 1 (2)         | 01    | 10bb   | bfff   |      |          | 3     |
| BTFSS   | f, b   | Bit Test f, Skip if Set                        | 1 (2)         | 01    | 11bb   | bfff   | ffff |          | 3     |
|         | ,      | LITERAL AND CO                                 | ( )           | IONS  |        |        |      |          |       |
| ADDLW   | k      | Add Literal and W                              | 1             | 11    | 111x   | kkkk   | kkkk | C,DC,Z   |       |
| ANDLW   | k      | AND Literal with W                             | 1             | 11    | 1001   | kkkk   | kkkk | Z        |       |
| CALL    | k      | Call Subroutine                                | 2             | 10    | 0kkk   | kkkk   | kkkk |          |       |
| CLRWDT  | -      | Clear Watchdog Timer                           | 1             | 00    | 0000   | 0110   | 0100 | TO,PD    |       |
| GOTO    | k      | Go to Address                                  | 2             | 10    | 1kkk   | kkkk   | kkkk | -        |       |
| IORLW   | k      | Inclusive OR Literal with W                    | 1             | 11    | 1000   | kkkk   | kkkk | Z        |       |
| MOVLW   | k      | Move Literal to W                              | 1             | 11    | 00xx   | kkkk   | kkkk |          |       |
| RETFIE  | -      | Return from Interrupt                          | 2             | 00    | 0000   | 0000   | 1001 |          |       |
| RETLW   | k      | Return with Literal in W                       | 2             | 11    | 01xx   | kkkk   |      |          |       |
| RETURN  | -      | Return from Subroutine                         | 2             | 00    | 0000   | 0000   | 1000 |          |       |
| SLEEP   | -      | Go into Standby mode                           | 1             | 00    | 0000   | 0110   | 0011 | TO,PD    |       |
| SUBLW   | k      | Subtract W from Literal                        | 1             | 11    |        | kkkk   |      | C,DC,Z   |       |
| XORLW   | k      | Exclusive OR Literal with W                    | 1             | 11    | 1010   | kkkk   |      | Z        |       |
| Note 1: |        | I/O register is modified as a function of itse |               |       |        |        |      |          |       |

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

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

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

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







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

| DC CHA       | ARACTE   | RISTICS                                                             | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extendedOperating voltage VDD range as described in DC specification(Section 17.1) |      |           |          |                                                                        |  |  |  |  |  |
|--------------|----------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|----------|------------------------------------------------------------------------|--|--|--|--|--|
| Param<br>No. | Sym      | Characteristic                                                      | Min                                                                                                                                                                                                                                                               | Тур† | Max       | Units    | Conditions                                                             |  |  |  |  |  |
|              | Vol      | Output Low Voltage                                                  |                                                                                                                                                                                                                                                                   |      |           |          |                                                                        |  |  |  |  |  |
| D080         |          | I/O ports                                                           | —                                                                                                                                                                                                                                                                 | —    | 0.6       | V        | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C                            |  |  |  |  |  |
| D083         |          | OSC2/CLKO (RC osc config)                                           | —                                                                                                                                                                                                                                                                 | —    | 0.6       | V        | IOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C                            |  |  |  |  |  |
|              | Vон      | Output High Voltage                                                 |                                                                                                                                                                                                                                                                   |      |           |          |                                                                        |  |  |  |  |  |
| D090         |          | I/O ports <sup>(3)</sup>                                            | Vdd – 0.7                                                                                                                                                                                                                                                         | —    | —         | V        | IOH = -3.0 mA, VDD = 4.5V,<br>-40°С to +85°С                           |  |  |  |  |  |
| D092         |          | OSC2/CLKO (RC osc config)                                           | Vdd - 0.7                                                                                                                                                                                                                                                         | —    | —         | V        | IOH = -1.3 mA, VDD = 4.5V,<br>-40°С to +85°С                           |  |  |  |  |  |
| D150*        | Vod      | Open-Drain High Voltage                                             | —                                                                                                                                                                                                                                                                 |      | 8.5       | V        | RA4 pin                                                                |  |  |  |  |  |
|              |          | Capacitive Loading Specs on<br>Output Pins                          |                                                                                                                                                                                                                                                                   |      |           |          |                                                                        |  |  |  |  |  |
| D100         | Cosc2    | OSC2 pin                                                            | _                                                                                                                                                                                                                                                                 | —    | 15        | pF       | In XT, HS and LP modes when<br>external clock is used to drive<br>OSC1 |  |  |  |  |  |
| D101<br>D102 | Сю<br>Св | All I/O pins and OSC2 (RC mode)<br>SCL, SDA (I <sup>2</sup> C mode) | —                                                                                                                                                                                                                                                                 | _    | 50<br>400 | pF<br>pF |                                                                        |  |  |  |  |  |
|              |          | Data EEPROM Memory                                                  |                                                                                                                                                                                                                                                                   |      |           | •        |                                                                        |  |  |  |  |  |
| D120         | ED       | Endurance                                                           | 100K                                                                                                                                                                                                                                                              | 1M   | _         | E/W      | -40°C to +85°C                                                         |  |  |  |  |  |
| D121         | Vdrw     | VDD for read/write                                                  | Vmin                                                                                                                                                                                                                                                              | —    | 5.5       | V        | Using EECON to read/write,<br>VMIN = min. operating voltage            |  |  |  |  |  |
| D122         | TDEW     | Erase/write cycle time                                              | —                                                                                                                                                                                                                                                                 | 4    | 8         | ms       |                                                                        |  |  |  |  |  |
|              |          | Program Flash Memory                                                |                                                                                                                                                                                                                                                                   |      |           | _        |                                                                        |  |  |  |  |  |
| D130         | Ер       | Endurance                                                           | 10K                                                                                                                                                                                                                                                               | 100K | _         | E/W      | -40°C to +85°C                                                         |  |  |  |  |  |
| D131         | Vpr      | VDD for read                                                        | VMIN                                                                                                                                                                                                                                                              | —    | 5.5       | V        | VMIN = min. operating voltage                                          |  |  |  |  |  |
| D132A        |          | VDD for erase/write                                                 | Vmin                                                                                                                                                                                                                                                              |      | 5.5       | V        | Using EECON to read/write,<br>VMIN = min. operating voltage            |  |  |  |  |  |
| D133         | TPEW     | Erase/Write cycle time                                              | —                                                                                                                                                                                                                                                                 | 4    | 8         | ms       |                                                                        |  |  |  |  |  |

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/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC16F87XA be driven with external clock in RC mode.

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

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

\*



| Param<br>No. | Symbol   | Characteristic                                                |               | Min        | Тур† | Мах          | Units    | Conditions |
|--------------|----------|---------------------------------------------------------------|---------------|------------|------|--------------|----------|------------|
| 10*          | TosH2ckL | OSC1 $\uparrow$ to CLKO $\downarrow$                          |               | _          | 75   | 200          | ns       | (Note 1)   |
| 11*          | TosH2ckH | OSC1 ↑ to CLKO ↑                                              |               | —          | 75   | 200          | ns       | (Note 1)   |
| 12*          | TCKR     | CLKO Rise Time                                                | —             | 35         | 100  | ns           | (Note 1) |            |
| 13*          | ТскF     | CLKO Fall Time                                                |               | —          | 35   | 100          | ns       | (Note 1)   |
| 14*          | TCKL2IOV | CLKO ↓ to Port Out Valid                                      |               | —          |      | 0.5 TCY + 20 | ns       | (Note 1)   |
| 15*          | ТюV2скН  | Port In Valid before CLKO ↑                                   |               | Tosc + 200 | —    | _            | ns       | (Note 1)   |
| 16*          | TCKH2IOI | Port In Hold after CLKO ↑                                     |               | 0          | —    | _            | ns       | (Note 1)   |
| 17*          | TosH2IoV | OSC1 ↑ (Q1 cycle) to Port Out Valid                           |               | —          | 100  | 255          | ns       |            |
| 18*          | TosH2ıol | OSC1 ↑ (Q2 cycle) to Port Input<br>Invalid (I/O in hold time) | Standard (F)  | 100        | —    | —            | ns       |            |
|              |          |                                                               | Extended (LF) | 200        | —    | _            | ns       |            |
| 19*          | TIOV20sH | Port Input Valid to OSC1 $\uparrow$ (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 or Low Time                           |               | Тсү        | —    | _            | ns       |            |

These parameters are characterized but not tested.

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

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

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

\*





100 Max (125°C) 10 Max (85°C) 1 IPD (NA) 0.1 0.01 Тур (25°С) Typical: statistical mean @ 25°C Maximum: mean +  $3\sigma$  (-40°C to +125°C) Minimum: mean -  $3\sigma$  (-40°C to +125°C) 0.001 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 VDD (V)













