



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              | 33                                                                        |
| Program Memory Size        | 7KB (4K x 14)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 128 x 8                                                                   |
| RAM Size                   | 192 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                 |
| Data Converters            | A/D 8x10b                                                                 |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 44-VQFN Exposed Pad                                                       |
| Supplier Device Package    | 44-QFN (8x8)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f874a-i-ml |

Email: info@E-XFL.COM

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

| Pin Name                                                | PDIP, SOIC,<br>SSOP Pin# | QFN<br>Pin# | I/O/P<br>Type      | Buffer<br>Type         | Description                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------|--------------------------|-------------|--------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKI<br>OSC1<br>CLKI                               | 9                        | 6           | I                  | ST/CMOS <sup>(3)</sup> | Oscillator crystal or external clock input.<br>Oscillator crystal input or external clock source input. ST<br>buffer when configured in RC mode; otherwise CMOS.<br>External clock source input. Always associated with pin<br>function OSC1 (see OSC1/CLKI, OSC2/CLKO pins). |
| OSC2/CLKO<br>OSC2<br>CLKO                               | 10                       | 7           | 0                  | _                      | Oscillator crystal or clock output.<br>Oscillator crystal output. Connects to crystal or resonator<br>in Crystal Oscillator mode.<br>In RC mode, OSC2 pin outputs CLKO, which has 1/4 the<br>frequency of OSC1 and denotes the instruction cycle rate.                        |
| MCLR/VPP<br>MCLR<br>VPP                                 | 1                        | 26          | I<br>P             | ST                     | Master Clear (input) or programming voltage (output).<br>Master Clear (Reset) input. This pin is an active low Reset<br>to the device.<br>Programming voltage input.                                                                                                          |
|                                                         |                          |             |                    |                        | PORTA is a bidirectional I/O port.                                                                                                                                                                                                                                            |
| RA0/AN0<br>RA0<br>AN0                                   | 2                        | 27          | I/O<br>I           | TTL                    | Digital I/O.<br>Analog input 0.                                                                                                                                                                                                                                               |
| RA1/AN1<br>RA1<br>AN1                                   | 3                        | 28          | I/O<br>I           | TTL                    | Digital I/O.<br>Analog input 1.                                                                                                                                                                                                                                               |
| RA2/AN2/VREF-/<br>CVREF<br>RA2<br>AN2<br>VREF-<br>CVREF | 4                        | 1           | I/O<br>I<br>I<br>O | TTL                    | Digital I/O.<br>Analog input 2.<br>A/D reference voltage (Low) input.<br>Comparator VREF output.                                                                                                                                                                              |
| RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+                    | 5                        | 2           | I/O<br>I<br>I      | TTL                    | Digital I/O.<br>Analog input 3.<br>A/D reference voltage (High) input.                                                                                                                                                                                                        |
| RA4/T0CKI/C1OUT<br>RA4<br>T0CKI<br>C1OUT                | 6                        | 3           | I/O<br>I<br>O      | ST                     | Digital I/O – Open-drain when configured as output.<br>Timer0 external clock input.<br>Comparator 1 output.                                                                                                                                                                   |
| RA5/AN4/SS/C2OUT<br>RA5<br>AN4<br>SS<br>C2OUT           | 7                        | 4           | I/O<br>I<br>I<br>O | TTL                    | Digital I/O.<br>Analog input 4.<br>SPI slave select input.<br>Comparator 2 output.                                                                                                                                                                                            |
| <b>Legena.</b> I = input                                | 0 = 00                   | ւթու        | 1/C                | v = mput/outpu         |                                                                                                                                                                                                                                                                               |

#### TABLE 1-2:PIC16F873A/876A PINOUT DESCRIPTION

— = Not used TTL = TTL input ST = Schmitt Trigger input

**Note 1:** This buffer is a Schmitt Trigger input when configured as the external interrupt.

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.

### 3.6 Writing to Flash Program Memory

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

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

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

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

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

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

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



| Name                   | Bit#  | Buffer                | Function                                                                                                                                          |
|------------------------|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT                | bit 0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software programmable weak pull-up.                                                        |
| RB1                    | bit 1 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB2                    | bit 2 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                                                    |
| RB3/PGM <sup>(3)</sup> | bit 3 | TTL                   | Input/output pin or programming pin in LVP mode. Internal software programmable weak pull-up.                                                     |
| RB4                    | bit 4 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB5                    | bit 5 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                         |
| RB6/PGC                | bit 6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or in-circuit debugger pin.<br>Internal software programmable weak pull-up. Serial programming clock. |
| RB7/PGD                | bit 7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change) or in-circuit debugger pin.<br>Internal software programmable weak pull-up. Serial programming data.  |

#### TABLE 4-3:PORTB FUNCTIONS

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

**Note 1:** This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode or in-circuit debugger.

**3:** Low-Voltage ICSP Programming (LVP) is enabled by default which disables the RB3 I/O function. LVP must be disabled to enable RB3 as an I/O pin and allow maximum compatibility to the other 28-pin and 40-pin mid-range devices.

| TABLE 4-4: | SUMMARY OF REGISTERS ASSOCIATED WITH PORTB |
|------------|--------------------------------------------|
|------------|--------------------------------------------|

| Address   | Name       | Bit 7 | Bit 6                         | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value<br>POR, | e on:<br>BOR | Valu<br>all o<br>Res | e on<br>ther<br>sets |
|-----------|------------|-------|-------------------------------|-------|-------|-------|-------|-------|-------|---------------|--------------|----------------------|----------------------|
| 06h, 106h | PORTB      | RB7   | RB6                           | RB5   | RB4   | RB3   | RB2   | RB1   | RB0   | xxxx          | xxxx         | uuuu                 | uuuu                 |
| 86h, 186h | TRISB      | PORTB | PORTB Data Direction Register |       |       |       |       |       | 1111  | 1111          | 1111         | 1111                 |                      |
| 81h, 181h | OPTION_REG | RBPU  | INTEDG                        | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111          | 1111         | 1111                 | 1111                 |

**Legend:** x = unknown, u = unchanged. Shaded cells are not used by PORTB.

### 4.3 PORTC and the TRISC Register

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

PORTC is multiplexed with several peripheral functions (Table 4-5). PORTC pins have Schmitt Trigger input buffers.

When the  $I^2C$  module is enabled, the PORTC<4:3> pins can be configured with normal  $I^2C$  levels, or with SMBus levels, by using the CKE bit (SSPSTAT<6>).

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. Since the TRIS bit override is in effect while the peripheral is enabled, read-modify-write instructions (BSF, BCF, XORWF) with TRISC as the destination, should be avoided. The user should refer to the corresponding peripheral section for the correct TRIS bit settings.

#### FIGURE 4-6: PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<2:0>, RC<7:5>



- Port/Peripheral Select signal selects between port
  - data and peripheral output.
  - **3:** Peripheral OE (Output Enable) is only activated if Peripheral Select is active.

#### FIGURE 4-7: PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT



#### 4.4 PORTD and TRISD Registers

| Note: | PORTD and TRISD are not implemented |
|-------|-------------------------------------|
|       | on the 28-pin devices.              |

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

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

#### FIGURE 4-8: PORTD BLOCK DIAGRAM (IN I/O PORT MODE)



| Name     | Bit#  | Buffer Type           | Function                                            |
|----------|-------|-----------------------|-----------------------------------------------------|
| RD0/PSP0 | bit 0 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 0. |
| RD1/PSP1 | bit 1 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 1. |
| RD2/PSP2 | bit2  | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 2. |
| RD3/PSP3 | bit 3 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 3. |
| RD4/PSP4 | bit 4 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 4. |
| RD5/PSP5 | bit 5 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 5. |
| RD6/PSP6 | bit 6 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 6. |
| RD7/PSP7 | bit 7 | ST/TTL <sup>(1)</sup> | Input/output port pin or Parallel Slave Port bit 7. |

#### TABLE 4-7:PORTD FUNCTIONS

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

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

| TABLE 4-0. JUNIMANT OF REGISTERS ASSOCIATED WITH FORT | TABLE 4-8: | SUMMARY OF REGISTERS ASSOCIATED WITH PORTD |
|-------------------------------------------------------|------------|--------------------------------------------|
|-------------------------------------------------------|------------|--------------------------------------------|

| Address | Name  | Bit 7 | Bit 6                         | Bit 5 | Bit 4   | Bit 3 | Bit 2   | Bit 1     | Bit 0      | Value<br>POR, | e on:<br>BOR | Valu<br>all o<br>Res | e on<br>ther<br>sets |
|---------|-------|-------|-------------------------------|-------|---------|-------|---------|-----------|------------|---------------|--------------|----------------------|----------------------|
| 08h     | PORTD | RD7   | RD6                           | RD5   | RD4     | RD3   | RD2     | RD1       | RD0        | xxxx          | xxxx         | uuuu                 | uuuu                 |
| 88h     | TRISD | PORT  | PORTD Data Direction Register |       |         |       |         |           | 1111       | 1111          | 1111         | 1111                 |                      |
| 89h     | TRISE | IBF   | OBF                           | IBOV  | PSPMODE |       | PORTE I | Data Dire | ction Bits | 0000          | -111         | 0000                 | -111                 |

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

#### 8.3.3 SETUP FOR PWM OPERATION

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

- 1. Set the PWM period by writing to the PR2 register.
- 2. Set the PWM duty cycle by writing to the CCPR1L register and CCP1CON<5:4> bits.
- 3. Make the CCP1 pin an output by clearing the TRISC<2> bit.
- 4. Set the TMR2 prescale value and enable Timer2 by writing to T2CON.
- 5. Configure the CCP1 module for PWM operation.

| TABLE 8-3: | <b>EXAMPLE PWM FREQUENCIES AND RESOLUTIONS AT 20 MHz</b> |
|------------|----------------------------------------------------------|
|            |                                                          |

| PWM Frequency              | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12kHz | 156.3 kHz | 208.3 kHz |
|----------------------------|----------|----------|-----------|----------|-----------|-----------|
| Timer Prescaler (1, 4, 16) | 16       | 4        | 1         | 1        | 1         | 1         |
| PR2 Value                  | 0xFFh    | 0xFFh    | 0xFFh     | 0x3Fh    | 0x1Fh     | 0x17h     |
| Maximum Resolution (bits)  | 10       | 10       | 10        | 8        | 7         | 5.5       |

| TABLE 8-4: | REGISTERS ASSOCIATED WITH CAPTURE, COMPARE AND TIMER1 |
|------------|-------------------------------------------------------|
|------------|-------------------------------------------------------|

| Address                | Name    | Bit 7                | Bit 6      | Bit 5        | Bit 4         | Bit 3         | Bit 2      | Bit 1      | Bit 0  | Value<br>POR, | e on:<br>BOR | Valu<br>all o<br>Res | e on<br>other<br>sets |
|------------------------|---------|----------------------|------------|--------------|---------------|---------------|------------|------------|--------|---------------|--------------|----------------------|-----------------------|
| 0Bh,8Bh,<br>10Bh, 18Bh | INTCON  | GIE                  | PEIE       | TMR0IE       | INTE          | RBIE          | TMR0IF     | INTF       | RBIF   | 0000          | 000x         | 0000                 | 000u                  |
| 0Ch                    | PIR1    | PSPIF <sup>(1)</sup> | ADIF       | RCIF         | TXIF          | SSPIF         | CCP1IF     | TMR2IF     | TMR1IF | 0000          | 0000         | 0000                 | 0000                  |
| 0Dh                    | PIR2    | _                    | _          | —            | —             |               | _          |            | CCP2IF |               | 0            |                      | 0                     |
| 8Ch                    | PIE1    | PSPIE <sup>(1)</sup> | ADIE       | RCIE         | TXIE          | SSPIE         | CCP1IE     | TMR2IE     | TMR1IE | 0000          | 0000         | 0000                 | 0000                  |
| 8Dh                    | PIE2    |                      | _          | —            | —             | -             | —          | _          | CCP2IE |               | 0            |                      | 0                     |
| 87h                    | TRISC   | PORTC D              | ata Direc  | tion Registe | er            |               |            |            |        | 1111          | 1111         | 1111                 | 1111                  |
| 0Eh                    | TMR1L   | Holding R            | egister fo | r the Least  | Significant I | Byte of the 1 | 6-bit TMR  | 1 Register |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 0Fh                    | TMR1H   | Holding R            | egister fo | r the Most S | Significant E | Byte of the 1 | 6-bit TMR1 | Register   |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 10h                    | T1CON   | _                    | —          | T1CKPS1      | T1CKPS0       | T1OSCEN       | T1SYNC     | TMR1CS     | TMR10N | 00            | 0000         | uu                   | uuuu                  |
| 15h                    | CCPR1L  | Capture/C            | Compare/F  | PWM Regis    | ter 1 (LSB)   |               |            |            |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 16h                    | CCPR1H  | Capture/C            | Compare/F  | PWM Regis    | ter 1 (MSB)   |               |            |            |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 17h                    | CCP1CON | _                    |            | CCP1X        | CCP1Y         | CCP1M3        | CCP1M2     | CCP1M1     | CCP1M0 | 00            | 0000         | 00                   | 0000                  |
| 1Bh                    | CCPR2L  | Capture/C            | Compare/F  | PWM Regis    | ter 2 (LSB)   |               |            |            |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 1Ch                    | CCPR2H  | Capture/C            | Compare/F  | PWM Regis    | ter 2 (MSB)   |               |            |            |        | xxxx          | xxxx         | uuuu                 | uuuu                  |
| 1Dh                    | CCP2CON |                      | —          | CCP2X        | CCP2Y         | CCP2M3        | CCP2M2     | CCP2M1     | CCP2M0 | 00            | 0000         | 00                   | 0000                  |

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

Note 1: The PSP is not implemented on 28-pin devices; always maintain these bits clear.





I<sup>2</sup>C SLAVE MODE TIMING (TRANSMISSION, 7-BIT ADDRESS)



#### 9.4.7 BAUD RATE GENERATOR

In I<sup>2</sup>C Master mode, the Baud Rate Generator (BRG) reload value is placed in the lower 7 bits of the SSPADD register (Figure 9-17). When a write occurs to SSPBUF, the Baud Rate Generator will automatically begin counting. The BRG counts down to 0 and stops until another reload has taken place. The BRG count is decremented twice per instruction cycle (Tcr) on the Q2 and Q4 clocks. In I<sup>2</sup>C Master mode, the BRG is reloaded automatically.

Once the given operation is complete (i.e., transmission of the last data bit is followed by ACK), the internal clock will automatically stop counting and the SCL pin will remain in its last state.

Table 9-3 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPADD.

#### FIGURE 9-17: BAUD RATE GENERATOR BLOCK DIAGRAM



### TABLE 9-3: I<sup>2</sup>C CLOCK RATE W/BRG

| Fcy    | FcY*2  | BRG Value | FscL<br>(2 Rollovers of BRG) |
|--------|--------|-----------|------------------------------|
| 10 MHz | 20 MHz | 19h       | 400 kHz <sup>(1)</sup>       |
| 10 MHz | 20 MHz | 20h       | 312.5 kHz                    |
| 10 MHz | 20 MHz | 3Fh       | 100 kHz                      |
| 4 MHz  | 8 MHz  | 0Ah       | 400 kHz <sup>(1)</sup>       |
| 4 MHz  | 8 MHz  | 0Dh       | 308 kHz                      |
| 4 MHz  | 8 MHz  | 28h       | 100 kHz                      |
| 1 MHz  | 2 MHz  | 03h       | 333 kHz <sup>(1)</sup>       |
| 1 MHz  | 2 MHz  | 0Ah       | 100 kHz                      |
| 1 MHz  | 2 MHz  | 00h       | 1 MHz <sup>(1)</sup>         |

**Note 1:** The I<sup>2</sup>C interface does not conform to the 400 kHz I<sup>2</sup>C specification (which applies to rates greater than 100 kHz) in all details, but may be used with care where higher rates are required by the application.

# 16.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers are supported with a full range of hardware and software development tools:

- Integrated Development Environment
  - MPLAB<sup>®</sup> IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C17 and MPLAB C18 C Compilers
  - MPLINK<sup>™</sup> Object Linker/
  - MPLIB<sup>™</sup> Object Librarian
  - MPLAB C30 C Compiler
  - MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
- MPLAB dsPIC30 Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB ICE 4000 In-Circuit Emulator
- In-Circuit Debugger
- MPLAB ICD 2
- Device Programmers
  - PRO MATE<sup>®</sup> II Universal Device Programmer
  - PICSTART<sup>®</sup> Plus Development Programmer
- Low Cost Demonstration Boards
  - PICDEM<sup>™</sup> 1 Demonstration Board
  - PICDEM.net<sup>™</sup> Demonstration Board
  - PICDEM 2 Plus Demonstration Board
  - PICDEM 3 Demonstration Board
  - PICDEM 4 Demonstration Board
  - PICDEM 17 Demonstration Board
  - PICDEM 18R Demonstration Board
  - PICDEM LIN Demonstration Board
  - PICDEM USB Demonstration Board
- Evaluation Kits
  - KEELOQ<sup>®</sup>
  - PICDEM MSC
  - microID®
  - CAN
  - PowerSmart<sup>®</sup>
  - Analog

#### 16.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller market. The MPLAB IDE is a Windows<sup>®</sup> based application that contains:

- · An interface to debugging tools
  - simulator
  - programmer (sold separately)
  - emulator (sold separately)
  - in-circuit debugger (sold separately)
- · A full-featured editor with color coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- High level source code debugging
- Mouse over variable inspection
- Extensive on-line help
- The MPLAB IDE allows you to:
- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PIC MCU emulator and simulator tools (automatically updates all project information)
- Debug using:
  - source files (assembly or C)
  - absolute listing file (mixed assembly and C)
  - machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost effective simulators, through low cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increasing flexibility and power.

#### 16.2 MPASM Assembler

The MPASM assembler is a full-featured, universal macro assembler for all PIC MCUs.

The MPASM assembler generates relocatable object files for the MPLINK object linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging.

The MPASM assembler features include:

- Integration into MPLAB IDE projects
- · User defined macros to streamline assembly code
- Conditional assembly for multi-purpose source files
- Directives that allow complete control over the assembly process

NOTES:

# **17.0 ELECTRICAL CHARACTERISTICS**

## Absolute Maximum Ratings †

| Ambient temperature under bias                                                                              | 55 to +125°C                       |
|-------------------------------------------------------------------------------------------------------------|------------------------------------|
| Storage temperature                                                                                         | 65°C to +150°C                     |
| Voltage on any pin with respect to Vss (except VDD, MCLR. and RA4)                                          | 0.3V to (VDD + 0.3V)               |
| Voltage on VDD with respect to VSS                                                                          | 0.3 to +7.5V                       |
| Voltage on MCLR with respect to Vss (Note 2)                                                                | 0 to +14V                          |
| Voltage on RA4 with respect to Vss                                                                          | 0 to +8.5V                         |
| Total power dissipation (Note 1)                                                                            | 1.0W                               |
| Maximum current out of Vss pin                                                                              | 300 mA                             |
| Maximum current into VDD pin                                                                                | 250 mA                             |
| Input clamp current, IIK (VI < 0 or VI > VDD)                                                               | ± 20 mA                            |
| Output clamp current, Iok (Vo < 0 or Vo > VDD)                                                              | ± 20 mA                            |
| Maximum output current sunk by any I/O pin                                                                  | 25 mA                              |
| Maximum output current sourced by any I/O pin                                                               | 25 mA                              |
| Maximum current sunk by PORTA, PORTB and PORTE (combined) (Note 3)                                          | 200 mA                             |
| Maximum current sourced by PORTA, PORTB and PORTE (combined) (Note 3)                                       | 200 mA                             |
| Maximum current sunk by PORTC and PORTD (combined) (Note 3)                                                 | 200 mA                             |
| Maximum current sourced by PORTC and PORTD (combined) (Note 3)                                              | 200 mA                             |
| <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VDD - | VOH) x IOH} + $\Sigma$ (VOI x IOL) |
| <b>2:</b> Voltage spikes below Vss at the $\overline{MCLR}$ pin, inducing currents greater than 80          | mA, may cause latch-up.            |

- 2: Voltage spikes below VSS at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the MCLR pin rather than pulling this pin directly to VSS.
- 3: PORTD and PORTE are not implemented on PIC16F873A/876A devices.

† NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

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

| PIC16LF873A/874A/876A/877A<br>(Industrial)          |        |                                                                                                                                                                                         | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |      |      |       |                                                        |  |  |
|-----------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|--------------------------------------------------------|--|--|
| PIC16F873A/874A/876A/877A<br>(Industrial, Extended) |        | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |                                                                                                                                    |      |      |       |                                                        |  |  |
| Param<br>No.                                        | Symbol | Characteristic/<br>Device                                                                                                                                                               | Min                                                                                                                                | Тур† | Max  | Units | Conditions                                             |  |  |
|                                                     | Vdd    | Supply Voltage                                                                                                                                                                          |                                                                                                                                    |      |      |       |                                                        |  |  |
| D001                                                |        | 16LF87XA                                                                                                                                                                                | 2.0                                                                                                                                | _    | 5.5  | V     | All configurations<br>(DC to 10 MHz)                   |  |  |
| D001                                                |        | 16F87XA                                                                                                                                                                                 | 4.0                                                                                                                                | _    | 5.5  | V     | All configurations                                     |  |  |
| D001A                                               |        |                                                                                                                                                                                         | VBOR                                                                                                                               |      | 5.5  | V     | BOR enabled, FMAX = 14 MHz <sup>(7)</sup>              |  |  |
| D002                                                | Vdr    | RAM Data Retention<br>Voltage <sup>(1)</sup>                                                                                                                                            | —                                                                                                                                  | 1.5  | _    | V     |                                                        |  |  |
| D003                                                | VPOR   | VDD Start Voltage to<br>ensure internal Power-on<br>Reset signal                                                                                                                        | —                                                                                                                                  | Vss  | _    | V     | See Section 14.5 "Power-on<br>Reset (POR)" for details |  |  |
| D004                                                | SVDD   | VDD Rise Rate to ensure<br>internal Power-on Reset<br>signal                                                                                                                            | 0.05                                                                                                                               | —    | —    | V/ms  | See Section 14.5 "Power-on<br>Reset (POR)" for details |  |  |
| D005                                                | VBOR   | Brown-out Reset<br>Voltage                                                                                                                                                              | 3.65                                                                                                                               | 4.0  | 4.35 | V     | BODEN bit in configuration word<br>enabled             |  |  |

Legend: Rows with standard voltage device data only are shaded for improved readability.

- † 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:** This is the limit to which VDD can be lowered without losing RAM data.
  - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors, such as I/O pin loading, switching rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption.
    - The test conditions for all IDD measurements in active operation mode are:
      - OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD;
      - MCLR = VDD; WDT enabled/disabled as specified.
  - **3:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impedance state and tied to VDD and Vss.
  - **4:** For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula Ir = VDD/2REXT (mA) with REXT in kΩ.
  - **5:** Timer1 oscillator (when enabled) adds approximately 20 μA to the specification. This value is from characterization and is for design guidance only. This is not tested.
  - 6: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.
  - 7: When BOR is enabled, the device will operate correctly until the VBOR voltage trip point is reached.



| TABLE 17-4: | <b>CLKO AND I/O TIMING REQUIREMENTS</b> |
|-------------|-----------------------------------------|
|             |                                         |

| Param<br>No. | Symbol   | Characteristic                              | Min           | Тур† | Max | Units        | Conditions |          |
|--------------|----------|---------------------------------------------|---------------|------|-----|--------------|------------|----------|
| 10*          | TosH2ckL | OSC1 ↑ to CLKO $↓$                          |               | _    | 75  | 200          | ns         | (Note 1) |
| 11*          | TosH2ckH | OSC1 ↑ to CLKO ↑                            |               | —    | 75  | 200          | ns         | (Note 1) |
| 12*          | TCKR     | CLKO Rise Time                              |               | —    | 35  | 100          | ns         | (Note 1) |
| 13*          | ТскF     | CLKO Fall Time                              |               | —    | 35  | 100          | ns         | (Note 1) |
| 14*          | TckL2IoV | CLKO $\downarrow$ to Port Out Valid         |               | —    | _   | 0.5 TCY + 20 | ns         | (Note 1) |
| 15*          | ТюV2скН  | Port In Valid before CLKO $\uparrow$        | Tosc + 200    |      | —   | ns           | (Note 1)   |          |
| 16*          | TCKH2IOI | Port In Hold after CLKO $\uparrow$          | 0             | _    | —   | ns           | (Note 1)   |          |
| 17*          | TosH2IoV | OSC1 ↑ (Q1 cycle) to Port Out Va            | —             | 100  | 255 | ns           |            |          |
| 18*          | TosH2iol | OSC1 $\uparrow$ (Q2 cycle) to Port Input    | Standard (F)  | 100  | _   | —            | ns         |          |
|              |          | Invalid (I/O in hold time)                  | Extended (LF) | 200  | —   | —            | ns         |          |
| 19*          | TIOV20sH | Port Input Valid to OSC1 $\uparrow$ (I/O in | setup time)   | 0    | _   | —            | ns         |          |
| 20*          | TIOR     | Port Output Rise Time                       | Standard (F)  | —    | 10  | 40           | ns         |          |
|              |          |                                             | Extended (LF) | —    | —   | 145          | ns         |          |
| 21*          | TIOF     | Port Output Fall Time                       | Standard (F)  | —    | 10  | 40           | ns         |          |
|              |          |                                             | Extended (LF) | —    | _   | 145          | ns         |          |
| 22††*        | TINP     | INT pin High or Low Time                    |               | Тсү  |     | _            | ns         |          |
| 23††*        | TRBP     | RB7:RB4 Change INT High or Lo               | w Time        | Тсү  | _   | _            | ns         |          |

These parameters are characterized but not tested.

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

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

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

\*







# TABLE 17-14: A/D CONVERTER CHARACTERISTICS:PIC16F873A/874A/876A/877A (INDUSTRIAL) PIC16LF873A/874A/876A/877A (INDUSTRIAL)

| Param<br>No. | Sym   | Characteristic                        |                   | Min         | Тур†                      | Мах         | Units | Conditions                                                                                                                                       |
|--------------|-------|---------------------------------------|-------------------|-------------|---------------------------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| A01          | NR    | Resolution                            |                   | _           | _                         | 10-bits     | bit   | $\begin{array}{l} {\sf VREF} = {\sf VDD} = 5.12{\sf V}, \\ {\sf VSS} \le {\sf VAIN} \le {\sf VREF} \end{array}$                                  |
| A03          | EIL   | Integral Linearity Er                 | ror               | -           | —                         | < ± 1       | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                                                     |
| A04          | Edl   | Differential Linearity Error          |                   | _           | —                         | < ± 1       | LSb   | $\begin{array}{l} VREF=VDD=5.12V,\\ VSS\leqVAIN\leqVREF \end{array}$                                                                             |
| A06          | EOFF  | Offset Error                          |                   | _           | —                         | < ± 2       | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                                                     |
| A07          | Egn   | Gain Error                            |                   | _           | —                         | < ± 1       | LSb   | VREF = VDD = 5.12V,<br>$VSS \le VAIN \le VREF$                                                                                                   |
| A10          | _     | Monotonicity                          |                   | _           | guaranteed <sup>(3)</sup> | —           | _     | $VSS \leq VAIN \leq VREF$                                                                                                                        |
| A20          | Vref  | Reference Voltage (VREF+ - VREF-)     |                   | 2.0         | —                         | Vdd + 0.3   | V     |                                                                                                                                                  |
| A21          | VREF+ | Reference Voltage                     | High              | AVDD – 2.5V |                           | AVDD + 0.3V | V     |                                                                                                                                                  |
| A22          | Vref- | Reference Voltage                     | Low               | AVss-0.3V   |                           | VREF+-2.0V  | V     |                                                                                                                                                  |
| A25          | VAIN  | Analog Input Voltag                   | е                 | Vss - 0.3V  | —                         | Vref + 0.3V | V     |                                                                                                                                                  |
| A30          | ZAIN  | Recommended Imp<br>Analog Voltage Sou | edance of<br>Irce | _           | —                         | 2.5         | kΩ    | (Note 4)                                                                                                                                         |
| A40          | IAD   | A/D Conversion                        | PIC16F87XA        | —           | 220                       | —           | μΑ    | Average current                                                                                                                                  |
|              |       | Current (VDD)                         | PIC16LF87XA       | —           | 90                        | —           | μA    | consumption when A/D is on <b>(Note 1)</b>                                                                                                       |
| A50          | IREF  | VREF Input Current                    | (Note 2)          |             |                           | 5           | μA    | During VAIN acquisition.<br>Based on differential of<br>VHOLD to VAIN to charge<br>CHOLD, see Section 11.1<br>"A/D Acquisition<br>Requirements". |
|              |       |                                       |                   | -           | _                         | 150         | μA    | During A/D conversion<br>cycle                                                                                                                   |

\* These parameters are characterized but not tested.

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

**Note 1:** When A/D is off, it will not consume any current other than minor leakage current. The power-down current spec includes any such leakage from the A/D module.

2: VREF current is from RA3 pin or VDD pin, whichever is selected as reference input.

3: The A/D conversion result never decreases with an increase in the input voltage and has no missing codes.

4: Maximum allowed impedance for analog voltage source is 10 kΩ. This requires higher acquisition time.









## 44-Lead Plastic Thin Quad Flatpack (PT) 10x10x1 mm Body, 1.0/0.10 mm Lead Form (TQFP)

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



|                          | Units  |      | INCHES |      | MILLIMETERS* |       |       |  |
|--------------------------|--------|------|--------|------|--------------|-------|-------|--|
| Dimension                | Limits | MIN  | NOM    | MAX  | MIN          | NOM   | MAX   |  |
| Number of Pins           | n      |      | 44     |      |              | 44    |       |  |
| Pitch                    | р      |      | .031   |      |              | 0.80  |       |  |
| Pins per Side            | n1     |      | 11     |      |              | 11    |       |  |
| Overall Height           | Α      | .039 | .043   | .047 | 1.00         | 1.10  | 1.20  |  |
| Molded Package Thickness | A2     | .037 | .039   | .041 | 0.95         | 1.00  | 1.05  |  |
| Standoff §               | A1     | .002 | .004   | .006 | 0.05         | 0.10  | 0.15  |  |
| Foot Length              | L      | .018 | .024   | .030 | 0.45         | 0.60  | 0.75  |  |
| Footprint (Reference)    | (F)    |      | .039   |      | 1.00         |       |       |  |
| Foot Angle               | ¢      | 0    | 3.5    | 7    | 0            | 3.5   | 7     |  |
| Overall Width            | E      | .463 | .472   | .482 | 11.75        | 12.00 | 12.25 |  |
| Overall Length           | D      | .463 | .472   | .482 | 11.75        | 12.00 | 12.25 |  |
| Molded Package Width     | E1     | .390 | .394   | .398 | 9.90         | 10.00 | 10.10 |  |
| Molded Package Length    | D1     | .390 | .394   | .398 | 9.90         | 10.00 | 10.10 |  |
| Lead Thickness           | С      | .004 | .006   | .008 | 0.09         | 0.15  | 0.20  |  |
| Lead Width               | В      | .012 | .015   | .017 | 0.30         | 0.38  | 0.44  |  |
| Pin 1 Corner Chamfer     | СН     | .025 | .035   | .045 | 0.64         | 0.89  | 1.14  |  |
| Mold Draft Angle Top     | α      | 5    | 10     | 15   | 5            | 10    | 15    |  |
| Mold Draft Angle Bottom  | β      | 5    | 10     | 15   | 5            | 10    | 15    |  |

\* Controlling Parameter § Significant Characteristic

Notes:

Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MS-026 Drawing No. C04-076

## 28-Lead Skinny Plastic Dual In-line (SP) – 300 mil (PDIP)

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



|                            | Units  |       | INCHES* |       | Μ     |       |       |
|----------------------------|--------|-------|---------|-------|-------|-------|-------|
| Dimension                  | _imits | MIN   | NOM     | MAX   | MIN   | NOM   | MAX   |
| Number of Pins             | n      |       | 28      |       |       | 28    |       |
| Pitch                      | р      |       | .100    |       |       | 2.54  |       |
| Top to Seating Plane       | А      | .140  | .150    | .160  | 3.56  | 3.81  | 4.06  |
| Molded Package Thickness   | A2     | .125  | .130    | .135  | 3.18  | 3.30  | 3.43  |
| Base to Seating Plane      | A1     | .015  |         |       | 0.38  |       |       |
| Shoulder to Shoulder Width | Е      | .300  | .310    | .325  | 7.62  | 7.87  | 8.26  |
| Molded Package Width       | E1     | .275  | .285    | .295  | 6.99  | 7.24  | 7.49  |
| Overall Length             | D      | 1.345 | 1.365   | 1.385 | 34.16 | 34.67 | 35.18 |
| Tip to Seating Plane       | L      | .125  | .130    | .135  | 3.18  | 3.30  | 3.43  |
| Lead Thickness             | С      | .008  | .012    | .015  | 0.20  | 0.29  | 0.38  |
| Upper Lead Width           | B1     | .040  | .053    | .065  | 1.02  | 1.33  | 1.65  |
| Lower Lead Width           | В      | .016  | .019    | .022  | 0.41  | 0.48  | 0.56  |
| Overall Row Spacing §      | eВ     | .320  | .350    | .430  | 8.13  | 8.89  | 10.92 |
| Mold Draft Angle Top       | α      | 5     | 10      | 15    | 5     | 10    | 15    |
| Mold Draft Angle Bottom    | β      | 5     | 10      | 15    | 5     | 10    | 15    |

\* Controlling Parameter § Significant Characteristic

Notes:

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

Drawing No. C04-070

## 28-Lead Plastic Shrink Small Outline (SS) - 209 mil, 5.30 mm (SSOP)

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









|                          | Units  | INCHES |      |      | MILLIMETERS* |        |        |  |
|--------------------------|--------|--------|------|------|--------------|--------|--------|--|
| Dimension                | Limits | MIN    | NOM  | MAX  | MIN          | NOM    | MAX    |  |
| Number of Pins           | n      |        | 28   |      |              | 28     |        |  |
| Pitch                    | р      |        | .026 |      |              | 0.65   |        |  |
| Overall Height           | А      | .068   | .073 | .078 | 1.73         | 1.85   | 1.98   |  |
| Molded Package Thickness | A2     | .064   | .068 | .072 | 1.63         | 1.73   | 1.83   |  |
| Standoff §               | A1     | .002   | .006 | .010 | 0.05         | 0.15   | 0.25   |  |
| Overall Width            | E      | .299   | .309 | .319 | 7.59         | 7.85   | 8.10   |  |
| Molded Package Width     | E1     | .201   | .207 | .212 | 5.11         | 5.25   | 5.38   |  |
| Overall Length           | D      | .396   | .402 | .407 | 10.06        | 10.20  | 10.34  |  |
| Foot Length              | L      | .022   | .030 | .037 | 0.56         | 0.75   | 0.94   |  |
| Lead Thickness           | С      | .004   | .007 | .010 | 0.10         | 0.18   | 0.25   |  |
| Foot Angle               | φ      | 0      | 4    | 8    | 0.00         | 101.60 | 203.20 |  |
| Lead Width               | В      | .010   | .013 | .015 | 0.25         | 0.32   | 0.38   |  |
| Mold Draft Angle Top     | α      | 0      | 5    | 10   | 0            | 5      | 10     |  |
| Mold Draft Angle Bottom  | β      | 0      | 5    | 10   | 0            | 5      | 10     |  |

\* Controlling Parameter § Significant Characteristic

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: MS-150

Drawing No. C04-073