



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                      | 20MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 24                                                                        |
| Program Memory Size        | 3.5KB (2K x 14)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 128 x 8                                                                   |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                 |
| Data Converters            | A/D 11x10b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                            |
| Supplier Device Package    | 28-SOIC                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f882t-i-so |

Email: info@E-XFL.COM

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

# PIC16F882/883/884/886/887

|     |                       |           | ,           | ,           |          |        | •       |           | ,       |             |
|-----|-----------------------|-----------|-------------|-------------|----------|--------|---------|-----------|---------|-------------|
| 0/1 | 28-Pin PDIP/SOIC/SSOP | Analog    | Comparators | Timers      | ЕССР     | EUSART | dSSM    | Interrupt | Pull-up | Basic       |
| RA0 | 2                     | AN0/ULPWU | C12IN0-     | —           | —        | _      | —       | —         |         | —           |
| RA1 | 3                     | AN1       | C12IN1-     | —           | —        | _      | —       | —         | —       | —           |
| RA2 | 4                     | AN2       | C2IN+       | —           | —        | _      |         | _         |         | VREF-/CVREF |
| RA3 | 5                     | AN3       | C1IN+       | —           | —        | —      | —       | —         | —       | Vref+       |
| RA4 | 6                     | —         | C1OUT       | TOCKI       | _        | _      | _       | _         | _       | —           |
| RA5 | 7                     | AN4       | C2OUT       | —           | _        | -      | SS      | —         | _       | —           |
| RA6 | 10                    | —         | _           | —           | —        | _      | _       | —         |         | OSC2/CLKOUT |
| RA7 | 9                     | —         | —           | —           | —        | _      | —       | —         | —       | OSC1/CLKIN  |
| RB0 | 21                    | AN12      | _           | —           | —        |        | _       | IOC/INT   | Y       | —           |
| RB1 | 22                    | AN10      | C12IN3-     | —           | P1C      |        | _       | IOC       | Y       | —           |
| RB2 | 23                    | AN8       |             | —           | P1B      |        | _       | IOC       | Y       | —           |
| RB3 | 24                    | AN9       | C12IN2-     | —           | —        |        | _       | IOC       | Y       | PGM         |
| RB4 | 25                    | AN11      |             | —           | P1D      |        | _       | IOC       | Y       | —           |
| RB5 | 26                    | AN13      | _           | T1G         | —        | _      | —       | IOC       | Y       | _           |
| RB6 | 27                    | —         | _           |             | —        | _      | —       | IOC       | Y       | ICSPCLK     |
| RB7 | 28                    | —         | _           | _           | —        | -      | —       | IOC       | Y       | ICSPDAT     |
| RC0 | 11                    | —         | _           | T1OSO/T1CKI | —        | -      | _       | —         | —       | —           |
| RC1 | 12                    | _         |             | T1OSI       | CCP2     | _      | —       | —         | _       | _           |
| RC2 | 13                    | —         |             |             | CCP1/P1A | _      | —       | —         |         |             |
| RC3 | 14                    | —         | _           | _           | —        | -      | SCK/SCL | —         | _       | _           |
| RC4 | 15                    | _         |             | _           | _        |        | SDI/SDA | —         | _       |             |
| RC5 | 16                    | —         |             | —           | —        | _      | SDO     | —         | _       | —           |
| RC6 | 17                    | —         |             |             | —        | TX/CK  | —       | —         |         |             |
| RC7 | 18                    | _         |             | _           | _        | RX/DT  | —       | —         | _       | _           |
| RE3 | 1                     | —         | _           | —           | —        | -      | —       | —         | Y(1)    | MCLR/Vpp    |
|     | 20                    | —         |             |             |          |        | —       | _         | _       | Vdd         |
| —   | 8                     | —         | _           |             | —        | _      | —       | —         | —       | Vss         |
| _   | 19                    | —         | _           | —           | —        | _      | —       | —         | _       | Vss         |

#### TABLE 1: 28-PIN PDIP, SOIC, SSOP ALLOCATION TABLE (PIC16F882/883/886)

**Note 1:** Pull-up activated only with external MCLR configuration.

# PIC16F882/883/884/886/887

## Pin Diagrams - PIC16F884/887, 44-Pin QFN



# 3.5 PORTC and TRISC Registers

PORTC is a 8-bit wide, bidirectional port. The corresponding data direction register is TRISC (Register 3-10). Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin). Example 3-4 shows how to initialize PORTC.

Reading the PORTC register (Register 3-9) reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified and then written to the PORT data latch.

The TRISC register (Register 3-10) controls the PORTC pin output drivers, even when they are being used as analog inputs. The user should ensure the bits in the TRISC register are maintained set when using them as analog inputs. I/O pins configured as analog input always read '0'.

#### EXAMPLE 3-4: INITIALIZING PORTC

| BANKSEL | PORTC       | ;                      |
|---------|-------------|------------------------|
| CLRF    | PORTC       | ;Init PORTC            |
| BANKSEL | TRISC       | ;                      |
| MOVLW   | B`00001100′ | ;Set RC<3:2> as inputs |
| MOVWF   | TRISC       | ;and set RC<7:4,1:0>   |
|         |             | ;as outputs            |
|         |             |                        |

## REGISTER 3-9: PORTC: PORTC REGISTER

| R/W-x |
|-------|-------|-------|-------|-------|-------|-------|-------|
| RC7   | RC6   | RC5   | RC4   | RC3   | RC2   | RC1   | RC0   |
| bit 7 |       |       |       |       |       |       | bit 0 |

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

bit 7-0

RC<7:0>: PORTC General Purpose I/O Pin bit

1 = Port pin is > VIH 0 = Port pin is < VIL

REGISTER 3-10: TRISC: PORTC TRI-STATE REGISTER

| TRISC7 TRISC6 TRISC5 TRISC4 TRISC3 TRISC2 TRISC1 TRIS | R/W-1  | R/W-1  | R/W-1  | R/W-1  | R/W-1  | R/W-1  | R/W-1 <sup>(1)</sup> | R/W-1 <sup>(1)</sup> |
|-------------------------------------------------------|--------|--------|--------|--------|--------|--------|----------------------|----------------------|
| bit 7                                                 | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1               | TRISC0               |
|                                                       | bit 7  |        |        |        |        |        |                      | bit 0                |

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

bit 7-0 TRISC<7:0>: PORTC Tri-State Control bit

1 = PORTC pin configured as an input (tri-stated)

0 = PORTC pin configured as an output

**Note 1:** TRISC<1:0> always reads '1' in LP Oscillator mode.

## 3.5.1 RC0/T1OSO/T1CKI

Figure 3-11 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose I/O
- a Timer1 oscillator output
- a Timer1 clock input





## 3.5.2 RC1/T1OSI/CCP2

Figure 3-12 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose I/O
- a Timer1 oscillator input
- a Capture input and Compare/PWM output for Comparator C2



## 3.5.3 RC2/P1A/CCP1

Figure 3-13 shows the diagram for this pin. This pin is configurable to function as one of the following:

- a general purpose I/O
- a PWM output
- a Capture input and Compare output for Comparator C1





# 8.10 Comparator Voltage Reference

The comparator voltage reference module provides an internally generated voltage reference for the comparators. The following features are available:

- Independent from Comparator operation
- Two 16-level voltage ranges
- Output clamped to Vss
- Ratiometric with VDD
- Fixed Reference (0.6V)

The VRCON register (Register 8-5) controls the voltage reference module shown in Figure 8-8.

The voltage source is selectable through both ends of the 16 connection resistor ladder network. Bit VRSS of the VRCON register selects either the internal or external voltage source.

The PIC16F882/883/884/886/887 allows the CVREF signal to be output to the RA2 pin of PORTA under certain configurations only. For more details, see Figure 8-9.

#### 8.10.1 INDEPENDENT OPERATION

The comparator voltage reference is independent of the comparator configuration. Setting the VREN bit of the VRCON register will enable the voltage reference.

#### 8.10.2 OUTPUT VOLTAGE SELECTION

The CVREF voltage reference has two ranges with 16 voltage levels in each range. Range selection is controlled by the VRR bit of the VRCON register. The 16 levels are set with the VR<3:0> bits of the VRCON register.

The CVREF output voltage is determined by the following equations:

## EQUATION 8-1: CVREF OUTPUT VOLTAGE

VRR = 1 (low range): CVREF = (VR<3:0>/24) × VLADDER VRR = 0 (high range): CVREF = (VLADDER/4) + (VR<3:0> × VLADDER/32) VLADDER = VDD or ([VREF+] - [VREF-]) or VREF+

The full range of VSS to VDD cannot be realized due to the construction of the module. See Figure 8-8.

#### 8.10.3 OUTPUT CLAMPED TO Vss

The CVREF output voltage can be set to Vss with no power consumption by clearing the FVREN bit of the VRCON register.

This allows the comparator to detect a zero-crossing while not consuming additional CVREF module current.

Note: Depending on the application, additional components may be required for a zero cross circuit. Reference TB3013, *"Using the ESD Parasitic Diodes on Mixed Signal Microcontrollers"* (DS93013), for more information.

#### 8.10.4 OUTPUT RATIOMETRIC TO VDD

The comparator voltage reference is VDD derived and therefore, the CVREF output changes with fluctuations in VDD. The tested absolute accuracy of the Comparator Voltage Reference can be found in **Section 17.0 "Electrical Specifications"**.

#### 8.10.5 FIXED VOLTAGE REFERENCE

The Fixed Voltage Reference is independent of VDD, with a nominal output voltage of 0.6V. This reference can be enabled by setting the FVREN bit of the SRCON register to '1'. This reference is always enabled when the HFINTOSC oscillator is active.

#### 8.10.6 FIXED VOLTAGE REFERENCE STABILIZATION PERIOD

When the Fixed Voltage Reference module is enabled, it will require some time for the reference and its amplifier circuits to stabilize. The user program must include a small delay routine to allow the module to settle. See **Section 17.0 "Electrical Specifications"** for the minimum delay requirement.

#### 8.10.7 VOLTAGE REFERENCE SELECTION

Multiplexers on the output of the voltage reference module enable selection of either the CVREF or Fixed Voltage Reference for use by the comparators.

Setting the C1RSEL bit of the CM2CON1 register enables current to flow in the CVREF voltage divider and selects the CVREF voltage for use by C1. Clearing the C1RSEL bit selects the fixed voltage for use by C1.

Setting the C2RSEL bit of the CM2CON1 register enables current to flow in the CVREF voltage divider and selects the CVREF voltage for use by C2. Clearing the C2RSEL bit selects the fixed voltage for use by C2.

When both the C1RSEL and C2RSEL bits are cleared, current flow in the CVREF voltage divider is disabled minimizing the power drain of the voltage reference peripheral.

# 9.0 ANALOG-TO-DIGITAL CONVERTER (ADC) MODULE

The Analog-to-Digital Converter (ADC) allows conversion of an analog input signal to a 10-bit binary representation of that signal. This device uses analog inputs, which are multiplexed into a single sample and hold circuit. The output of the sample and hold is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers (ADRESL and ADRESH).

The ADC voltage reference is software selectable to be either internally generated or externally supplied.

The ADC can generate an interrupt upon completion of a conversion. This interrupt can be used to wake-up the device from Sleep.

Figure 9-1 shows the block diagram of the ADC.



#### FIGURE 9-1: ADC BLOCK DIAGRAM

## 11.5.4 OPERATION IN SLEEP MODE

In Sleep mode, the TMR2 register will not increment and the state of the module will not change. If the CCPx pin is driving a value, it will continue to drive that value. When the device wakes up, TMR2 will continue from its previous state.

#### 11.5.5 CHANGES IN SYSTEM CLOCK FREQUENCY

The PWM frequency is derived from the system clock frequency. Any changes in the system clock frequency will result in changes to the PWM frequency. See Section 4.0 "Oscillator Module (With Fail-Safe Clock Monitor)" for additional details.

#### 11.5.6 EFFECTS OF RESET

Any Reset will force all ports to Input mode and the CCP registers to their Reset states.

### 11.5.7 SETUP FOR PWM OPERATION

The following steps should be taken when configuring the CCP module for PWM operation:

- 1. Disable the PWM pin (CCPx) output drivers as an input by setting the associated TRIS bit.
- 2. Set the PWM period by loading the PR2 register.
- Configure the CCP module for the PWM mode by loading the CCPxCON register with the appropriate values.
- Set the PWM duty cycle by loading the CCPRxL register and DCxB<1:0> bits of the CCPxCON register.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIR1 register.
  - Set the Timer2 prescale value by loading the T2CKPS bits of the T2CON register.
  - Enable Timer2 by setting the TMR2ON bit of the T2CON register.
- 6. Enable PWM output after a new PWM cycle has started:
  - Wait until Timer2 overflows (TMR2IF bit of the PIR1 register is set).
  - Enable the CCPx pin output driver by clearing the associated TRIS bit.

| 1M< | 1:0>            | Signal        | 0          | Pulse       | PR2+1       |
|-----|-----------------|---------------|------------|-------------|-------------|
|     |                 |               | -          | Period —    |             |
| 00  | (Single Output) | P1A Modulated |            |             | <br>        |
|     |                 | P1A Modulated |            | 1) belay(1) | į           |
| 10  | (Half-Bridge)   | P1B Modulated |            |             |             |
|     |                 | P1A Active    |            | · · ·       |             |
| 01  | (Full-Bridge,   | P1B Inactive  | :          |             |             |
|     | Folwald)        | P1C Inactive  |            | I           | I           |
|     |                 | P1D Modulated |            |             | <br>        |
|     |                 | P1A Inactive  | !          | 1<br>1<br>1 | 1<br>1<br>1 |
| 11  | (Full-Bridge,   | P1B Modulated |            |             | I           |
|     | Keverse)        | P1C Active    | _ <u>;</u> | -<br>       |             |
|     |                 | P1D Inactive  | ;          | <u> </u>    |             |

## FIGURE 11-7: EXAMPLE ENHANCED PWM OUTPUT RELATIONSHIPS (ACTIVE-LOW STATE)

Delay = 4 \* Tosc \* (PWM1CON<6:0>)

Note 1: Dead-band delay is programmed using the PWM1CON register (Section 11.6.6 "Programmable Dead-Band Delay Mode").

## 11.6.1 HALF-BRIDGE MODE

In Half-Bridge mode, two pins are used as outputs to drive push-pull loads. The PWM output signal is output on the CCPx/P1A pin, while the complementary PWM output signal is output on the P1B pin (see Figure 11-9). This mode can be used for Half-Bridge applications, as shown in Figure 11-9, or for Full-Bridge applications, where four power switches are being modulated with two PWM signals.

In Half-Bridge mode, the programmable dead-band delay can be used to prevent shoot-through current in Half-Bridge power devices. The value of the PDC<6:0> bits of the PWM1CON register sets the number of instruction cycles before the output is driven active. If the value is greater than the duty cycle, the corresponding output remains inactive during the entire cycle. See **Section 11.6.6 "Programmable Dead-Band Delay Mode"** for more details of the dead-band delay operations. Since the P1A and P1B outputs are multiplexed with the PORT data latches, the associated TRIS bits must be cleared to configure P1A and P1B as outputs.

#### FIGURE 11-8: EXAMPLE OF HALF-BRIDGE PWM OUTPUT



## FIGURE 11-9: EXAMPLE OF HALF-BRIDGE APPLICATIONS



# PIC16F882/883/884/886/887



## TABLE 12-1: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION

| Name    | Bit 7                         | Bit 6       | Bit 5    | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|---------|-------------------------------|-------------|----------|--------|--------|--------|--------|--------|---------------------|
| BAUDCTL | ABDOVF                        | RCIDL       | _        | SCKP   | BRG16  | —      | WUE    | ABDEN  | 159                 |
| INTCON  | GIE                           | PEIE        | TOIE     | INTE   | RBIE   | T0IF   | INTF   | RBIF   | 32                  |
| PIE1    | —                             | ADIE        | RCIE     | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 33                  |
| PIR1    | —                             | ADIF        | RCIF     | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 35                  |
| RCREG   | EUSART R                      | eceive Data | Register |        |        |        |        |        | 155                 |
| RCSTA   | SPEN                          | RX9         | SREN     | CREN   | ADDEN  | FERR   | OERR   | RX9D   | 158                 |
| SPBRG   | BRG7                          | BRG6        | BRG5     | BRG4   | BRG3   | BRG2   | BRG1   | BRG0   | 160                 |
| SPBRGH  | BRG15                         | BRG14       | BRG13    | BRG12  | BRG11  | BRG10  | BRG9   | BRG8   | 160                 |
| TRISC   | TRISC7                        | TRISC6      | TRISC5   | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 54                  |
| TXREG   | EUSART Transmit Data Register |             |          |        |        |        |        |        |                     |
| TXSTA   | CSRC                          | TX9         | TXEN     | SYNC   | SENDB  | BRGH   | TRMT   | TX9D   | 157                 |

**Legend:** x = unknown, – = unimplemented read as '0'. Shaded cells are not used for Asynchronous Transmission.

## 12.3 EUSART Baud Rate Generator (BRG)

The Baud Rate Generator (BRG) is an 8-bit or 16-bit timer that is dedicated to the support of both the asynchronous and synchronous EUSART operation. By default, the BRG operates in 8-bit mode. Setting the BRG16 bit of the BAUDCTL register selects 16-bit mode.

The SPBRGH, SPBRG register pair determines the period of the free running baud rate timer. In Asynchronous mode the multiplier of the baud rate period is determined by both the BRGH bit of the TXSTA register and the BRG16 bit of the BAUDCTL register. In Synchronous mode, the BRGH bit is ignored.

Table 12-3 contains the formulas for determining the baud rate. Example 12-1 provides a sample calculation for determining the baud rate and baud rate error.

Typical baud rates and error values for various asynchronous modes have been computed for your convenience and are shown in Table 12-3. It may be advantageous to use the high baud rate (BRGH = 1), or the 16-bit BRG (BRG16 = 1) to reduce the baud rate error. The 16-bit BRG mode is used to achieve slow baud rates for fast oscillator frequencies.

Writing a new value to the SPBRGH, SPBRG register pair causes the BRG timer to be reset (or cleared). This ensures that the BRG does not wait for a timer overflow before outputting the new baud rate. If the system clock is changed during an active receive operation, a receive error or data loss may result. To avoid this problem, check the status of the RCIDL bit to make sure that the receive operation is Idle before changing the system clock.

#### EXAMPLE 12-1: CALCULATING BAUD RATE ERROR



|      | Configuration Bi | its  |                     | Baud Pate Formula |  |  |
|------|------------------|------|---------------------|-------------------|--|--|
| SYNC | BRG16            | BRGH | BRG/EUSART Mode     | Baud Kate Formula |  |  |
| 0    | 0                | 0    | 8-bit/Asynchronous  | Fosc/[64 (n+1)]   |  |  |
| 0    | 0                | 1    | 8-bit/Asynchronous  | Fosc/[16 (n+1)]   |  |  |
| 0    | 1                | 0    | 16-bit/Asynchronous |                   |  |  |
| 0    | 1                | 1    | 16-bit/Asynchronous |                   |  |  |
| 1    | 0                | x    | 8-bit/Synchronous   | Fosc/[4 (n+1)]    |  |  |
| 1    | 1                | x    | 16-bit/Synchronous  |                   |  |  |

## TABLE 12-3: BAUD RATE FORMULAS

**Legend:** x = Don't care, n = value of SPBRGH, SPBRG register pair

## TABLE 12-4: REGISTERS ASSOCIATED WITH THE BAUD RATE GENERATOR

| Name    | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register<br>on Page |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|---------------------|
| BAUDCTL | ABDOVF | RCIDL | _     | SCKP  | BRG16 | —     | WUE   | ABDEN | 159                 |
| RCSTA   | SPEN   | RX9   | SREN  | CREN  | ADDEN | FERR  | OERR  | RX9D  | 158                 |
| SPBRG   | BRG7   | BRG6  | BRG5  | BRG4  | BRG3  | BRG2  | BRG1  | BRG0  | 160                 |
| SPBRGH  | BRG15  | BRG14 | BRG13 | BRG12 | BRG11 | BRG10 | BRG9  | BRG8  | 160                 |
| TXSTA   | CSRC   | TX9   | TXEN  | SYNC  | SENDB | BRGH  | TRMT  | TX9D  | 157                 |

Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used for the Baud Rate Generator.

## 12.4.2 SYNCHRONOUS SLAVE MODE

The following bits are used to configure the EUSART for Synchronous slave operation:

- SYNC = 1
- CSRC = 0
- SREN = 0 (for transmit); SREN = 1 (for receive)
- CREN = 0 (for transmit); CREN = 1 (for receive)
- SPEN = 1

Setting the SYNC bit of the TXSTA register configures the device for synchronous operation. Clearing the CSRC bit of the TXSTA register configures the device as a slave. Clearing the SREN and CREN bits of the RCSTA register ensures that the device is in the Transmit mode, otherwise the device will be configured to receive. Setting the SPEN bit of the RCSTA register enables the EUSART. If the RX/DT or TX/CK pins are shared with an analog peripheral the analog I/O functions must be disabled by clearing the corresponding ANSEL bits.

#### 12.4.2.1 EUSART Synchronous Slave Transmit

The operation of the Synchronous Master and Slave modes are identical (see Section 12.4.1.3 "Synchronous Master Transmission"), except in the case of the Sleep mode.

If two words are written to the TXREG and then the SLEEP instruction is executed, the following will occur:

- 1. The first character will immediately transfer to the TSR register and transmit.
- 2. The second word will remain in TXREG register.
- 3. The TXIF bit will not be set.
- After the first character has been shifted out of TSR, the TXREG register will transfer the second character to the TSR and the TXIF bit will now be set.
- If the PEIE and TXIE bits are set, the interrupt will wake the device from Sleep and execute the next instruction. If the GIE bit is also set, the program will call the Interrupt Service Routine.
- 12.4.2.2 Synchronous Slave Transmission Setup:
- 1. Set the SYNC and SPEN bits and clear the CSRC bit.
- 2. Clear the CREN and SREN bits.
- If interrupts are desired, set the TXIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 4. If 9-bit transmission is desired, set the TX9 bit.
- 5. Enable transmission by setting the TXEN bit.
- 6. If 9-bit transmission is selected, insert the Most Significant bit into the TX9D bit.
- 7. Start transmission by writing the Least Significant eight bits to the TXREG register.

#### TABLE 12-9: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE TRANSMISSION

| Name    | Bit 7                        | Bit 6                         | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register on<br>Page |  |
|---------|------------------------------|-------------------------------|--------|--------|--------|--------|--------|--------|---------------------|--|
| BAUDCTL | ABDOVF                       | RCIDL                         | _      | SCKP   | BRG16  | _      | WUE    | ABDEN  | 159                 |  |
| INTCON  | GIE                          | PEIE                          | TOIE   | INTE   | RBIE   | T0IF   | INTF   | RBIF   | 32                  |  |
| PIE1    | —                            | ADIE                          | RCIE   | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 33                  |  |
| PIR1    | —                            | ADIF                          | RCIF   | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 35                  |  |
| RCREG   | EUSART Receive Data Register |                               |        |        |        |        |        |        |                     |  |
| RCSTA   | SPEN                         | RX9                           | SREN   | CREN   | ADDEN  | FERR   | OERR   | RX9D   | 158                 |  |
| SPBRG   | BRG7                         | BRG6                          | BRG5   | BRG4   | BRG3   | BRG2   | BRG1   | BRG0   | 160                 |  |
| SPBRGH  | BRG15                        | BRG14                         | BRG13  | BRG12  | BRG11  | BRG10  | BRG9   | BRG8   | 160                 |  |
| TRISC   | TRISC7                       | TRISC6                        | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 54                  |  |
| TXREG   | EUSART T                     | EUSART Transmit Data Register |        |        |        |        |        |        |                     |  |
| TXSTA   | CSRC                         | TX9                           | TXEN   | SYNC   | SENDB  | BRGH   | TRMT   | TX9D   | 157                 |  |

**Legend:** x = unknown, - = unimplemented read as '0'. Shaded cells are not used for Synchronous Slave Transmission.

### 13.4.5 BAUD RATE GENERATOR

In I<sup>2</sup>C Master mode, the reload value for the BRG is located in the lower seven bits of the SSPADD register (Figure 13-11). 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 (TcY) on the Q2 and Q4 clocks. In I<sup>2</sup>C Master mode, the BRG is reloaded automatically. If clock arbitration is taking place, for instance, the BRG will be reloaded when the SCL pin is sampled high (Figure 13-12).

## FIGURE 13-11: BAUD RATE GENERATOR BLOCK DIAGRAM



#### FIGURE 13-12: BAUD RATE GENERATOR TIMING WITH CLOCK ARBITRATION



#### 13.4.10 ACKNOWLEDGE SEQUENCE TIMING

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

#### 13.4.10.1 WCOL Status Flag

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

#### 13.4.11 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 register). 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 register) is set. A TBRG later, the PEN bit is cleared and the SSPIF bit is set (Figure 13-18).

#### 13.4.11.1 WCOL Status Flag

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

#### FIGURE 13-17: ACKNOWLEDGE SEQUENCE WAVEFORM



# 14.0 SPECIAL FEATURES OF THE CPU

The PIC16F882/883/884/886/887 devices have a host of features intended to maximize system reliability, minimize cost through elimination of external components, provide power-saving features and offer code protection.

These features are:

- Reset
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- Oscillator selection
- Sleep
- Code protection
- ID Locations
- In-Circuit Serial Programming<sup>™</sup>
- Low-voltage In-Circuit Serial Programming<sup>™</sup>

The PIC16F882/883/884/886/887 devices have 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 64 ms (nominal) on power-up only, designed to keep the part in Reset while the power supply stabilizes. There is also circuitry to reset the device if a brown-out occurs, which can use the Power-up Timer to provide at least a 64 ms Reset. With these three functions-on-chip, most applications need no external Reset circuitry.

The 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
- An interrupt

Several oscillator options are also made available to allow the part to fit the application. The INTOSC option saves system cost while the LP crystal option saves power. A set of Configuration bits are used to select various options (see Register 14-3).

## 17.5 DC Characteristics: PIC16F882/883/884/886/887-I (Industrial) PIC16F882/883/884/886/887-E (Extended)

| DC CHARACTERISTICS |      |                                      | $ \begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for industrial} \\ -40^\circ C \leq TA \leq +125^\circ C \mbox{ for extended} \end{array} $ |          |          |       |                                                                                                                       |
|--------------------|------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------|
| Param<br>No.       | Sym. | Characteristic                       | Min.                                                                                                                                                                                                                                                         | Тур†     | Max.     | Units | Conditions                                                                                                            |
|                    | VIL  | Input Low Voltage                    |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
|                    |      | I/O Port:                            |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
| D030               |      | with TTL buffer                      | Vss                                                                                                                                                                                                                                                          | —        | 0.8      | V     | $4.5V \leq V\text{DD} \leq 5.5V$                                                                                      |
| D030A              |      |                                      | Vss                                                                                                                                                                                                                                                          | —        | 0.15 Vdd | V     | $2.0V \leq V\text{DD} \leq 4.5V$                                                                                      |
| D031               |      | with Schmitt Trigger buf-<br>fer     | Vss                                                                                                                                                                                                                                                          | —        | 0.2 Vdd  | V     | $2.0V \leq V \text{DD} \leq 5.5 V$                                                                                    |
| D032               |      | MCLR, OSC1 (RC mode) <sup>(1)</sup>  | Vss                                                                                                                                                                                                                                                          | —        | 0.2 Vdd  | V     |                                                                                                                       |
| D033               |      | OSC1 (XT and LP modes)               | Vss                                                                                                                                                                                                                                                          | —        | 0.3      | V     |                                                                                                                       |
| D033A              |      | OSC1 (HS mode)                       | Vss                                                                                                                                                                                                                                                          | —        | 0.3 Vdd  | V     |                                                                                                                       |
|                    | Vih  | Input High Voltage                   |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
|                    |      | I/O ports:                           |                                                                                                                                                                                                                                                              | —        |          |       |                                                                                                                       |
| D040               |      | with TTL buffer                      | 2.0                                                                                                                                                                                                                                                          | —        | Vdd      | V     | $4.5V \leq V\text{DD} \leq 5.5V$                                                                                      |
| D040A              |      |                                      | 0.25 VDD + 0.8                                                                                                                                                                                                                                               | —        | Vdd      | V     | $2.0V \leq V\text{DD} \leq 4.5V$                                                                                      |
| D041               |      | with Schmitt Trigger buffer          | 0.8 Vdd                                                                                                                                                                                                                                                      | —        | Vdd      | V     | $2.0V \leq V \text{DD} \leq 5.5 \text{V}$                                                                             |
| D042               |      | MCLR                                 | 0.8 Vdd                                                                                                                                                                                                                                                      | —        | Vdd      | V     |                                                                                                                       |
| D043               |      | OSC1 (XT and LP modes)               | 1.6                                                                                                                                                                                                                                                          | —        | Vdd      | V     |                                                                                                                       |
| D043A              |      | OSC1 (HS mode)                       | 0.7 Vdd                                                                                                                                                                                                                                                      | —        | Vdd      | V     |                                                                                                                       |
| D043B              |      | OSC1 (RC mode)                       | 0.9 Vdd                                                                                                                                                                                                                                                      | —        | Vdd      | V     | (Note 1)                                                                                                              |
|                    | lı∟  | Input Leakage Current <sup>(2)</sup> |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
| D060               |      | I/O ports                            | —                                                                                                                                                                                                                                                            | ± 0.1    | ± 1      | μΑ    | $\label{eq:VSS} \begin{split} &V{\sf SS} \leq V{\sf PIN} \leq V{\sf DD}, \\ &P{\sf in at high-impedance} \end{split}$ |
| D061               |      | MCLR <sup>(3)</sup>                  | —                                                                                                                                                                                                                                                            | $\pm0.1$ | ± 5      | μΑ    | $VSS \leq VPIN \leq VDD$                                                                                              |
| D063               |      | OSC1                                 | —                                                                                                                                                                                                                                                            | ± 0.1    | ± 5      | μΑ    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP oscillator configuration                                                    |
| D070*              | IPUR | PORTB Weak Pull-up Cur-<br>rent      | 50                                                                                                                                                                                                                                                           | 250      | 400      | μΑ    | VDD = 5.0V, VPIN = VSS                                                                                                |
|                    | Vol  | Output Low Voltage <sup>(5)</sup>    |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
| D080               |      | I/O ports                            | —                                                                                                                                                                                                                                                            | —        | 0.6      | V     | IOL = 8.5 mA, VDD = 4.5V<br>(Ind.)                                                                                    |
|                    | Vон  | Output High Voltage <sup>(5)</sup>   |                                                                                                                                                                                                                                                              |          |          |       |                                                                                                                       |
| D090               |      | I/O ports                            | Vdd - 0.7                                                                                                                                                                                                                                                    | —        | -        | V     | IOH = -3.0 mA, VDD = 4.5V<br>(Ind.)                                                                                   |

These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 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 to use an external clock in RC mode.

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

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

4: See Section 10.3.1 "Using the Data EEPROM" for additional information.

5: Including OSC2 in CLKOUT mode.

# PIC16F882/883/884/886/887



## TABLE 17-3: CLKOUT AND I/O TIMING PARAMETERS

| Standard Operating Conditions (unless otherwise stated)<br>Operating Temperature -40°C $\leq$ TA $\leq$ +125°C |                     |                                                             |               |          |          |       |                          |
|----------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------|---------------|----------|----------|-------|--------------------------|
| Param<br>No.                                                                                                   | Sym. Characteristic |                                                             | Min.          | Тур†     | Max.     | Units | Conditions               |
| OS11                                                                                                           | TosH2ckL            | Fosc↑ to CLKOUT↓ <sup>(1)</sup>                             | —             | —        | 70       | ns    | VDD = 5.0V               |
| OS12                                                                                                           | TosH2ckH            | Fosc↑ to CLKOUT↑ <sup>(1)</sup>                             | —             | —        | 72       | ns    | VDD = 5.0V               |
| OS13                                                                                                           | TCKL2IOV            | CLKOUT↓ to Port out valid <sup>(1)</sup>                    | —             | —        | 20       | ns    |                          |
| OS14                                                                                                           | ТюV2скН             | Port input valid before CLKOUT <sup>(1)</sup>               | Tosc + 200 ns | —        | _        | ns    |                          |
| OS15*                                                                                                          | TosH2IoV            | Fosc↑ (Q1 cycle) to Port out valid                          | —             | 50       | 70       | ns    | VDD = 5.0V               |
| OS16                                                                                                           | TosH2IOI            | Fosc↑ (Q2 cycle) to Port input invalid (I/O in hold time)   | 50            | —        | _        | ns    | VDD = 5.0V               |
| OS17                                                                                                           | TioV2osH            | Port input valid to Fosc↑ (Q2 cycle)<br>(I/O in setup time) | 20            |          |          | ns    |                          |
| OS18                                                                                                           | TIOR                | Port output rise time <sup>(2)</sup>                        |               | 15<br>40 | 72<br>32 | ns    | VDD = 2.0V<br>VDD = 5.0V |
| OS19                                                                                                           | TIOF                | Port output fall time <sup>(2)</sup>                        |               | 28<br>15 | 55<br>30 | ns    | VDD = 2.0V<br>VDD = 5.0V |
| OS20*                                                                                                          | Tinp                | INT pin input high or low time                              | 25            | —        | _        | ns    |                          |
| OS21*                                                                                                          | TRAP                | PORTA interrupt-on-change new<br>input level time           | Тсү           | —        |          | ns    |                          |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated.

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

2: Includes OSC2 in CLKOUT mode.

# 28-Lead Plastic Quad Flat, No Lead Package (ML) - 6x6 mm Body [QFN] With 0.55 mm Terminal Length

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



|                         | Units  | М        | LLIMETERS | ;    |  |  |
|-------------------------|--------|----------|-----------|------|--|--|
| Dimension               | Limits | MIN      | NOM       | MAX  |  |  |
| Number of Pins          | N      | 28       |           |      |  |  |
| Pitch                   | е      |          | 0.65 BSC  |      |  |  |
| Overall Height          | Α      | 0.80     | 0.90      | 1.00 |  |  |
| Standoff                | A1     | 0.00     | 0.02      | 0.05 |  |  |
| Terminal Thickness      | A3     | 0.20 REF |           |      |  |  |
| Overall Width           | E      |          | 6.00 BSC  |      |  |  |
| Exposed Pad Width       | E2     | 3.65     | 3.70      | 4.20 |  |  |
| Overall Length          | D      | 6.00 BSC |           |      |  |  |
| Exposed Pad Length      | D2     | 3.65     | 3.70      | 4.20 |  |  |
| Terminal Width          | b      | 0.23     | 0.30      | 0.35 |  |  |
| Terminal Length         | L      | 0.50     | 0.55      | 0.70 |  |  |
| Terminal-to-Exposed Pad | K      | 0.20     | -         | -    |  |  |

#### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Package is saw singulated

3. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-105C Sheet 2 of 2

# APPENDIX A: DATA SHEET REVISION HISTORY

## Revision A (5/2006)

Initial release of this data sheet.

# Revision B (7/2006)

Pin Diagrams (44-Pin QFN drawing); Revised Table 2-1, Addr. 1DH (CCP2CON); Section 3.0, 3.1; Section 3.4.4.6; Table 3; Table 3-1 (ANSEL); Table 3-3 (CCP2CON); Register 3-1; Register 3.2; Register 3-3; Register 3-4; Register 3-9; Register 3-10; Register 3-11; Register 3-12; Register 3-14; Table 3-5 (ANSEL); Figure 3-5; Figure 3-11; Figure 8-2; Figure 8-3; Figure 9-1; Register 9-1; Section 9.1.4; Example 10-4; Figure 11-5; Table 11-5 (P1M); Section 11.5.2; Section 11.5.7, Number 4; Table 11-7 (CCP2CON); Section 12.3.1 (Para. 3); Figure 12-6 (Title); Sections 14.2, 14.3 and 14.4 DC Characteristics (Max); Table 14-4 (OSCCON); Section 14.3 (TMR0); Section 14.3.2 (TMR0).

# **Revision C**

Section 19.0 Packaging Information: Replaced package drawings and added note. Added PIC16F882 part number. Replaced PICmicro with PIC.

# **Revision D**

Replaced Package Drawings (Rev. AM); Replaced Development Support Section; Revised Product ID Section.

# **Revision E (01/2008)**

Added Char Data; Removed Preliminary status; Revised Device Table (PIC16F882, I/O); Revised the following: Pin Diagram 44 TQFP, pin 30; Table 5, I/O RA7; Table 1-1, RA1 and RA4; Section 2.2.1; Register 2-3, INTCON; Example 3-1; Section 3.2.2; Example 3-2; Figure 6-1; Section 6.2.2; Section 6.6; Section 8.10.3; Table 9-1; Equation 11-1; Added Figure 11-14 and renumbered remaining Figures; Register 11-3; Register 13-3; Section 14.0; Section 14.1; Section 14.9; Section 14.10; Section 17.0; Updated Package Drawings.

# Revision F (04/2009)

Revised Product ID: Removed 'F' (std. voltage range) from part numbers; Revised Figure 6-1: Timer1 Block Diagram; Revised Figure 8-3, Comparator C2 Block Diagram; Added note to Section 8.10.3; Revised Section 8.10.7.

# **Revision G (10/2012)**

Updated data sheet to new format; Updated Register 13-1 and Register 13-2; Updated the Packaging Information section; Updated the Product Identification System section; Other minor corrections.

# Revision H (04/2015)

Added Section 17.9: High Temperature Operation in the Electrical Specifications section.

# **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

| PART NO.                 | [X] <sup>(1)</sup> - X <u>/XX XXX</u><br>T Tape and Reel Temperature Package Pattern<br>Option Range                                                                                     | <ul> <li>Examples:</li> <li>a) PIC16F883-E/P 301 = Extended Temp., PDIP package, 20 MHz, QTP pattern #301</li> <li>b) PIC16F883-I/SO = Industrial Temp., SOIC package 20 MHz</li> </ul>                                                                                                                                                          |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device:                  | PIC16F883, PIC16F883T <sup>(1)</sup> , PIC16F884, PIC16F884T <sup>(1)</sup> ,<br>PIC16F886, PIC16F886T <sup>(1)</sup> , PIC16F887, PIC16F887T <sup>(1)</sup> ,<br>VDD range 2.0V to 5.5V | pasiago, 20 m.2                                                                                                                                                                                                                                                                                                                                  |
| Tape and Reel<br>Option: | Blank = Standard packaging (tube or tray)<br>T = Tape and Reel <sup>(1)</sup>                                                                                                            |                                                                                                                                                                                                                                                                                                                                                  |
| Temperature<br>Range:    | I = $-40^{\circ}$ C to $+85^{\circ}$ C (Industrial)<br>E = $-40^{\circ}$ C to $+125^{\circ}$ C (Extended)                                                                                |                                                                                                                                                                                                                                                                                                                                                  |
| Package: <sup>(2)</sup>  | ML=Quad Flat No Leads (QFN)P=Plastic DIPPT=Plastic Thin-Quad Flatpack (TQFP)SO=Plastic Small Outline (SOIC) (7.50 mm)SP=Skinny Plastic DIPSS=Plastic Shrink Small Outline                | <ul> <li>Note 1: Tape and Reel identifier only appears in the catalog part number description. This identifier is used for ordering purposes and is not printed on the device package. Check with your Microchip Sales Office for package availability with the Tape and Reel option.</li> <li>2: For other small form-factor package</li> </ul> |
| Pattern:                 | QTP, SQTP, Code or Special Requirements (blank otherwise)                                                                                                                                | availability and marking information, please<br>visit www.microchip.com/packaging or<br>contact your local sales office.                                                                                                                                                                                                                         |