



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              | Through Hole                                                             |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                  |
| Supplier Device Package    | 28-SPDIP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f882-i-sp |

Email: info@E-XFL.COM

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

### 2.2.2.4 PIE1 Register

The PIE1 register contains the interrupt enable bits, as shown in Register 2-4.

**Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt.

# **REGISTER DEFINITIONS: PIE1**

### REGISTER 2-4: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1

| U-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|-------|-------|-------|-------|-------|--------|--------|--------|
| —     | ADIE  | RCIE  | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE |
| 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 | Unimplemented: Read as '0'                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------|
| bit 6 | ADIE: A/D Converter (ADC) Interrupt Enable bit                                                                         |
|       | <ul><li>1 = Enables the ADC interrupt</li><li>0 = Disables the ADC interrupt</li></ul>                                 |
| bit 5 | RCIE: EUSART Receive Interrupt Enable bit                                                                              |
|       | <ul><li>1 = Enables the EUSART receive interrupt</li><li>0 = Disables the EUSART receive interrupt</li></ul>           |
| bit 4 | TXIE: EUSART Transmit Interrupt Enable bit                                                                             |
|       | <ul><li>1 = Enables the EUSART transmit interrupt</li><li>0 = Disables the EUSART transmit interrupt</li></ul>         |
| bit 3 | SSPIE: Master Synchronous Serial Port (MSSP) Interrupt Enable bit                                                      |
|       | <ul><li>1 = Enables the MSSP interrupt</li><li>0 = Disables the MSSP interrupt</li></ul>                               |
| bit 2 | CCP1IE: CCP1 Interrupt Enable bit                                                                                      |
|       | <ul><li>1 = Enables the CCP1 interrupt</li><li>0 = Disables the CCP1 interrupt</li></ul>                               |
| bit 1 | TMR2IE: Timer2 to PR2 Match Interrupt Enable bit                                                                       |
|       | <ul><li>1 = Enables the Timer2 to PR2 match interrupt</li><li>0 = Disables the Timer2 to PR2 match interrupt</li></ul> |
| bit 0 | TMR1IE: Timer1 Overflow Interrupt Enable bit                                                                           |
|       | <ul><li>1 = Enables the Timer1 overflow interrupt</li><li>0 = Disables the Timer1 overflow interrupt</li></ul>         |
|       |                                                                                                                        |



# 5.0 TIMER0 MODULE

The Timer0 module is an 8-bit timer/counter with the following features:

- 8-bit timer/counter register (TMR0)
- 8-bit prescaler (shared with Watchdog Timer)
- · Programmable internal or external clock source
- Programmable external clock edge selection
- Interrupt on overflow

Figure 5-1 is a block diagram of the Timer0 module.

# 5.1 Timer0 Operation

When used as a timer, the Timer0 module can be used as either an 8-bit timer or an 8-bit counter.

### 5.1.1 8-BIT TIMER MODE

When used as a timer, the Timer0 module will increment every instruction cycle (without prescaler). Timer mode is selected by clearing the T0CS bit of the OPTION register to '0'.

When TMR0 is written, the increment is inhibited for two instruction cycles immediately following the write.

Note: The value written to the TMR0 register can be adjusted, in order to account for the two instruction cycle delay when TMR0 is written.

### 5.1.2 8-BIT COUNTER MODE

When used as a counter, the Timer0 module will increment on every rising or falling edge of the T0CKI pin. The incrementing edge is determined by the T0SE bit of the OPTION register. Counter mode is selected by setting the T0CS bit of the OPTION register to '1'.



### FIGURE 5-1: TIMER0/WDT PRESCALER BLOCK DIAGRAM

# 6.7 Timer1 Interrupt

The Timer1 register pair (TMR1H:TMR1L) increments to FFFFh and rolls over to 0000h. When Timer1 rolls over, the Timer1 interrupt flag bit of the PIR1 register is set. To enable the interrupt on rollover, you must set these bits:

- Timer1 interrupt enable bit of the PIE1 register
- PEIE bit of the INTCON register
- GIE bit of the INTCON register

The interrupt is cleared by clearing the TMR1IF bit in the Interrupt Service Routine.

Note: The TMR1H:TTMR1L register pair and the TMR1IF bit should be cleared before enabling interrupts.

# 6.8 Timer1 Operation During Sleep

Timer1 can only operate during Sleep when setup in Asynchronous Counter mode. In this mode, an external crystal or clock source can be used to increment the counter. To set up the timer to wake the device:

- TMR1ON bit of the T1CON register must be set
- TMR1IE bit of the PIE1 register must be set
- · PEIE bit of the INTCON register must be set

The device will wake-up on an overflow and execute the next instruction. If the GIE bit of the INTCON register is set, the device will call the Interrupt Service Routine (0004h).

# 6.9 ECCP Capture/Compare Time Base

The ECCP module uses the TMR1H:TMR1L register pair as the time base when operating in Capture or Compare mode.

In Capture mode, the value in the TMR1H:TMR1L register pair is copied into the CCPRxH:CCPRxL register pair on a configured event.

In Compare mode, an event is triggered when the value CCPRxH:CCPRxL register pair matches the value in the TMR1H:TMR1L register pair. This event can be a Special Event Trigger.

See Section 11.0 "Capture/Compare/PWM Modules (CCP1 and CCP2)" for more information.

# 6.10 ECCP Special Event Trigger

If an ECCP is configured to trigger a special event, the trigger will clear the TMR1H:TMR1L register pair. This special event does not cause a Timer1 interrupt. The ECCP module may still be configured to generate a ECCP interrupt.

In this mode of operation, the CCPRxH:CCPRxL register pair effectively becomes the period register for Timer1.

Timer1 should be synchronized to the Fosc to utilize the Special Event Trigger. Asynchronous operation of Timer1 can cause a Special Event Trigger to be missed.

In the event that a write to TMR1H or TMR1L coincides with a Special Event Trigger from the ECCP, the write will take precedence.

For more information, see Section 11.0 "Capture/ Compare/PWM Modules (CCP1 and CCP2)".

# 6.11 Comparator Synchronization

The same clock used to increment Timer1 can also be used to synchronize the comparator output. This feature is enabled in the Comparator module.

When using the comparator for Timer1 gate, the comparator output should be synchronized to Timer1. This ensures Timer1 does not miss an increment if the comparator changes.

For more information, see **Section 8.0 "Comparator Module**".



### FIGURE 6-2: TIMER1 INCREMENTING EDGE

| R/W-0           | U-0                                                                                        | R/W-0            | R/W-0          | U-0              | U-0              | U-0             | U-0   |  |
|-----------------|--------------------------------------------------------------------------------------------|------------------|----------------|------------------|------------------|-----------------|-------|--|
| ADFM            | _                                                                                          | VCFG1            | VCFG0          | _                | —                | —               | _     |  |
| bit 7           |                                                                                            |                  |                |                  |                  |                 | bit 0 |  |
|                 |                                                                                            |                  |                |                  |                  |                 |       |  |
| Legend:         |                                                                                            |                  |                |                  |                  |                 |       |  |
| R = Readable    | bit                                                                                        | W = Writable     | bit            | U = Unimpler     | mented bit, read | d as '0'        |       |  |
| -n = Value at F | POR                                                                                        | '1' = Bit is set |                | '0' = Bit is cle | ared             | x = Bit is unkr | nown  |  |
| hit 7           |                                                                                            | Conversion Pos   | ult Format Sol | ect hit          |                  |                 |       |  |
|                 | ADFM: A/D Conversion Result Format Select bit<br>1 = Right justified<br>0 = Left justified |                  |                |                  |                  |                 |       |  |
| bit 6           | Unimplemen                                                                                 | ted: Read as '   | 0'             |                  |                  |                 |       |  |
| bit 5           | VCFG1: Volta                                                                               | age Reference    | bit            |                  |                  |                 |       |  |
|                 | 1 = VREF- pin<br>0 = VSS                                                                   |                  |                |                  |                  |                 |       |  |
| bit 4           | bit 4 VCFG0: Voltage Reference bit                                                         |                  |                |                  |                  |                 |       |  |
|                 | 1 = VREF+ pir<br>0 = VDD                                                                   | 1                |                |                  |                  |                 |       |  |
| bit 3-0         | Unimplemen                                                                                 | ted: Read as '   | 0'             |                  |                  |                 |       |  |

# REGISTER 9-2: ADCON1: A/D CONTROL REGISTER 1

### **REGISTER 9-3:** ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 0

| R/W-x  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRES9 | ADRES8 | ADRES7 | ADRES6 | ADRES5 | ADRES4 | ADRES3 | ADRES2 |
| bit 7  |        |        |        |        |        |        | bit 0  |
|        |        |        |        |        |        |        |        |
| Logond |        |        |        |        |        |        |        |

| Logena.           |                  |                                    |                    |  |  |
|-------------------|------------------|------------------------------------|--------------------|--|--|
| 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 ADRES<9:2>: ADC Result Register bits

Upper eight bits of 10-bit conversion result

'1' = Bit is set

### **REGISTER 9-4:** ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 0

| R/W-x                             | R/W-x  | R/W-x | R/W-x | R/W-x         | R/W-x              | R/W-x | R/W-x |
|-----------------------------------|--------|-------|-------|---------------|--------------------|-------|-------|
| ADRES1                            | ADRES0 | —     | —     | —             | —                  | —     | —     |
| bit 7                             |        |       |       |               |                    |       | bit 0 |
|                                   |        |       |       |               |                    |       |       |
| Legend:                           |        |       |       |               |                    |       |       |
| R = Readable bit W = Writable bit |        |       | t     | U = Unimpleme | ented bit, read as | · '0' |       |

'0' = Bit is cleared

| bit 7-6 | ADRES<1:0>: ADC Result Register bits Lower two bits of 10-bit conversion result |
|---------|---------------------------------------------------------------------------------|
| bit 5-0 | Reserved: Do not use.                                                           |

### REGISTER 9-5: ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 1

| R/W-x  | R/W-x  |
|-------|-------|-------|-------|-------|-------|--------|--------|
| —     | —     | —     | —     | —     | —     | ADRES9 | ADRES8 |
| 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-2 Reserved: Do not use.

-n = Value at POR

bit 1-0 ADRES<9:8>: ADC Result Register bits Upper two bits of 10-bit conversion result

# REGISTER 9-6: ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 1

| R/W-x  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| ADRES7 | ADRES6 | ADRES5 | ADRES4 | ADRES3 | ADRES2 | ADRES1 | ADRES0 |
| bit 7  |        |        |        |        |        |        | bit 0  |

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

bit 7-0 ADRES<7:0>: ADC Result Register bits Lower eight bits of 10-bit conversion result x = Bit is unknown

# 9.3 A/D Acquisition Requirements

For the ADC to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The Analog Input model is shown in Figure 9-4. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), see Figure 9-4. The maximum recommended impedance for analog sources is 10 k $\Omega$ . As the source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an A/D acquisition must be done before the conversion can be started. To calculate the minimum acquisition time, Equation 9-1 may be used. This equation assumes that 1/2 LSb error is used (1024 steps for the ADC). The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution.

# EQUATION 9-1: ACQUISITION TIME EXAMPLE

Assumptions: Temperature = 50°C and external impedance of 10k 
$$\Omega$$
 5.0V VDD  

$$T_{ACQ} = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient
= TAMP + TC + TCOFF
= 2µs + TC + [(Temperature - 25°C)(0.05µs/°C)]
The value for Tc can be approximated with the following equations:
$$V_{APPLIED} \left( 1 - \frac{1}{(2^{n+1}) - 1} \right) = V_{CHOLD} \qquad ;[1] V_{CHOLD} charged to within 1/2 lsb
V_{APPLIED} \left( 1 - \frac{1}{(2^{n+1}) - 1} \right) = V_{CHOLD} \qquad ;[2] V_{CHOLD} charge response to V_{APPLIED}
$$V_{APPLIED} \left( 1 - e^{\frac{-TC}{RC}} \right) = V_{CHOLD} \qquad ;[2] V_{CHOLD} charge response to V_{APPLIED}
V_{APPLIED} \left( 1 - e^{\frac{-TC}{RC}} \right) = V_{APPLIED} \left( 1 - \frac{1}{(2^{n+1}) - 1} \right) \qquad ;combining [1] and [2]$$
Solving for TC:  

$$T_{C} = -C_{HOLD} (RIC + RSS + RS) ln(1/2047) = -10pF(1k\Omega + 7k\Omega + 10k\Omega) ln(0.0004885) = 1.37µs$$
Therefore:  

$$T_{ACQ} = 2MS + 1.37MS + [(50°C - 25°C)(0.05MS/°C)] = 4.67MS$$$$$$

**Note 1:** The reference voltage (VREF) has no effect on the equation, since it cancels itself out.

- 2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
- **3:** The maximum recommended impedance for analog sources is  $10 \text{ k}\Omega$ . This is required to meet the pin leakage specification.

© 2006-2015 Microchip Technology Inc.

|        |          |               |           |        | -      | -      |         |        | -                   |
|--------|----------|---------------|-----------|--------|--------|--------|---------|--------|---------------------|
| Name   | Bit 7    | Bit 6         | Bit 5     | Bit 4  | Bit 3  | Bit 2  | Bit 1   | Bit 0  | Register<br>on Page |
| ADCON0 | ADCS1    | ADCS0         | CHS3      | CHS2   | CHS1   | CHS0   | GO/DONE | ADON   | 104                 |
| ADCON1 | ADFM     | —             | VCFG1     | VCFG0  | _      | _      | _       | —      | 105                 |
| ANSEL  | ANS7     | ANS6          | ANS5      | ANS4   | ANS3   | ANS2   | ANS1    | ANS0   | 41                  |
| ANSELH | —        | —             | ANS13     | ANS12  | ANS11  | ANS10  | ANS9    | ANS8   | 49                  |
| ADRESH | A/D Resu | lt Register I | High Byte |        |        |        |         |        | 106                 |
| ADRESL | A/D Resu | It Register   | Low Byte  |        |        |        |         |        | 106                 |
| 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                  |
| PORTA  | RA7      | RA6           | RA5       | RA4    | RA3    | RA2    | RA1     | RA0    | 40                  |
| PORTB  | RB7      | RB6           | RB5       | RB4    | RB3    | RB2    | RB1     | RB0    | 49                  |
| PORTE  | —        | —             | —         | —      | RE3    | RE2    | RE1     | RE0    | 60                  |
| TRISA  | TRISA7   | TRISA6        | TRISA5    | TRISA4 | TRISA3 | TRISA2 | TRISA1  | TRISA0 | 40                  |
| TRISB  | TRISB7   | TRISB6        | TRISB5    | TRISB4 | TRISB3 | TRISB2 | TRISB1  | TRISB0 | 49                  |
| TRISE  | _        | _             | _         | _      | TRISE3 | TRISE2 | TRISE1  | TRISE0 | 60                  |

TABLE 9-2: SUMMARY OF ASSOCIATED ADC REGISTERS

**Legend:** x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used for ADC module.

### 10.1.2 READING THE DATA EEPROM MEMORY

To read a data memory location, the user must write the address to the EEADR register, clear the EEPGD control bit of the EECON1 register, and then set control bit RD. The data is available at the very next cycle, in the EEDAT register; therefore, it can be read in the next instruction. EEDAT will hold this value until another read or until it is written to by the user (during a write operation).

| FXAMPI | F 10-1  | ΔΔΤΔ | FFPROM | RFAD |
|--------|---------|------|--------|------|
|        | L IV-I. |      |        | NLAD |

| BANKSEL | EEADR         | ;                     |
|---------|---------------|-----------------------|
| MOVLW   | DATA_EE_ADDR  | ;                     |
| MOVWF   | EEADR         | ;Data Memory          |
|         |               | ;Address to read      |
| BANKSEL | EECON1        | ;                     |
| BCF     | EECON1, EEPGD | ;Point to DATA memory |
| BSF     | EECON1, RD    | ;EE Read              |
| BANKSEL | EEDAT         | ;                     |
| MOVF    | EEDAT, W      | W = EEDAT             |
| BCF     | STATUS, RP1   | ;Bank 0               |
|         |               |                       |

# 10.1.3 WRITING TO THE DATA EEPROM MEMORY

To write an EEPROM data location, the user must first write the address to the EEADR register and the data to the EEDAT register. Then the user must follow a specific sequence to initiate the write for each byte.

The write will not initiate if the above sequence is not followed exactly (write 55h to EECON2, write AAh to EECON2, then set WR bit) for each byte. Interrupts should be disabled during this code segment.

Additionally, the WREN bit in EECON1 must be set to enable write. This mechanism prevents accidental writes to data EEPROM due to errant (unexpected) code execution (i.e., lost programs). The user should keep the WREN bit clear at all times, except when updating EEPROM. The WREN bit is not cleared by hardware.

After a write sequence has been initiated, clearing the WREN bit will not affect this write cycle. The WR bit will be inhibited from being set unless the WREN bit is set.

At the completion of the write cycle, the WR bit is cleared in hardware and the EE Write Complete Interrupt Flag bit (EEIF) is set. The user can either enable this interrupt or poll this bit. EEIF must be cleared by software.

|            | BANKSEL | EEADR         | ;                                            |
|------------|---------|---------------|----------------------------------------------|
|            | MOVLW   | DATA_EE_ADDR  | ;                                            |
|            | MOVWF   | EEADR         | ;Data Memory Address to write                |
|            | MOVLW   | DATA_EE_DATA  | ;                                            |
|            | MOVWF   | EEDAT         | ;Data Memory Value to write                  |
|            | BANKSEL | EECON1        | ;                                            |
|            | BCF     | EECON1, EEPGD | ;Point to DATA memory                        |
|            | BSF     | EECON1, WREN  | ;Enable writes                               |
|            | DOE     |               |                                              |
|            | BCF     | INTCON, GIE   | Disable INTS.                                |
|            | BTFSC   | INTCON, GIE   | ;SEE AN576                                   |
|            | GOTO    | \$-2          |                                              |
|            | MOVLW   | 55h           | ;                                            |
| ce ed      | MOVWF   | EECON2        | ;Write 55h                                   |
| Juire      | MOVLW   | AAh           | ;                                            |
| Seg        | MOVWF   | EECON2        | ;Write AAh                                   |
| т <i>о</i> | BSF     | EECON1, WR    | ;Set WR bit to begin write                   |
|            | BSF     | INTCON, GIE   | ;Enable INTs.                                |
|            | SLEEP   |               | ;Wait for interrupt to signal write complete |
|            | BCF     | EECON1, WREN  | ;Disable writes                              |
|            | BCF     | STATUS, RPO   | ;Bank 0                                      |
|            | BCF     | STATUS, RP1   |                                              |
|            |         |               |                                              |

#### EXAMPLE 10-2: DATA EEPROM WRITE

# **REGISTER DEFINITIONS: CCP CONTROL**

# REGISTER 11-1: CCP1CON: ENHANCED CCP1 CONTROL REGISTER

| R/W-0                                                                    | R/W-0                                                                                                                                                                                                                                                                | R/W-0                                                                                                                                                                                                                                                 | R/W-0                                                                                                                                                                                                                  | R/W-0                                                                                                                                                        | R/W-0                                                                                                      | R/W-0                                                                 | R/W-0           |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------|
| P1M1                                                                     | P1M0                                                                                                                                                                                                                                                                 | DC1B1                                                                                                                                                                                                                                                 | DC1B0                                                                                                                                                                                                                  | CCP1M3                                                                                                                                                       | CCP1M2                                                                                                     | CCP1M1                                                                | CCP1M0          |
| 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 cle                                                                                                                                             | ared                                                                                                       | x = Bit is unk                                                        | nown            |
| bit 7-6                                                                  | <b>P1M&lt;1:0&gt;:</b> P <sup>1</sup><br><u>If CCP1M&lt;3:2</u><br>xx = P1A as<br><u>If CCP1M&lt;3:2</u><br>00 = Single<br>01 = Full-Bri<br>10 = Half-Bri<br>11 = Full-Bri                                                                                           | WM Output Co<br>$2 \ge 00, 01, 1$<br>signed as Cap<br>$2 \ge 11$ :<br>output; P1A m<br>dge output for<br>idge output; P1<br>dge output rev                                                                                                            | onfiguration bit<br><u>0:</u><br>iture/Compare<br>odulated; P1B<br>ward; P1D mo<br>A, P1B modula<br>erse; P1B mo                                                                                                       | s<br>input; P1B, P1<br>, P1C, P1D ass<br>dulated; P1A ad<br>ated with dead-b<br>dulated; P1C ad                                                              | C, P1D assign<br>signed as port<br>ctive; P1B, P1<br>pand control; P<br>ctive; P1A, P1I                    | ed as port pins<br>pins<br>C inactive<br>1C, P1D assign<br>D inactive | ed as port pins |
| bit 5-4                                                                  | <ul> <li>DC1B&lt;1:0&gt;: PWM Duty Cycle Least Significant bits</li> <li>Capture mode:<br/>Unused.</li> <li>Compare mode:<br/>Unused.</li> <li>PWM mode:</li> <li>These bits are the two L She of the DWM duty evels. The eight MShe are found in CCRP11.</li> </ul> |                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                        |                                                                                                                                                              |                                                                                                            |                                                                       | R1L.            |
| bit 3-0                                                                  | CCP1M<3:0> 0000 = Captu 0001 = Unus 0010 = Com 0011 = Unus 0100 = Captu 0101 = Captu 0101 = Captu 0110 = Captu 1000 = Com 1001 = Com 1001 = Com 1010 = Com 1010 = Com 1010 = PWM 1101 = PWM 1110 = PWM                                                               | ECCP Mode<br>ure/Compare/F<br>ed (reserved)<br>pare mode, tog<br>ed (reserved)<br>ure mode, eve<br>ure mode, eve<br>ure mode, eve<br>ure mode, eve<br>pare mode, se<br>pare mode, ge<br>ected)<br>pare mode, trig<br>I mode; P1A, F<br>I mode; P1A, F | Select bits<br>PWM off (reset<br>agle output on<br>ry falling edge<br>ry rising edge<br>ry 4th rising ed<br>to utput on ma<br>ear output on m<br>enerate softwa<br>gger special ev<br>PIC active-hig<br>PIC active-low | s ECCP module<br>match (CCP1IF<br>edge<br>tch (CCP1IF bin<br>hatch (CCP1IF bin<br>are interrupt or<br>rent (CCP1IF bin<br>h; P1B, P1D act<br>h; P1B, P1D act | e)<br>F bit is set)<br>bit is set)<br>n match (CCP<br>it is set; CCP1<br>tive-high<br>tive-low<br>ive-high | 21IF bit is set,<br>resets TMR1 c                                     | CCP1 pin is     |

1111 = PWM mode; P1A, P1C active-low; P1B, P1D active-low

# PIC16F882/883/884/886/887

# 11.6.7 PULSE STEERING MODE

In Single Output mode, pulse steering allows any of the PWM pins to be the modulated signal. Additionally, the same PWM signal can be simultaneously available on multiple pins.

Once the Single Output mode is selected (CCP1M<3:2> = 11 and P1M<1:0> = 00 of the CCP1CON register), the user firmware can bring out the same PWM signal to one, two, three or four output pins by setting the appropriate STR<D:A> bits of the PSTRCON register, as shown in Table 11-5.

| Note: | The associated TRIS bits must be set to      |
|-------|----------------------------------------------|
|       | output ('0') to enable the pin output driver |
|       | in order to see the PWM signal on the pin.   |

While the PWM Steering mode is active, CCP1M<1:0> bits of the CCP1CON register select the PWM output polarity for the P1<D:A> pins.

The PWM auto-shutdown operation also applies to PWM Steering mode as described in **Section 11.6.4** "**Enhanced PWM Auto-Shutdown Mode**". An autoshutdown event will only affect pins that have PWM outputs enabled.

# **REGISTER DEFINITIONS: PULSE STEERING CONTROL**

# REGISTER 11-5: PSTRCON: PULSE STEERING CONTROL REGISTER<sup>(1)</sup>

| U-0   | U-0 | U-0 | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-1 |
|-------|-----|-----|---------|-------|-------|-------|-------|
| —     | —   | —   | STRSYNC | STRD  | STRC  | STRB  | STRA  |
| bit 7 |     |     |         |       |       |       | bit 0 |
|       |     |     |         |       |       |       |       |

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

| bit 7-5 | Unimplemented: Read as '0'                                                           |
|---------|--------------------------------------------------------------------------------------|
| bit 4   | STRSYNC: Steering Sync bit                                                           |
|         | 1 = Output steering update occurs on next PWM period                                 |
|         | 0 = Output steering update occurs at the beginning of the instruction cycle boundary |
| bit 3   | STRD: Steering Enable bit D                                                          |
|         | 1 = P1D pin has the PWM waveform with polarity control from CCPxM<1:0>               |
|         | 0 = P1D pin is assigned to port pin                                                  |
| bit 2   | STRC: Steering Enable bit C                                                          |
|         | 1 = P1C pin has the PWM waveform with polarity control from CCPxM<1:0>               |
|         | 0 = P1C pin is assigned to port pin                                                  |
| bit 1   | STRB: Steering Enable bit B                                                          |
|         | 1 = P1B pin has the PWM waveform with polarity control from CCPxM<1:0>               |
|         | 0 = P1B pin is assigned to port pin                                                  |
| bit 0   | STRA: Steering Enable bit A                                                          |
|         | 1 = P1A pin has the PWM waveform with polarity control from CCPxM<1:0>               |
|         | 0 = P1A pin is assigned to port pin                                                  |
|         |                                                                                      |

# Note 1: The PWM Steering mode is available only when the CCP1CON register bits CCP1M<3:2> = 11 and P1M<1:0> = 00.

Logondi

### 13.3.3 MASTER MODE

The master can initiate the data transfer at any time because it controls the SCK. The master determines when the slave is to broadcast data by the software protocol.

In Master mode, the data is transmitted/received as soon as the SSPBUF register is written to. If the SPI is only going to receive, the SDO output could be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPBUF register as a normal received byte (interrupts and Status bits appropriately set). This could be useful in receiver applications as a "Line Activity Monitor" mode. The clock polarity is selected by appropriately programming the CKP bit of the SSPCON register. This, then, would give waveforms for SPI communication as shown in Figure 13-2, Figure 13-4 and Figure 13-5, where the MSb is transmitted first. In Master mode, the SPI clock rate (bit rate) is user programmable to be one of the following:

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

This allows a maximum data rate (at 40 MHz) of 10.00 Mbps.

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





# PIC16F882/883/884/886/887



### 13.4.16.3 Bus Collision During a Stop Condition

Bus collision occurs during a Stop condition if:

- a) After the SDA pin has been de-asserted and allowed to float high, SDA is sampled low after the BRG has timed out.
- b) After the SCL pin is de-asserted, SCL is sampled low before SDA goes high.

The Stop condition begins with SDA asserted low. When SDA is sampled low, the SCL pin is allowed to float. When the pin is sampled high (clock arbitration), the Baud Rate Generator is loaded with SSPADD<6:0> and counts down to 0. After the BRG times out, SDA is sampled. If SDA is sampled low, a bus collision has occurred. This is due to another master attempting to drive a data '0' (Figure 13-26). If the SCL pin is sampled low before SDA is allowed to float high, a bus collision occurs. This is another case of another master attempting to drive a data '0' (Figure 13-27).

# FIGURE 13-26: BUS COLLISION DURING A STOP CONDITION (CASE 1)







#### SSP MASK REGISTER 13.4.17

An SSP Mask (SSPMSK) register is available in I<sup>2</sup>C Slave mode as a mask for the value held in the SSPSR register during an address comparison operation. A zero ('0') bit in the SSPMSK register has the effect of making the corresponding bit in the SSPSR register a "don't care".

This register is reset to all '1's upon any Reset condition and, therefore, has no effect on standard SSP operation until written with a mask value.

This register must be initiated prior to setting SSPM<3:0> bits to select the I<sup>2</sup>C Slave mode (7-bit or 10-bit address).

This register can only be accessed when the appropriate mode is selected by bits (SSPM<3:0> of SSPCON).

The SSP Mask register is active during:

- 7-bit Address mode: address compare of A<7:1>.
- 10-bit Address mode: address compare of A<7:0> only. The SSP mask has no effect during the reception of the first (high) byte of the address.

| R/W-1                                                                                                                                                                                           | R/W-1                                                                                 | R/W-1            | R/W-1 | R/W-1            | R/W-1    | R/W-1          | R/W-1               |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------|-------|------------------|----------|----------------|---------------------|--|
| MSK7                                                                                                                                                                                            | MSK6                                                                                  | MSK5             | MSK4  | MSK3             | MSK2     | MSK1           | MSK0 <sup>(2)</sup> |  |
| bit 7                                                                                                                                                                                           |                                                                                       | ·                |       |                  |          |                | bit 0               |  |
|                                                                                                                                                                                                 |                                                                                       |                  |       |                  |          |                |                     |  |
| Legend:                                                                                                                                                                                         |                                                                                       |                  |       |                  |          |                |                     |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'                                                                                                                            |                                                                                       |                  |       |                  | d as '0' |                |                     |  |
| -n = Value at F                                                                                                                                                                                 | POR                                                                                   | '1' = Bit is set |       | '0' = Bit is cle | ared     | x = Bit is unk | nown                |  |
|                                                                                                                                                                                                 |                                                                                       |                  |       |                  |          |                |                     |  |
| bit 7-1                                                                                                                                                                                         | MSK<7:1>: №                                                                           | lask bits        |       |                  |          | _              |                     |  |
| 1 = The received address bit n is compared to SSPADD <n> to detect <math>I^2C</math> address match<br/>0 = The received address bit n is not used to detect <math>I^2C</math> address match</n> |                                                                                       |                  |       |                  |          |                | itch                |  |
| bit 0                                                                                                                                                                                           | bit 0 MSK<0>: Mask bit for I <sup>2</sup> C Slave mode, 10-bit Address <sup>(2)</sup> |                  |       |                  |          |                |                     |  |
|                                                                                                                                                                                                 | $I^2C$ Slave mode, 10-bit Address (SSPM<3:0> = 0111):                                 |                  |       |                  |          |                |                     |  |

#### SSPMSK: SSP MASK REGISTER<sup>(1)</sup> REGISTER 13-4:

- 1 = The received address bit 0 is compared to SSPADD<0> to detect  $I^2C$  address match 0 = The received address bit 0 is not used to detect I<sup>2</sup>C address match
- Note 1: When SSPCON bits SSPM<3:0> = 1001, any reads or writes to the SSPADD SFR address are accessed through the SSPMSK register.
  - 2: In all other SSP modes, this bit has no effect.

# 14.5 Watchdog Timer (WDT)

The WDT has the following features:

- Operates from the LFINTOSC (31 kHz)
- · Contains a 16-bit prescaler
- Shares an 8-bit prescaler with Timer0
- Time-out period is from 1 ms to 268 seconds
- · Configuration bit and software controlled

WDT is cleared under certain conditions described in Table 14-7.

### 14.5.1 WDT OSCILLATOR

The WDT derives its time base from the 31 kHz LFINTOSC. The LTS bit of the OSCCON register does not reflect that the LFINTOSC is enabled.

The value of WDTCON is '---0 1000' on all Resets. This gives a nominal time base of 17 ms.

# Note: When the Oscillator Start-up Timer (OST) is invoked, the WDT is held in Reset, because the WDT Ripple Counter is used by the OST to perform the oscillator delay count. When the OST count has expired, the WDT will begin counting (if enabled).

# FIGURE 14-9: WATCHDOG TIMER BLOCK DIAGRAM



WDT CONTROL

The WDTE bit is located in the Configuration Word

When the WDTE bit in the Configuration Word

Register 1 is set, the SWDTEN bit of the WDTCON

register has no effect. If WDTE is clear, then the

SWDTEN bit can be used to enable and disable the

WDT. Setting the bit will enable it and clearing the bit

The PSA and PS<2:0> bits of the OPTION register have the same function as in previous versions of the

PIC16F882/883/884/886/887 family of microcontrollers. See Section 5.0 "Timer0 Module" for more

Register 1. When set, the WDT runs continuously.

14.5.2

will disable it.

information.

# TABLE 14-7: WDT STATUS

| Conditions                                               | WDT                          |
|----------------------------------------------------------|------------------------------|
| WDTE = 0                                                 | Cleared                      |
| CLRWDT Command                                           |                              |
| Oscillator Fail Detected                                 |                              |
| Exit Sleep + System Clock = T1OSC, EXTRC, INTOSC, EXTCLK |                              |
| Exit Sleep + System Clock = XT, HS, LP                   | Cleared until the end of OST |

# **15.0 INSTRUCTION SET SUMMARY**

The PIC16F882/883/884/886/887 instruction set is highly orthogonal and is comprised of three basic categories:

- Byte-oriented operations
- Bit-oriented operations
- Literal and control operations

Each PIC16 instruction is a 14-bit word divided into an **opcode**, which specifies the instruction type and one or more **operands**, which further specify the operation of the instruction. The formats for each of the categories is presented in Figure 15-1, while the various opcode fields are summarized in Table 15-1.

Table 15-2 lists the instructions recognized by the MPASM<sup>TM</sup> assembler.

For **byte-oriented** instructions, 'f' represents a file register designator and 'd' represents a destination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is zero, the result is placed in the W register. If 'd' is one, the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator, which selects the bit affected by the operation, while 'f' represents the address of the file in which the bit is located.

For **literal and control** operations, 'k' represents an 8-bit or 11-bit constant, or literal value.

One instruction cycle consists of four oscillator periods; for an oscillator frequency of 4 MHz, this gives a normal instruction execution time of 1  $\mu$ s. All instructions are executed within a single instruction cycle, unless a conditional test is true, or the program counter is changed as a result of an instruction. When this occurs, the execution takes two instruction cycles, with the second cycle executed as a NOP.

All instruction examples use the format '0xhh' to represent a hexadecimal number, where 'h' signifies a hexadecimal digit.

# 15.1 Read-Modify-Write Operations

Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (RMW) operation. The register is read, the data is modified, and the result is stored according to either the instruction, or the destination designator 'd'. A read operation is performed on a register even if the instruction writes to that register.

For example, a CLRF PORTA instruction will read PORTA, clear all the data bits, then write the result back to PORTA. This example would have the unintended consequence of clearing the condition that set the RAIF flag.

# TABLE 15-1: OPCODE FIELD DESCRIPTIONS

| Field | Description                                                                                                                                                                     |  |  |  |  |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| f     | Register file address (0x00 to 0x7F)                                                                                                                                            |  |  |  |  |  |  |
| W     | Working register (accumulator)                                                                                                                                                  |  |  |  |  |  |  |
| b     | Bit address within an 8-bit file register                                                                                                                                       |  |  |  |  |  |  |
| k     | Literal field, constant data or label                                                                                                                                           |  |  |  |  |  |  |
| x     | Don't care location (= 0 or 1).<br>The assembler will generate code with $x = 0$ .<br>It is the recommended form of use for<br>compatibility with all Microchip software tools. |  |  |  |  |  |  |
| d     | Destination select; $d = 0$ : store result in W,<br>d = 1: store result in file register f.<br>Default is $d = 1$ .                                                             |  |  |  |  |  |  |
| PC    | Program Counter                                                                                                                                                                 |  |  |  |  |  |  |
| TO    | Time-out bit                                                                                                                                                                    |  |  |  |  |  |  |
| С     | Carry bit                                                                                                                                                                       |  |  |  |  |  |  |
| DC    | Digit carry bit                                                                                                                                                                 |  |  |  |  |  |  |
| Z     | Zero bit                                                                                                                                                                        |  |  |  |  |  |  |
| PD    | Power-down bit                                                                                                                                                                  |  |  |  |  |  |  |

### FIGURE 15-1: GENERAL FORMAT FOR INSTRUCTIONS



# TABLE 17-11: PIC16F882/883/884/886/887 A/D CONVERSION REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |      |                                                                       |            |              |            |       |                                                                                                                                                           |  |  |
|----------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------|------------|--------------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Param<br>No.                                                                                                         | Sym. | Characteristic                                                        | Min.       | Тур†         | Max.       | Units | Conditions                                                                                                                                                |  |  |
| AD130*                                                                                                               | Tad  | A/D Clock Period                                                      | 1.6        | —            | 9.0        | μS    | Tosc-based, VREF $\geq$ 3.0V                                                                                                                              |  |  |
|                                                                                                                      |      |                                                                       | 3.0        | —            | 9.0        | μS    | Tosc-based, VREF full range                                                                                                                               |  |  |
|                                                                                                                      |      | A/D Internal RC<br>Oscillator Period                                  | 3.0<br>1.6 | 6.0<br>4.0   | 9.0<br>6.0 | μS    | ADCS<1:0> = 11 (ADRC mode)<br>At VDD = 2.5V<br>At VDD = 5.0V                                                                                              |  |  |
| AD131                                                                                                                | TCNV | Conversion Time<br>(not including<br>Acquisition Time) <sup>(1)</sup> | _          | 11           | _          | TAD   | Set GO/DONE bit to new data in A/D<br>Result register                                                                                                     |  |  |
| AD132*                                                                                                               | TACQ | Acquisition Time                                                      |            | 11.5         | —          | μS    |                                                                                                                                                           |  |  |
| AD133*                                                                                                               | Тамр | Amplifier Settling Time                                               |            | —            | 5          | μS    |                                                                                                                                                           |  |  |
| AD134                                                                                                                | Tgo  | Q4 to A/D Clock Start                                                 |            | Tosc/2       | —          | —     |                                                                                                                                                           |  |  |
|                                                                                                                      |      |                                                                       | _          | Tosc/2 + Tcy |            |       | If the A/D clock source is selected as<br>RC, a time of TCY is added before the<br>A/D clock starts. This allows the SLEEP<br>instruction to be executed. |  |  |

\* 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: ADRESH and ADRESL registers may be read on the following TCY cycle.

2: See Section 9.3 "A/D Acquisition Requirements" for minimum conditions.

# PIC16F882/883/884/886/887

# 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

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



Microchip Technology Drawing C04-052C Sheet 1 of 2

# 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN]



Microchip Technology Drawing C04-103C Sheet 1 of 2