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 - Microcontrollers</u>" | Details | | |----------------------------|--------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 20MHz | | Connectivity | UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 33 | | Program Memory Size | 3.5KB (2K x 14) | | Program Memory Type | FLASH | | EEPROM Size | 64 x 8 | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V | | Data Converters | A/D 8x10b | | Oscillator Type | External | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-LCC (J-Lead) | | Supplier Device Package | 44-PLCC (16.59x16.59) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf871-i-l | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong | Key Features<br>PICmicro™ Mid-Range MCU Family Reference Manual<br>(DS33023) | PIC16F870 | PIC16F871 | |------------------------------------------------------------------------------|----------------------|----------------------| | Operating Frequency | DC - 20 MHz | DC - 20 MHz | | RESETS (and Delays) | POR, BOR (PWRT, OST) | POR, BOR (PWRT, OST) | | FLASH Program Memory (14-bit words) | 2K | 2K | | Data Memory (bytes) | 128 | 128 | | EEPROM Data Memory | 64 | 64 | | Interrupts | 10 | 11 | | I/O Ports | Ports A,B,C | Ports A,B,C,D,E | | Timers | 3 | 3 | | Capture/Compare/PWM modules | 1 | 1 | | Serial Communications | USART | USART | | Parallel Communications | _ | PSP | | 10-bit Analog-to-Digital Module | 5 input channels | 8 input channels | | Instruction Set | 35 Instructions | 35 Instructions | TABLE 1-1: PIC16F870 PINOUT DESCRIPTION | Pin Name | DIP<br>Pin# | SOIC<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | |-----------------|-------------|--------------|---------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OSC1/CLKI | 9 | 9 | I | ST/CMOS <sup>(3)</sup> | Oscillator crystal input/external clock source input. | | OSC2/CLKO | 10 | 10 | 0 | _ | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. In RC mode, the OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. | | MCLR/VPP/THV | 1 | 1 | I/P | ST | Master Clear (Reset) input or programming voltage input or High Voltage Test mode control. This pin is an active low RESET to the device. | | | | | | | PORTA is a bi-directional I/O port. | | RA0/AN0 | 2 | 2 | I/O | TTL | RA0 can also be analog input 0. | | RA1/AN1 | 3 | 3 | I/O | TTL | RA1 can also be analog input 1. | | RA2/AN2/VREF- | 4 | 4 | I/O | TTL | RA2 can also be analog input 2 or negative analog reference voltage. | | RA3/AN3/VREF+ | 5 | 5 | I/O | TTL | RA3 can also be analog input 3 or positive analog reference voltage. | | RA4/T0CKI | 6 | 6 | I/O | ST/OD | RA4 can also be the clock input to the Timer0 module. Output is open drain type. | | RA5/AN4 | 7 | 7 | I/O | TTL | RA5 can also be analog input 4. | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs. | | RB0/INT | 21 | 21 | I/O | TTL/ST <sup>(1)</sup> | RB0 can also be the external interrupt pin. | | RB1 | 22 | 22 | I/O | TTL | | | RB2 | 23 | 23 | I/O | TTL | | | RB3/PGM | 24 | 24 | I/O | TTL/ST <sup>(1)</sup> | RB3 can also be the low voltage programming input. | | RB4 | 25 | 25 | I/O | TTL | Interrupt-on-change pin. | | RB5 | 26 | 26 | I/O | TTL | Interrupt-on-change pin. | | RB6/PGC | 27 | 27 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming clock. | | RB7/PGD | 28 | 28 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin. Serial programming data. | | | | | | | PORTC is a bi-directional I/O port. | | RC0/T1OSO/T1CKI | 11 | 11 | I/O | ST | RC0 can also be the Timer1 oscillator output or Timer1 clock input. | | RC1/T1OSI | 12 | 12 | I/O | ST | RC1 can also be the Timer1 oscillator input. | | RC2/CCP1 | 13 | 13 | I/O | ST | RC2 can also be the Capture1 input/Compare1 output/<br>PWM1 output. | | RC3 | 14 | 14 | I/O | ST | | | RC4 | 15 | 15 | I/O | ST | | | RC5 | 16 | 16 | I/O | ST | | | RC6/TX/CK | 17 | 17 | I/O | ST | RC6 can also be the USART Asynchronous Transmit or Synchronous Clock. | | RC7/RX/DT | 18 | 18 | I/O | ST | RC7 can also be the USART Asynchronous Receive or Synchronous Data. | | Vss | 8, 19 | 8, 19 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 20 | 20 | Р | _ | Positive supply for logic and I/O pins. | Legend: I = input O = output — = Not used I/O = input/output TTL = TTL input P = power ST = Schmitt Trigger input Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt or LVP mode. - 2: This buffer is a Schmitt Trigger input when used in Serial Programming mode. - 3: This buffer is a Schmitt Trigger input when configured in RC Oscillator mode and a CMOS input otherwise. OD = Open Drain **TABLE 1-2:** PIC16F871 PINOUT DESCRIPTION | Pin Name | DIP<br>Pin# | PLCC<br>Pin# | QFP<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description | | | |-----------------|-------------|--------------|-------------|---------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | OSC1/CLKI | 13 | 14 | 30 | I | ST/CMOS <sup>(4)</sup> | Oscillator crystal input/external clock source input. | | | | OSC2/CLKO | 14 | 15 | 31 | 0 | Н | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. In RC mode, OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. | | | | MCLR/VPP/THV | 1 | 2 | 18 | I/P | ST | Master Clear (Reset) input or programming voltage input or High Voltage Test mode control. This pin is an active low RESET to the device. | | | | | | | | | | PORTA is a bi-directional I/O port. | | | | RA0/AN0 | 2 | 3 | 19 | I/O | TTL | RA0 can also be analog input 0. | | | | RA1/AN1 | 3 | 4 | 20 | I/O | TTL | RA1 can also be analog input 1. | | | | RA2/AN2/VREF- | 4 | 5 | 21 | I/O | TTL | RA2 can also be analog input 2 or negative analog reference voltage. | | | | RA3/AN3/VREF+ | 5 | 6 | 22 | I/O | TTL | RA3 can also be analog input 3 or positive analog reference voltage. | | | | RA4/T0CKI | 6 | 7 | 23 | I/O | ST | RA4 can also be the clock input to the Timer0 timer/counter. Output is open drain type. | | | | RA5/AN4 | 7 | 8 | 24 | I/O | TTL | RA5 can also be analog input 4. | | | | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs. | | | | RB0/INT | 33 | 36 | 8 | I/O | TTL/ST <sup>(1)</sup> | RB0 can also be the external interrupt pin. | | | | RB1 | 34 | 37 | 9 | I/O | TTL | | | | | RB2 | 35 | 38 | 10 | I/O | TTL | | | | | RB3/PGM | 36 | 39 | 11 | I/O | TTL/ST <sup>(1)</sup> | RB3 can also be the low voltage programming input. | | | | RB4 | 37 | 41 | 14 | I/O | TTL | Interrupt-on-change pin. | | | | RB5 | 38 | 42 | 15 | I/O | TTL | Interrupt-on-change pin. | | | | RB6/PGC | 39 | 43 | 16 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming clock. | | | | RB7/PGD | 40 | 44 | 17 | I/O | TTL/ST <sup>(2)</sup> | Interrupt-on-change pin or In-Circuit Debugger pin.<br>Serial programming data. | | | | | | | | | | PORTC is a bi-directional I/O port. | | | | RC0/T1OSO/T1CKI | 15 | 16 | 32 | I/O | ST | RC0 can also be the Timer1 oscillator output or a Timer1 clock input. | | | | RC1/T1OSI | 16 | 18 | 35 | I/O | ST | RC1 can also be the Timer1 oscillator input. | | | | RC2/CCP1 | 17 | 19 | 36 | I/O | ST | RC2 can also be the Capture1 input/Compare1 output/PWM1 output. | | | | RC3 | 18 | 20 | 37 | I/O | ST | | | | | RC4 | 23 | 25 | 42 | I/O | ST | | | | | RC5 | 24 | 26 | 43 | I/O | ST | | | | | RC6/TX/CK | 25 | 27 | 44 | I/O | ST | RC6 can also be the USART Asynchronous Transmit or Synchronous Clock. | | | | RC7/RX/DT | 26 | 29 | 1 | I/O | ST | RC7 can also be the USART Asynchronous Receive or Synchronous Data. | | | | | | | • | | | thuit D navior | | | Legend: I = input O = output I/O = input/output P = power TTL = TTL input ST = Schmitt Trigger input Note 1: This buffer is a Schmitt Trigger input when configured as an external interrupt or LVP mode. - 2: This buffer is a Schmitt Trigger input when used in Serial Programming mode. - 3: This buffer is a Schmitt Trigger input when configured as general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus). - 4: This buffer is a Schmitt Trigger input when configured in RC Oscillator mode and a CMOS input otherwise. #### 2.2.2.5 PIR1 Register The PIR1 register contains the individual flag bits for the peripheral interrupts. Note: Interrupt flag bits get set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt bits are clear prior to enabling an interrupt. #### REGISTER 2-5: PIR1 REGISTER (ADDRESS: 0Ch) | R/W-0 | R/W-0 | R-0 | R-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | |----------------------|-------|------|------|-----|--------|--------|--------| | PSPIF <sup>(1)</sup> | ADIF | RCIF | TXIF | _ | CCP1IF | TMR2IF | TMR1IF | | bit 7 | | | | | | | bit 0 | bit 7 **PSPIF**<sup>(1)</sup>: Parallel Slave Port Read/Write Interrupt Flag bit 1 = A read or a write operation has taken place (must be cleared in software) 0 = No read or write has occurred bit 6 ADIF: A/D Converter Interrupt Flag bit 1 = An A/D conversion completed 0 = The A/D conversion is not complete bit 5 RCIF: USART Receive Interrupt Flag bit 1 = The USART receive buffer is full 0 = The USART receive buffer is empty bit 4 **TXIF**: USART Transmit Interrupt Flag bit 1 = The USART transmit buffer is empty 0 = The USART transmit buffer is full bit 3 **Unimplemented**: Read as '0' bit 2 **CCP1IF**: CCP1 Interrupt Flag bit Capture mode: 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare mode: 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM mode: Unused in this mode. bit 1 TMR2IF: TMR2 to PR2 Match Interrupt Flag bit 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred bit 0 TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflowed (must be cleared in software) 0 = TMR1 register did not overflow Note 1: PSPIF is reserved on the PIC16F870; always maintain this bit clear. | Legend: | | | | |--------------------|------------------|----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented | bit, read as '0' | | - n = Value at POR | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | #### 2.2.2.6 PIE2 Register The PIE2 register contains the individual enable bit for the EEPROM write operation interrupt. #### REGISTER 2-6: PIE2 REGISTER (ADDRESS: 8Dh) | U-0 | U-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | |-------|-----|-----|-------|-----|-----|-----|-------| | _ | _ | _ | EEIE | _ | _ | | _ | | bit 7 | | • | | • | | • | bit 0 | bit 7-5 Unimplemented: Read as '0' bit 4 **EEIE**: EEPROM Write Operation Interrupt Enable bit 1 = Enable EE write interrupt0 = Disable EE write interrupt bit 3-0 Unimplemented: Read as '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 #### 2.2.2.8 PCON Register The Power Control (PCON) register contains flag bits to allow differentiation between a Power-on Reset (POR), a Brown-out Reset (BOR), a Watchdog Reset (WDT) and an external MCLR Reset. Note: BOR is unknown on POR. It must be set by the user and checked on subsequent RESETS to see if BOR is clear, indicating a brown-out has occurred. The BOR status bit is a don't care and is not predictable if the brown-out circuit is disabled (by clearing the BOREN bit in the configuration word). #### REGISTER 2-8: PCON REGISTER (ADDRESS: 8Eh) | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-1 | |-------|-----|-----|-----|-----|-----|-------|-------| | _ | _ | _ | _ | _ | _ | POR | BOR | | bit 7 | | | | | | | bit 0 | bit 7-2 Unimplemented: Read as '0' bit 1 POR: Power-on Reset Status bit 1 = No Power-on Reset occurred 0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs) bit 0 BOR: Brown-out Reset Status bit 1 = No Brown-out Reset occurred 0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs) Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' - n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown #### 8.2 Capture Mode In Capture mode, CCPR1H:CCPR1L captures the 16-bit value of the TMR1 register when an event occurs on pin RC2/CCP1. An event is defined as one of the following: - · Every falling edge - · Every rising edge - · Every 4th rising edge - · Every 16th rising edge The type of event is configured by control bits CCP1M3:CCP1M0 (CCP1CON<3:0>). When a capture is made, the interrupt request flag bit CCP1IF (PIR1<2>) is set. The interrupt flag must be cleared in software. If another capture occurs before the value in register CCPR1 is read, the old captured value is overwritten by the new value. #### 8.2.1 CCP PIN CONFIGURATION In Capture mode, the RC2/CCP1 pin should be configured as an input by setting the TRISC<2> bit. **Note:** If the RC2/CCP1 pin is configured as an output, a write to the port can cause a capture condition. # FIGURE 8-1: CAPTURE MODE OPERATION BLOCK DIAGRAM #### 8.2.2 TIMER1 MODE SELECTION Timer1 must be running in Timer mode, or Synchronized Counter mode, for the CCP module to use the capture feature. In Asynchronous Counter mode, the capture operation may not work. #### 8.2.3 SOFTWARE INTERRUPT When the Capture mode is changed, a false capture interrupt may be generated. The user should keep bit CCP1IE (PIE1<2>) clear to avoid false interrupts and should clear the flag bit, CCP1IF, following any such change in Operating mode. #### 8.2.4 CCP PRESCALER There are four prescaler settings, specified by bits CCP1M3:CCP1M0. Whenever the CCP module is turned off, or the CCP module is not in Capture mode, the prescaler counter is cleared. Any RESET will clear the prescaler counter. Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared, therefore, the first capture may be from a non-zero prescaler. Example 8-1 shows the recommended method for switching between capture prescalers. This example also clears the prescaler counter and will not generate the "false" interrupt. ### EXAMPLE 8-1: CHANGING BETWEEN CAPTURE PRESCALERS TABLE 9-4: BAUD RATES FOR ASYNCHRONOUS MODE (BRGH = 1) | BAUD | F | osc = 20 M | Hz | F | osc = 16 M | Hz | Fosc = 10 MHz | | | |-------------|----------|------------|-----------------------------|----------|------------|-----------------------------|---------------|------------|-----------------------------| | RATE<br>(K) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | KBAUD | %<br>ERROR | SPBRG<br>value<br>(decimal) | | 0.3 | - | - | - | - | - | - | - | - | - | | 1.2 | - | - | - | - | - | - | - | - | - | | 2.4 | - | - | - | - | - | - | 2.441 | 1.71 | 255 | | 9.6 | 9.615 | 0.16 | 129 | 9.615 | 0.16 | 103 | 9.615 | 0.16 | 64 | | 19.2 | 19.231 | 0.16 | 64 | 19.231 | 0.16 | 51 | 19.531 | 1.72 | 31 | | 28.8 | 29.070 | 0.94 | 42 | 29.412 | 2.13 | 33 | 28.409 | 1.36 | 21 | | 33.6 | 33.784 | 0.55 | 36 | 33.333 | 0.79 | 29 | 32.895 | 2.10 | 18 | | 57.6 | 59.524 | 3.34 | 20 | 58.824 | 2.13 | 16 | 56.818 | 1.36 | 10 | | HIGH | 4.883 | - | 255 | 3.906 | - | 255 | 2.441 | - | 255 | | LOW | 1250.000 | - | 0 | 1000.000 | | 0 | 625.000 | - | 0 | | BAUD | F | osc = 4 MH | łz | Fosc = 3.6864 MHz | | | | |-------------|---------|------------|-------|-------------------|------------|-----------------------------|--| | RATE<br>(K) | KBAUD | %<br>ERROR | Value | | %<br>ERROR | SPBRG<br>value<br>(decimal) | | | 0.3 | - | - | - | - | - | - | | | 1.2 | 1.202 | 0.17 | 207 | 1.2 | 0 | 191 | | | 2.4 | 2.404 | 0.17 | 103 | 2.4 | 0 | 95 | | | 9.6 | 9.615 | 0.16 | 25 | 9.6 | 0 | 23 | | | 19.2 | 19.231 | 0.16 | 12 | 19.2 | 0 | 11 | | | 28.8 | 27.798 | 3.55 | 8 | 28.8 | 0 | 7 | | | 33.6 | 35.714 | 6.29 | 6 | 32.9 | 2.04 | 6 | | | 57.6 | 62.500 | 8.51 | 3 | 57.6 | 0 | 3 | | | HIGH | 0.977 | - | 255 | 0.9 | - | 255 | | | LOW | 250.000 | - | 0 | 230.4 | - | 0 | | When setting up an Asynchronous Transmission, follow these steps: - 1. Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, set bit BRGH (Section 9.1). - Enable the asynchronous serial port by clearing bit SYNC and setting bit SPEN. - If interrupts are desired, then set enable bit TXIE. - If 9-bit transmission is desired, then set transmit bit TX9. - Enable the transmission by setting bit TXEN, which will also set bit TXIF. - 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D. - Load data to the TXREG register (starts transmission). - If using interrupts, ensure that GIE and PEIE (bits 7 and 6) of the INTCON register are set. #### FIGURE 9-2: ASYNCHRONOUS MASTER TRANSMISSION #### FIGURE 9-3: ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK) #### TABLE 9-5: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR, BOR | Value on<br>all other<br>RESETS | |------------------------|--------|----------------------|----------|------------|-------|-------|--------|--------|--------|-----------------------|---------------------------------| | 0Bh, 8Bh,<br>10Bh,18Bh | INTCON | GIE | PEIE | TOIE | INTE | RBIE | TOIF | INTF | R0IF | 0000 000x | 0000 000u | | 0Ch | PIR1 | PSPIF <sup>(1)</sup> | ADIF | RCIF | TXIF | _ | CCP1IF | TMR2IF | TMR1IF | 0000 -000 | 0000 -000 | | 18h | RCSTA | SPEN | RX9 | SREN | CREN | _ | FERR | OERR | RX9D | 0000 -00x | 0000 -00x | | 19h | TXREG | USART Tra | nsmit Re | gister | | | | | | 0000 0000 | 0000 0000 | | 8Ch | PIE1 | PSPIE <sup>(1)</sup> | ADIE | RCIE | TXIE | _ | CCP1IE | TMR2IE | TMR1IE | 0000 -000 | 0000 -000 | | 98h | TXSTA | CSRC | TX9 | TXEN | SYNC | _ | BRGH | TRMT | TX9D | 0000 -010 | 0000 -010 | | 99h | SPBRG | Baud Rate | Generato | r Register | | • | • | • | | 0000 0000 | 0000 0000 | Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for asynchronous transmission. Note 1: Bits PSPIE and PSPIF are reserved on the PIC16F870; always maintain these bits clear. #### 10.4 A/D Conversions Clearing the GO/DONE bit during a conversion will abort the current conversion. The A/D result register pair will NOT be updated with the partially completed A/D conversion sample. That is, the ADRESH:ADRESL registers will continue to contain the value of the last completed conversion (or the last value written to the ADRESH:ADRESL registers). After the A/D conversion is aborted, a 2 TAD wait is required before the next acquisition is started. After this 2 TAD wait, acquisition on the selected channel is automatically started. The GO/DONE bit can then be set to start the conversion. In Figure 10-3, after the GO bit is set, the first time segment has a minimum of TCY and a maximum of TAD. **Note:** The GO/DONE bit should **NOT** be set in the same instruction that turns on the A/D. #### FIGURE 10-3: A/D CONVERSION TAD CYCLES #### 10.4.1 A/D RESULT REGISTERS The ADRESH:ADRESL register pair is the location where the 10-bit A/D result is loaded at the completion of the A/D conversion. This register pair is 16-bits wide. The A/D module gives the flexibility to left or right justify the 10-bit result in the 16-bit result register. The A/D For- mat Select bit (ADFM) controls this justification. Figure 10-4 shows the operation of the A/D result justification. The extra bits are loaded with '0'. When an A/D result will not overwrite these locations (A/D disable), these registers may be used as two general purpose 8-bit registers. #### FIGURE 10-4: A/D RESULT JUSTIFICATION TABLE 11-4: STATUS BITS AND THEIR SIGNIFICANCE | POR | BOR | то | PD | | |-----|-----|----|----|---------------------------------------------------------| | 0 | х | 1 | 1 | Power-on Reset | | 0 | х | 0 | х | Illegal, TO is set on POR | | 0 | х | х | 0 | Illegal, PD is set on POR | | 1 | 0 | 1 | 1 | Brown-out Reset | | 1 | 1 | 0 | 1 | WDT Reset | | 1 | 1 | 0 | 0 | WDT Wake-up | | 1 | 1 | u | u | MCLR Reset during normal operation | | 1 | 1 | 1 | 0 | MCLR Reset during SLEEP or interrupt wake-up from SLEEP | Legend: x = don't care, u = unchanged TABLE 11-5: RESET CONDITION FOR SPECIAL REGISTERS | Condition | Program<br>Counter | STATUS<br>Register | PCON<br>Register | |------------------------------------|-----------------------|--------------------|------------------| | Power-on Reset | 000h | 0001 1xxx | 0x | | MCLR Reset during normal operation | 000h | 000u uuuu | uu | | MCLR Reset during SLEEP | 000h | 0001 0uuu | uu | | WDT Reset | 000h | 0000 luuu | uu | | WDT Wake-up | PC + 1 | uuu0 0uuu | uu | | Brown-out Reset | 000h | 0001 1uuu | u0 | | Interrupt wake-up from SLEEP | PC + 1 <sup>(1)</sup> | uuu1 0uuu | uu | Legend: u = unchanged, x = unknown, - = unimplemented bit, read as '0' Note 1: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h). TABLE 11-6: INITIALIZATION CONDITIONS FOR ALL REGISTERS | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | TO THE TENED TO THE TENED TENED | | | | | | | | | |-----------------------------------------|---------------------------------|-----------|------------------------------------|--------------------------|---------------------------------|--|--|--|--| | Register | ister Devices | | Power-on Reset,<br>Brown-out Reset | MCLR Resets<br>WDT Reset | Wake-up via WDT or<br>Interrupt | | | | | | W | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | INDF | PIC16F870 | PIC16F871 | N/A | N/A | N/A | | | | | | TMR0 | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | PCL | PIC16F870 | PIC16F871 | 0000h | 0000h | PC + 1 <sup>(2)</sup> | | | | | | STATUS | PIC16F870 | PIC16F871 | 0001 1xxx | 000q quuu <b>(3)</b> | uuuq quuu(3) | | | | | | FSR | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | PORTA | PIC16F870 | PIC16F871 | 0x 0000 | 0u 0000 | uu uuuu | | | | | | PORTB | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | PORTC | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | PORTD | PIC16F870 | PIC16F871 | xxxx xxxx | uuuu uuuu | uuuu uuuu | | | | | | PORTE | PIC16F870 | PIC16F871 | xxx | uuu | uuu | | | | | | PCLATH | PIC16F870 | PIC16F871 | 0 0000 | 0 0000 | u uuuu | | | | | | INTCON | PIC16F870 | PIC16F871 | 0000 000x | 0000 000u | uuuu uuuu(1) | | | | | Legend: u = unchanged, x = unknown, - = unimplemented bit, read as '0', <math>q = value depends on condition, r = reserved, maintain clear Note 1: One or more bits in INTCON, PIR1 and/or PIR2 will be affected (to cause wake-up). - 2: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h). - 3: See Table 11-5 for RESET value for specific condition. #### 11.13 Power-down Mode (SLEEP) Power-down mode is entered by executing a ${\tt SLEEP}$ instruction. If enabled, the Watchdog Timer will be cleared but keeps running, the $\overline{PD}$ bit (STATUS<3>) is cleared, the $\overline{TO}$ (STATUS<4>) bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, low, or hi-impedance). For lowest current consumption in this mode, place all I/O pins at either VDD or Vss, ensure no external circuitry is drawing current from the I/O pin, power-down the A/D and disable external clocks. Pull all I/O pins that are hi-impedance inputs, high or low externally, to avoid switching currents caused by floating inputs. The TOCKI input should also be at VDD or Vss for lowest current consumption. The contribution from on-chip pull-ups on PORTB should also be considered. The MCLR pin must be at a logic high level (VIHMC). #### 11.13.1 WAKE-UP FROM SLEEP The device can wake-up from SLEEP through one of the following events: - 1. External RESET input on MCLR pin. - Watchdog Timer Wake-up (if WDT was enabled). - 3. Interrupt from INT pin, RB port change or peripheral interrupt. External MCLR Reset will cause a device RESET. All other events are considered a continuation of program execution and cause a "wake-up". The TO and PD bits in the STATUS register can be used to determine the cause of device RESET. The PD bit, which is set on power-up, is cleared when SLEEP is invoked. The TO bit is cleared if a WDT time-out occurred and caused wake-up. The following peripheral interrupts can wake the device from SLEEP: - 1. PSP read or write (PIC16F874/877 only). - 2. TMR1 interrupt. Timer1 must be operating as an asynchronous counter. - 3. CCP Capture mode interrupt. - Special event trigger (Timer1 in Asynchronous mode using an external clock). - 5. SSP (START/STOP) bit detect interrupt. - SSP transmit or receive in Slave mode (SPI/I<sup>2</sup>C). - 7. USART RX or TX (Synchronous Slave mode). - 8. A/D conversion (when A/D clock source is RC). - 9. EEPROM write operation completion Other peripherals cannot generate interrupts, since during SLEEP, no on-chip clocks are present. When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up is regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction and then branches to the interrupt address (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction. #### 11.13.2 WAKE-UP USING INTERRUPTS When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur: - If the interrupt occurs before the execution of a SLEEP instruction, the SLEEP instruction will complete as a NOP. Therefore, the WDT and WDT postscaler will not be cleared, the TO bit will not be set and PD bits will not be cleared. - If the interrupt occurs during or after the execution of a SLEEP instruction, the device will immediately wake-up from SLEEP. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT postscaler will be cleared, the TO bit will be set and the PD bit will be cleared. Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the $\overline{PD}$ bit. If the $\overline{PD}$ bit is set, the SLEEP instruction was executed as a NOP. To ensure that the WDT is cleared, a <code>CLRWDT</code> instruction should be executed before a <code>SLEEP</code> instruction. ### PIC16F870/871 TABLE 12-2: PIC16F870/871 INSTRUCTION SET | Mnemo | Mnemonic, Operands Description | | Cycles | | 14-Bit ( | Opcode | Status | Notes | | |--------|--------------------------------|------------------------------|---------|--------|----------|--------|--------|----------|-------| | Opera | | | Cycles | MSb | | | LSb | Affected | Notes | | | | BYTE-ORIENTED FILE REGIS | TER OPE | RATIO | NS | | | | | | ADDWF | f, d | Add W and f | 1 | 0.0 | 0111 | dfff | ffff | C,DC,Z | 1,2 | | ANDWF | f, d | AND W with f | 1 | 00 | 0101 | dfff | ffff | Z | 1,2 | | CLRF | f | Clear f | 1 | 00 | 0001 | lfff | ffff | Z | 2 | | CLRW | - | Clear W | 1 | 00 | 0001 | 0xxx | xxxx | Z | | | COMF | f, d | Complement f | 1 | 00 | 1001 | dfff | ffff | Z | 1,2 | | DECF | f, d | Decrement f | 1 | 00 | 0011 | dfff | ffff | Z | 1,2 | | DECFSZ | f, d | Decrement f, Skip if 0 | 1(2) | 00 | 1011 | dfff | ffff | | 1,2,3 | | INCF | f, d | Increment f | 1 | 00 | 1010 | dfff | ffff | Z | 1,2 | | INCFSZ | f, d | Increment f, Skip if 0 | 1(2) | 00 | 1111 | dfff | ffff | | 1,2,3 | | IORWF | f, d | Inclusive OR W with f | 1 | 00 | 0100 | dfff | ffff | Z | 1,2 | | MOVF | f, d | Move f | 1 | 00 | 1000 | dfff | ffff | Z | 1,2 | | MOVWF | f | Move W to f | 1 | 00 | 0000 | lfff | ffff | | | | NOP | - | No Operation | 1 | 00 | 0000 | 0xx0 | 0000 | | | | RLF | f, d | Rotate Left f through Carry | 1 | 00 | 1101 | dfff | ffff | С | 1,2 | | RRF | f, d | Rotate Right f through Carry | 1 | 00 | 1100 | dfff | ffff | С | 1,2 | | SUBWF | f, d | Subtract W from f | 1 | 00 | 0010 | dfff | ffff | C,DC,Z | 1,2 | | SWAPF | f, d | Swap nibbles in f | 1 | 00 | 1110 | dfff | ffff | | 1,2 | | XORWF | f, d | Exclusive OR W with f | 1 | 00 | 0110 | dfff | ffff | Z | 1,2 | | | | BIT-ORIENTED FILE REGIST | ER OPER | RATION | NS | | | | | | BCF | f, b | Bit Clear f | 1 | 01 | 00bb | bfff | ffff | | 1,2 | | BSF | f, b | Bit Set f | 1 | 01 | 01bb | bfff | ffff | | 1,2 | | BTFSC | f, b | Bit Test f, Skip if Clear | 1 (2) | 01 | 10bb | bfff | ffff | | 3 | | BTFSS | f, b | Bit Test f, Skip if Set | 1 (2) | 01 | 11bb | bfff | ffff | | 3 | | | | LITERAL AND CONTROL | OPERATI | IONS | | | | | | | ADDLW | k | Add literal and W | 1 | 11 | 111x | kkkk | kkkk | C,DC,Z | | | ANDLW | k | AND literal with W | 1 | 11 | 1001 | kkkk | kkkk | Z | | | CALL | k | Call subroutine | 2 | 10 | 0kkk | kkkk | kkkk | | | | CLRWDT | - | Clear Watchdog Timer | 1 | 00 | 0000 | 0110 | 0100 | TO,PD | | | GOTO | k | Go to address | 2 | 10 | 1kkk | kkkk | kkkk | | | | IORLW | k | Inclusive OR literal with W | 1 | 11 | 1000 | kkkk | kkkk | Z | | | MOVLW | k | Move literal to W | 1 | 11 | 00xx | kkkk | kkkk | | | | RETFIE | - | Return from interrupt | 2 | 00 | 0000 | 0000 | 1001 | | | | RETLW | k | Return with literal in W | 2 | 11 | 01xx | kkkk | kkkk | | | | RETURN | - | Return from Subroutine | 2 | 00 | 0000 | 0000 | 1000 | | | | SLEEP | - | Go into Standby mode | 1 | 0.0 | 0000 | 0110 | 0011 | TO,PD | | | SUBLW | k | Subtract W from literal | 1 | 11 | 110x | kkkk | kkkk | C,DC,Z | | | XORLW | k | Exclusive OR literal with W | 1 | 11 | 1010 | kkkk | kkkk | Z | | Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'. **Note:** Additional information on the mid-range instruction set is available in the PIC<sup>®</sup> Mid-Range MCU Family Reference Manual (DS33023). <sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module. <sup>3:</sup> If Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP. ## 13.3 MPLAB C17 and MPLAB C18 C Compilers The MPLAB C17 and MPLAB C18 Code Development Systems are complete ANSI C compilers for Microchip's PIC17CXXX and PIC18CXXX family of microcontrollers. These compilers provide powerful integration capabilities, superior code optimization and ease of use not found with other compilers. For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger. #### 13.4 MPLINK Object Linker/ MPLIB Object Librarian The MPLINK object linker combines relocatable objects created by the MPASM assembler and the MPLAB C17 and MPLAB C18 C compilers. It can link relocatable objects from pre-compiled libraries, using directives from a linker script. The MPLIB object librarian manages the creation and modification of library files of pre-compiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications. The object linker/library features include: - Efficient linking of single libraries instead of many smaller files - Enhanced code maintainability by grouping related modules together - Flexible creation of libraries with easy module listing, replacement, deletion and extraction #### 13.5 MPLAB C30 C Compiler The MPLAB C30 C compiler is a full-featured, ANSI compliant, optimizing compiler that translates standard ANSI C programs into dsPIC30F assembly language source. The compiler also supports many command-line options and language extensions to take full advantage of the dsPIC30F device hardware capabilities, and afford fine control of the compiler code generator. MPLAB C30 is distributed with a complete ANSI C standard library. All library functions have been validated and conform to the ANSI C library standard. The library includes functions for string manipulation, dynamic memory allocation, data conversion, time-keeping, and math functions (trigonometric, exponential and hyperbolic). The compiler provides symbolic information for high level source debugging with the MPLAB IDE. ### 13.6 MPLAB ASM30 Assembler, Linker, and Librarian MPLAB ASM30 assembler produces relocatable machine code from symbolic assembly language for dsPIC30F devices. MPLAB C30 compiler uses the assembler to produce it's object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include: - · Support for the entire dsPIC30F instruction set - · Support for fixed-point and floating-point data - · Command line interface - Rich directive set - · Flexible macro language - · MPLAB IDE compatibility #### 13.7 MPLAB SIM Software Simulator The MPLAB SIM software simulator allows code development in a PC hosted environment by simulating the PIC series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file, or user defined key press, to any pin. The execution can be performed in Single-Step, Execute Until Break, or Trace mode. The MPLAB SIM simulator fully supports symbolic debugging using the MPLAB C17 and MPLAB C18 C Compilers, as well as the MPASM assembler. The software simulator offers the flexibility to develop and debug code outside of the laboratory environment, making it an excellent, economical software development tool. #### 13.8 MPLAB SIM30 Software Simulator The MPLAB SIM30 software simulator allows code development in a PC hosted environment by simulating the dsPIC30F series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file, or user defined key press, to any of the pins. The MPLAB SIM30 simulator fully supports symbolic debugging using the MPLAB C30 C Compiler and MPLAB ASM30 assembler. The simulator runs in either a Command Line mode for automated tasks, or from MPLAB IDE. This high speed simulator is designed to debug, analyze and optimize time intensive DSP routines. #### 14.3 DC Characteristics: PIC16F870/871 (Extended) | DC CHA | ARACTI | ERISTICS | Standard Operating Conditions (unless otherwise stated) Operating temperature -40°C $\leq$ TA $\leq$ +125°C Operating voltage VDD range as described in DC specification (Section ) | | | | | | |--------------|--------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|-------|------------------------------------------------------------------------------------------|--| | Param<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | | | | VIL | Input Low Voltage | | | | | | | | | | I/O ports: | | | | | | | | D030 | | with TTL buffer | Vss | _ | 0.15 VDD | V | For entire VDD range | | | D030A | | | Vss | _ | 0.8V | V | $4.5V \le VDD \le 5.5V$ | | | D031 | | with Schmitt Trigger buffer | Vss | _ | 0.2 VDD | V | | | | D032 | | MCLR, OSC1 (in RC mode) | Vss | _ | 0.2 VDD | V | | | | D033 | | OSC1 (in XT, HS and LP) | Vss | _ | 0.3 VDD | V | (Note 1) | | | | | Ports RC3 and RC4: | | | | | | | | D034 | | with Schmitt Trigger buffer | Vss | _ | 0.3 VDD | V | For entire VDD range | | | D034A | | with SMBus | -0.5 — 0.6 V | | | V | For VDD = 4.5 to 5.5V | | | | VIH | Input High Voltage | | | | | | | | | | I/O ports: | | _ | | | | | | D040 | | with TTL buffer | 2.0 | _ | VDD | V | $4.5V \le VDD \le 5.5V$ | | | D040A | | | 0.25 VDD<br>+ 0.8V | _ | VDD | V | For entire VDD range | | | D041 | | with Schmitt Trigger buffer | 0.8 VDD | _ | Vdd | V | For entire VDD range | | | D042 | | MCLR | 0.8 VDD | _ | VDD | V | | | | D042A | | OSC1 (XT, HS and LP) | 0.7 VDD | _ | VDD | V | (Note 1) | | | D043 | | OSC1 (in RC mode) | 0.9 VDD | _ | VDD | V | | | | | | Ports RC3 and RC4: | | | | | | | | D044 | | with Schmitt Trigger buffer | 0.7 VDD | _ | VDD | V | For entire VDD range | | | D044A | | with SMBus | 1.4 | _ | 5.5 | V | For VDD = 4.5 to 5.5V | | | D070A | IPURB | PORTB Weak Pull-up Current | 50 | 250 | 400 | μΑ | VDD = 5V, VPIN = VSS | | | | lı∟ | Input Leakage Current <sup>(2,3)</sup> | | | | | | | | D060 | | I/O ports | _ | _ | ±1 | μΑ | Vss ≤ VPIN ≤ VDD,<br>Pin at hi-impedance | | | D061 | | MCLR, RA4/T0CKI | _ | _ | ±5 | μΑ | $Vss \le VPIN \le VDD$ | | | D063 | | OSC1 | _ | _ | ±5 | μА | $\label{eq:VSS} \mbox{VSIN} \leq \mbox{VDD, XT, HS} \\ \mbox{and LP osc configuration}$ | | <sup>\*</sup> These parameters are characterized but not tested. - 2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as current sourced by the pin. <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. **Note 1:** In RC oscillator configuration, the OSC1/CLKI pin is a Schmitt Trigger input. It is not recommended that the PIC16F87X be driven with external clock in RC mode. TABLE 14-1: EXTERNAL CLOCK TIMING REQUIREMENTS | Param<br>No. | Sym | Characteristic | Min | Тур† | Max | Units | Conditions | |--------------|-------|---------------------------------|--------|------|-----------|------------|----------------------------| | | Fosc | External CLKI Frequency | DC | _ | 4 | MHz | XT and RC Osc mode | | | | (Note 1) | DC | _ | 4 | MHz | HS Osc mode (-04) | | | | | | _ | 20 | MHz | HS Osc mode (-20) | | | | | DC | _ | 200 | kHz | LP Osc mode | | | | Oscillator Frequency | DC | _ | 4 | MHz | RC Osc mode | | | | (Note 1) | 0.1 | _ | 4 | MHz | XT Osc mode | | | | | 4<br>5 | _ | 20<br>200 | MHz<br>kHz | HS Osc mode<br>LP Osc mode | | 1 | Tosc | External CLKI Period | 250 | _ | _ | ns | XT and RC Osc mode | | | | (Note 1) | 250 | _ | _ | ns | HS Osc mode (-04) | | | | | 50 | | | ns | HS Osc mode (-20) | | | | | 5 | | | μS | LP Osc mode | | | | Oscillator Period | 250 | _ | _ | ns | RC Osc mode | | | | (Note 1) | 250 | _ | 10,000 | ns | XT Osc mode | | | | | 250 | _ | 250 | ns | HS Osc mode (-04) | | | | | 50 | _ | 250 | ns | HS Osc mode (-20) | | | | | 5 | _ | _ | μS | LP Osc mode | | 2 | TCY | Instruction Cycle Time (Note 1) | 200 | Tcy | DC | ns | Tcy = 4/Fosc | | 3 | TosL, | External Clock in (OSC1) High | 100 | _ | _ | ns | XT oscillator | | | TosH | or Low Time | 2.5 | _ | _ | μS | LP oscillator | | | | | 15 | _ | _ | ns | HS oscillator | | 4 | TosR, | External Clock in (OSC1) Rise | _ | _ | 25 | ns | XT oscillator | | | TosF | or Fall Time | _ | _ | 50 | ns | LP oscillator | | | | | _ | _ | 15 | ns | HS oscillator | <sup>†</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Note 1: Instruction cycle period (TcY) equals four times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1/CLKI pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices. #### 44-Lead Plastic Leaded Chip Carrier (L) - Square (PLCC) For the most current package drawings, please see the Microchip Packaging Specification located Note: at http://www.microchip.com/packaging | | Units | | INCHES* | | MILLIMETERS | | | |--------------------------|--------|------|---------|------|-------------|-------|-------| | Dimension | Limits | MIN | MOM | MAX | MIN | NOM | MAX | | Number of Pins | n | | 44 | | | 44 | | | Pitch | р | | .050 | | | 1.27 | | | Pins per Side | n1 | | 11 | | | 11 | | | Overall Height | Α | .165 | .173 | .180 | 4.19 | 4.39 | 4.57 | | Molded Package Thickness | A2 | .145 | .153 | .160 | 3.68 | 3.87 | 4.06 | | Standoff § | A1 | .020 | .028 | .035 | 0.51 | 0.71 | 0.89 | | Side 1 Chamfer Height | A3 | .024 | .029 | .034 | 0.61 | 0.74 | 0.86 | | Corner Chamfer 1 | CH1 | .040 | .045 | .050 | 1.02 | 1.14 | 1.27 | | Corner Chamfer (others) | CH2 | .000 | .005 | .010 | 0.00 | 0.13 | 0.25 | | Overall Width | Е | .685 | .690 | .695 | 17.40 | 17.53 | 17.65 | | Overall Length | D | .685 | .690 | .695 | 17.40 | 17.53 | 17.65 | | Molded Package Width | E1 | .650 | .653 | .656 | 16.51 | 16.59 | 16.66 | | Molded Package Length | D1 | .650 | .653 | .656 | 16.51 | 16.59 | 16.66 | | Footprint Width | E2 | .590 | .620 | .630 | 14.99 | 15.75 | 16.00 | | Footprint Length | D2 | .590 | .620 | .630 | 14.99 | 15.75 | 16.00 | | Lead Thickness | С | .008 | .011 | .013 | 0.20 | 0.27 | 0.33 | | Upper Lead Width | B1 | .026 | .029 | .032 | 0.66 | 0.74 | 0.81 | | Lower Lead Width | В | .013 | .020 | .021 | 0.33 | 0.51 | 0.53 | | Mold Draft Angle Top | α | 0 | 5 | 10 | 0 | 5 | 10 | | Mold Draft Angle Bottom | β | 0 | 5 | 10 | 0 | 5 | 10 | <sup>\*</sup> Controlling Parameter Notes: Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MO-047 Drawing No. C04-048 <sup>§</sup> Significant Characteristic ### PIC16F870/871 ## APPENDIX C: CONVERSION CONSIDERATIONS This appendix discusses the considerations for converting from previous versions of a device to the ones listed in this data sheet. Typically, these changes are due to the differences in the process technology used. An example of this type of conversion is from a PIC17C756 to a PIC18F8720. **Not Applicable** # APPENDIX D: MIGRATION FROM MID-RANGE TO ENHANCED DEVICES A detailed discussion of the differences between the mid-range MCU devices (i.e., PIC16CXXX) and the enhanced devices (i.e., PIC18FXXX) is provided in AN716, "Migrating Designs from PIC16C74A/74B to PIC18C442." The changes discussed, while device specific, are generally applicable to all mid-range to enhanced device migrations. This Application Note is available as Literature Number DS00716. ## PIC16F870/871 | STATUS Register | 13, 15 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PD Bit | | | <del></del> | | | TO Bit | 91 | | Synchronous Master Reception | | | Associated Registers | 75 | | Synchronous Master Transmission | | | Associated Registers | 73 | | <u> </u> | 73 | | Synchronous Slave Reception | | | Associated Registers | 77 | | Synchronous Slave Transmission | | | Associated Registers | 76 | | Associated Registers | 7 0 | | Т | | | • | | | T1CKPS0 Bit | 49 | | T1CKPS1 Bit | 49 | | T1CON Register | | | | | | T10SCEN Bit | | | T1SYNC Bit | 49 | | T2CKPS0 Bit | 53 | | T2CKPS1 Bit | 53 | | T2CON Register | | | | | | TAD | | | Time-out Sequence | 92 | | Timer0 | 45 | | Associated Registers | 47 | | Clock Source Edge Select (T0SE Bit) | | | | | | Clock Source Select (T0CS Bit) | | | External Clock | 46 | | Interrupt | 45 | | Overflow Enable (T0IE Bit) | 18 | | Overflow Flag (T0IF Bit) | | | | | | Overflow Interrupt | | | | | | Prescaler | 46 | | Prescaler<br>T0CKI | | | T0CKI | 46 | | T0CKI | 46<br>49 | | T0CKI Timer1 Associated Registers | 46<br>49 | | Timer1 | 46<br>49<br>52 | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to | 46<br>49<br>52 | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation | 46<br>49<br>52<br>51 | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation | 46<br>49<br>52<br>51 | | TOCKI | 46<br>49<br>52<br>51<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>51<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>51<br>50<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>51<br>50<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>51<br>50<br>50 | | TOCKI | 46<br>52<br>51<br>50<br>50<br>50<br>50<br>51 | | TOCKI | 46<br>52<br>51<br>50<br>50<br>50<br>50<br>51 | | TOCKI | 4652515051505150515051515151 | | TOCKI | 46525150505150515152 | | TOCKI | 46525150505150515152 | | TOCKI | | | TOCKI | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H. TMR1L | | | TOCKI | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers Output | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers Output Postscaler | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers Output Postscaler Prescaler | | | TOCKI Timer1 Associated Registers Asynchronous Counter Mode Reading and Writing to Counter Operation Incrementing Edge (figure) Operation in Asynchronous Counter Mode Operation in Synchronized Counter Mode Operation in Timer Mode Oscillator Capacitor Selection Prescaler Resetting of Timer1 Register Pair (TMR1H, TMR1L) Resetting Timer1 Using a CCP Trigger Output TMR1H TMR1L Timer2 Associated Registers Output Postscaler Prescaler Prescaler and Postscaler | | | Timer1 | | | Timer1 | | | Timer1 | | | Timer1 | | | Timer1 | 4649515051505151515151525151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151 | | Timer1 | 4649515051505151515151525151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151 | | Timer1 | 4651505150515151515151515153545354535453 | | Asynchronous Reception with | | |------------------------------------------|-----| | Address Detect | | | Brown-out Reset | | | Capture/Compare/PWM (CCP1) | | | CLKO and I/O | | | External Clock | | | Parallel Slave Port (PSP) Read | | | Parallel Slave Port (PSP) Write | 43 | | RESET, Watchdog Timer, Oscillator | | | Start-up Timer and Power-up Timer | | | Slow Rise Time (MCLR Tied to VDD) | 96 | | Time-out Sequence on Power-up | | | (MCLR Not Tied to VDD) | | | Case 1 | | | Case 2 | 95 | | Time-out Sequence on Power-up | | | (MCLR Tied to VDD) | 95 | | Timer0 and Timer1 External Clock | | | USART Asynchronous Reception | | | USART Synchronous Receive (Master/Slave) | 133 | | USART Synchronous Reception | | | (Master Mode, SREN) | | | USART Synchronous Transmission | 73 | | USART Synchronous Transmission | | | (Master/Slave) | | | Wake-up from SLEEP via Interrupt | | | Γiming Parameter Symbology | | | ΓMR0 Register | | | TMR1CS Bit | | | ГМR1H Register | | | TMR1L Register | | | TMR1ON Bit | | | ΓMR2 Register | | | TMR2ON Bit | | | TOUTPS0 Bit | | | FOUTPS1 Bit | | | TOUTPS2 Bit | | | TOUTPS3 Bit | | | TRISA | | | TRISA Register | | | TRISB | | | TRISB Register | | | TRISC | | | TRISC Register | | | FRISDFIRISD Register | 15 | | | | | TRISE TRISE Register | | | IRISE RegisterIBF Bit | | | IBOV Bit | | | OBF Bit | | | PSPMODE Bit | | | TXREG Register | | | TXXEG Register | | | TXSTA Register | | | BRGH Bit | | | CSRC Bit | _ | | TRMT Bit | | | TX9 Bit | | | TX9D Bit | _ | | TXEN Bit | | | I ALIN DIL | 01 | | | |