



#### 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              | 22                                                                       |
| Program Memory Size        | 14KB (8K x 14)                                                           |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                |                                                                          |
| RAM Size                   | 368 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                |
| Data Converters            | A/D 5x8b                                                                 |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                           |
| Supplier Device Package    | 28-SSOP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f76t-i-ss |
|                            |                                                                          |

Email: info@E-XFL.COM

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

#### 1.0 **DEVICE OVERVIEW**

This document contains device specific information about the following devices:

- PIC16F73
- PIC16F74
- PIC16F76
- PIC16F77

PIC16F73/76 devices are available only in 28-pin packages, while PIC16F74/77 devices are available in 40-pin and 44-pin packages. All devices in the PIC16F7X family share common architecture, with the following differences:

- The PIC16F73 and PIC16F76 have one-half of the total on-chip memory of the PIC16F74 and **PIC16F77**
- The 28-pin devices have 3 I/O ports, while the 40/44-pin devices have 5
- · The 28-pin devices have 11 interrupts, while the 40/44-pin devices have 12
- The 28-pin devices have 5 A/D input channels, while the 40/44-pin devices have 8
- The Parallel Slave Port is implemented only on the 40/44-pin devices

PIC16F7X DEVICE FEATURES **PIC16F74 PIC16F76 Key Features PIC16F73 PIC16F77 Operating Frequency** DC - 20 MHz DC - 20 MHz DC - 20 MHz DC - 20 MHz **RESETS** (and Delays) POR, BOR POR. BOR POR. BOR POR, BOR (PWRT, OST) (PWRT, OST) (PWRT, OST) (PWRT, OST) FLASH Program Memory 4K 4K 8K 8K (14-bit words) Data Memory (bytes) 368 192 192 368 Interrupts 11 12 11 12 I/O Ports Ports A,B,C Ports A,B,C Ports A,B,C,D,E Ports A,B,C,D,E Timers 3 3 3 3 Capture/Compare/PWM Modules 2 2 2 2 SSP, USART Serial Communications SSP, USART SSP. USART SSP, USART Parallel Communications PSP PSP 8-bit Analog-to-Digital Module **5 Input Channels** 8 Input Channels 5 Input Channels 8 Input Channels Instruction Set **35 Instructions 35 Instructions** 35 Instructions **35 Instructions** Packaging 28-pin DIP 40-pin PDIP 28-pin DIP 40-pin PDIP 28-pin SOIC 44-pin PLCC 28-pin SOIC 44-pin PLCC 28-pin SSOP 44-pin TQFP 28-pin SSOP 44-pin TQFP 28-pin MLF 28-pin MLF

#### **TABLE 1-1:**

The available features are summarized in Table 1-1. Block diagrams of the PIC16F73/76 and PIC16F74/77 devices are provided in Figure 1-1 and Figure 1-2, respectively. The pinouts for these device families are listed in Table 1-2 and Table 1-3.

Additional information may be found in the PICmicro™ Mid-Range Reference Manual (DS33023), which may be obtained from your local Microchip Sales Representative or downloaded from the Microchip website. The Reference Manual should be considered a complementary document to this data sheet, and is highly recommended reading for a better understanding of the device architecture and operation of the peripheral modules.

#### 2.2.2.4 PIE1 Register

The PIE1 register contains the individual enable bits for the peripheral interrupts.

Note: Bit PEIE (INTCON<6>) must be set to enable any peripheral interrupt.

# REGISTER 2-4: PIE1 REGISTER (ADDRESS 8Ch)

|              |                        | •                                                                          |               | •            |         |        |        |        |  |  |  |  |  |  |
|--------------|------------------------|----------------------------------------------------------------------------|---------------|--------------|---------|--------|--------|--------|--|--|--|--|--|--|
|              | R/W-0                  | R/W-0                                                                      | R/W-0         | R/W-0        | R/W-0   | R/W-0  | R/W-0  | R/W-0  |  |  |  |  |  |  |
|              | PSPIE <sup>(1)</sup>   | ADIE                                                                       | RCIE          | TXIE         | SSPIE   | CCP1IE | TMR2IE | TMR1IE |  |  |  |  |  |  |
|              | bit 7                  |                                                                            |               |              |         |        |        |        |  |  |  |  |  |  |
|              |                        |                                                                            |               |              |         |        |        |        |  |  |  |  |  |  |
| bit 7        | PSPIE <sup>(1)</sup> : | PSPIE <sup>(1)</sup> : Parallel Slave Port Read/Write Interrupt Enable bit |               |              |         |        |        |        |  |  |  |  |  |  |
|              | 1 = Enable             | es the PSP r                                                               | ead/write int | terrupt      |         |        |        |        |  |  |  |  |  |  |
|              | 0 = Disabl             | es the PSP                                                                 | read/write in | terrupt      |         |        |        |        |  |  |  |  |  |  |
| bit 6        | ADIE: A/D              | Converter I                                                                | nterrupt Ena  | able bit     |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the A/D co                                                              |               |              |         |        |        |        |  |  |  |  |  |  |
|              | 0 = Disabl             | es the A/D c                                                               | onverter inte | errupt       |         |        |        |        |  |  |  |  |  |  |
| bit 5        |                        | ART Receive                                                                | •             |              |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the USAR                                                                |               |              |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the USAF                                                                |               |              |         |        |        |        |  |  |  |  |  |  |
| bit 4        |                        | RT Transmi                                                                 | -             |              |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the USAR                                                                |               |              |         |        |        |        |  |  |  |  |  |  |
| <b>h</b> # 0 |                        | es the USAF                                                                |               |              | hla h:+ |        |        |        |  |  |  |  |  |  |
| bit 3        | •                      | nchronous S                                                                |               | iterrupt Ena | DIE DIT |        |        |        |  |  |  |  |  |  |
|              |                        | es the SSP in<br>es the SSP i                                              |               |              |         |        |        |        |  |  |  |  |  |  |
| bit 2        |                        | CP1 Interru                                                                |               | i+           |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the CCP1                                                                | •             | it i         |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the CCP                                                                 | •             |              |         |        |        |        |  |  |  |  |  |  |
| bit 1        |                        | MR2 to PR                                                                  |               | rrupt Enable | e bit   |        |        |        |  |  |  |  |  |  |
|              |                        | es the TMR2                                                                |               | •            |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the TMR2                                                                |               |              |         |        |        |        |  |  |  |  |  |  |
| bit 0        | TMR1IE: T              | MR1 Overfl                                                                 | ow Interrupt  | Enable bit   |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the TMR1                                                                |               |              |         |        |        |        |  |  |  |  |  |  |
|              |                        | es the TMR'                                                                |               | •            |         |        |        |        |  |  |  |  |  |  |
|              |                        |                                                                            |               |              |         |        |        |        |  |  |  |  |  |  |

Note 1: PSPIE is reserved on 28-pin devices; always maintain this bit clear.

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

# 2.3 PCL and PCLATH

The program counter (PC) is 13 bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC<12:8>) are not readable, but are indirectly writable through the PCLATH register. On any RESET, the upper bits of the PC will be cleared. Figure 2-4 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 2-4: LOADING OF PC IN DIFFERENT SITUATIONS



#### 2.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the Application Note, *"Implementing a Table Read"* (AN556).

#### 2.3.2 STACK

The PIC16F7X family has an 8-level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed, or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

- Note 1: There are no status bits to indicate stack overflow or stack underflow conditions.
  - 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt address.

# 2.4 Program Memory Paging

PIC16F7X devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11 bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction, the upper 2 bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is popped off the stack. Therefore, manipulation of the PCLATH<4:3> bits are not required for the RETURN instructions (which POPs the address from the stack).

| Note: | The contents of the PCLATH are         |  |  |  |  |  |  |  |  |  |  |
|-------|----------------------------------------|--|--|--|--|--|--|--|--|--|--|
|       | unchanged after a RETURN or RETFIE     |  |  |  |  |  |  |  |  |  |  |
|       | instruction is executed. The user must |  |  |  |  |  |  |  |  |  |  |
|       | setup the PCLATH for any subsequent    |  |  |  |  |  |  |  |  |  |  |
|       | CALLS <b>or</b> GOTOS.                 |  |  |  |  |  |  |  |  |  |  |

Example 2-1 shows the calling of a subroutine in page 1 of the program memory. This example assumes that PCLATH is saved and restored by the Interrupt Service Routine (if interrupts are used).

#### EXAMPLE 2-1: CALL OF A SUBROUTINE IN PAGE 1 FROM PAGE 0

|         | ORG  | 0x500    |                                                          |
|---------|------|----------|----------------------------------------------------------|
|         | BCF  | PCLATH,4 |                                                          |
|         | BSF  | PCLATH,3 | ;Select page 1<br>;(800h-FFFh)                           |
|         | CALL | SUB1_P1  | ;Call subroutine in                                      |
|         | :    |          | ;page 1 (800h-FFFh)                                      |
|         | :    |          |                                                          |
|         | ORG  | 0x900    | ;page 1 (800h-FFFh)                                      |
| SUB1_P1 |      |          |                                                          |
|         | :    |          | ;called subroutine                                       |
|         | :    |          | ;page 1 (800h-FFFh)                                      |
|         | :    |          |                                                          |
| RETURN  |      |          | ;return to Call<br>;subroutine in page 0<br>;(000h-7FFh) |

# 4.2 PORTB and the TRISB Register

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

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit RBPU (OPTION\_REG<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.





Four of the PORTB pins (RB7:RB4) have an interrupt-on-change feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB7:RB4 pin configured as an output is excluded from the interrupt-on-change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are ORed together to generate the RB Port Change Interrupt with flag bit RBIF (INTCON<0>). This interrupt can wake the device from SLEEP. The user, in the Interrupt Service Routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear flag bit RBIF.

A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition and allow flag bit RBIF to be cleared.

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt-on-change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.

This interrupt on mismatch feature, together with software configureable pull-ups on these four pins, allow easy interface to a keypad and make it possible for wake-up on key depression. Refer to the Embedded Control Handbook, "Implementing Wake-up on Key Stroke" (AN552).

RB0/INT is an external interrupt input pin and is configured using the INTEDG bit (OPTION\_REG<6>).

RB0/INT is discussed in detail in Section 12.11.1.

#### FIGURE 4-4: BLOCK DIAGRAM OF RB7:RB4 PINS



| Name    | Bit# | Buffer                | Function                                                                                                               |
|---------|------|-----------------------|------------------------------------------------------------------------------------------------------------------------|
| RB0/INT | bit0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software programmable weak pull-up.                             |
| RB1     | bit1 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                         |
| RB2     | bit2 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                         |
| RB3     | bit3 | TTL                   | Input/output pin. Internal software programmable weak pull-up.                                                         |
| RB4     | bit4 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                              |
| RB5     | bit5 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                              |
| RB6     | bit6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change).<br>Internal software programmable weak pull-up. Serial programming clock. |
| RB7     | bit7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change).<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.

#### 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 on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-----------|------------|---------|---------------|-----------|-----------|-------|-------|-------|-------|--------------------------|---------------------------------|
| 06h, 106h | PORTB      | RB7     | RB6           | RB5       | RB4       | RB3   | RB2   | RB1   | RB0   | xxxx xxxx                | uuuu uuuu                       |
| 86h, 186h | TRISB      | PORTB I | Data Directio | 1111 1111 | 1111 1111 |       |       |       |       |                          |                                 |
| 81h, 181h | OPTION_REG | RBPU    | INTEDG        | TOCS      | T0SE      | 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, bi-directional 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 Hi-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 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 destination should be avoided. The user should refer to the corresponding peripheral section for the correct TRIS bit settings, and to Section 13.1 for additional information on read-modify-write operations.

#### FIGURE 4-5:

#### PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE)



**3:** Peripheral OE (output enable) is only activated if peripheral select is active.

| Name            | Bit# | Buffer Type | Function                                                                                        |
|-----------------|------|-------------|-------------------------------------------------------------------------------------------------|
| RC0/T1OSO/T1CKI | bit0 | ST          | Input/output port pin or Timer1 oscillator output/Timer1 clock input.                           |
| RC1/T1OSI/CCP2  | bit1 | ST          | Input/output port pin or Timer1 oscillator input or Capture2 input/Compare2 output/PWM2 output. |
| RC2/CCP1        | bit2 | ST          | Input/output port pin or Capture1 input/Compare1 output/PWM1 output.                            |
| RC3/SCK/SCL     | bit3 | ST          | RC3 can also be the synchronous serial clock for both SPI and $I^2C$ modes.                     |
| RC4/SDI/SDA     | bit4 | ST          | RC4 can also be the SPI Data In (SPI mode) or Data I/O (I <sup>2</sup> C mode).                 |
| RC5/SDO         | bit5 | ST          | Input/output port pin or Synchronous Serial Port data output.                                   |
| RC6/TX/CK       | bit6 | ST          | Input/output port pin or USART Asynchronous Transmit or<br>Synchronous Clock.                   |
| RC7/RX/DT       | bit7 | ST          | Input/output port pin or USART Asynchronous Receive or Synchronous Data.                        |

#### TABLE 4-5: PORTC FUNCTIONS

Legend: ST = Schmitt Trigger input

#### TABLE 4-6: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC

| Address | Name  | Bit 7 | Bit 6     | Bit 5     | Bit 4     | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|---------|-------|-------|-----------|-----------|-----------|-------|-------|-------|-------|--------------------------|---------------------------------|
| 07h     | PORTC | RC7   | RC6       | RC5       | RC4       | RC3   | RC2   | RC1   | RC0   | xxxx xxxx                | uuuu uuuu                       |
| 87h     | TRISC | PORTC | Data Dire | 1111 1111 | 1111 1111 |       |       |       |       |                          |                                 |

Legend: x = unknown, u = unchanged

# 4.4 **PORTD and TRISD Registers**

This section is not applicable to the PIC16F73 or PIC16F76.

PORTD is an 8-bit port with Schmitt Trigger input buffers. Each pin is individually configureable 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-6: PORTD BLOCK DIAGRAM (IN I/O PORT MODE)



| Name     | Bit# | Buffer Type           | Function                                          |
|----------|------|-----------------------|---------------------------------------------------|
| RD0/PSP0 | bit0 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit0 |
| RD1/PSP1 | bit1 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit1 |
| RD2/PSP2 | bit2 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit2 |
| RD3/PSP3 | bit3 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit3 |
| RD4/PSP4 | bit4 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit4 |
| RD5/PSP5 | bit5 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit5 |
| RD6/PSP6 | bit6 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit6 |
| RD7/PSP7 | bit7 | ST/TTL <sup>(1)</sup> | Input/output port pin or parallel slave port bit7 |

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

| Address | Name  | Bit 7 | Bit 6    | Bit 5     | Bit 4   | Bit 3     | Bit 2     | Bit 1        | Bit 0     | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|---------|-------|-------|----------|-----------|---------|-----------|-----------|--------------|-----------|--------------------------|---------------------------------|
| 08h     | PORTD | RD7   | RD6      | RD5       | RD4     | RD3       | RD2       | RD1          | RD0       | xxxx xxxx                | uuuu uuuu                       |
| 88h     | TRISD | PORT  | D Data D | Direction |         | 1111 1111 | 1111 1111 |              |           |                          |                                 |
| 89h     | TRISE | IBF   | OBF      | IBOV      | PSPMODE |           | PORTE Da  | ata Directio | 0000 -111 | 0000 -111                |                                 |

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

| Address               | Name    | Bit 7                | Bit 6       | Bit 5      | Bit 4    | Bit 3      | Bit 2       | Bit 1   | Bit 0  | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|-----------------------|---------|----------------------|-------------|------------|----------|------------|-------------|---------|--------|--------------------------|---------------------------------|
| 0Bh,8Bh.<br>10Bh,18Bh | INTCON  | GIE                  | PEIE        | TMR0IE     | INTE     | RBIE       | TMR0IF      | INTF    | RBIF   | x000 0000                | 0000 000u                       |
| 0Ch                   | PIR1    | PSPIF <sup>(1)</sup> | ADIF        | RCIF       | TXIF     | SSPIF      | CCP1IF      | TMR2IF  | TMR1IF | 0000 0000                | 0000 0000                       |
| 8Ch                   | PIE1    | PSPIE <sup>(1)</sup> | ADIE        | RCIE       | TXIE     | SSPIE      | CCP1IE      | TMR2IE  | TMR1IE | 0000 0000                | 0000 0000                       |
| 87h                   | TRISC   | PORTC Da             | ta Directio | on Registe | r        |            |             |         |        | 1111 1111                | 1111 1111                       |
| 13h                   | SSPBUF  | Synchronou           | us Serial F | Port Recei | ve Buff  | er/Transm  | it Register |         |        | XXXX XXXX                | uuuu uuuu                       |
| 14h                   | SSPCON  | WCOL                 | SSPOV       | SSPEN      | СКР      | SSPM3      | SSPM2       | SSPM1   | SSPM0  | 0000 0000                | 0000 0000                       |
| 85h                   | TRISA   | —                    | _           | PORTA D    | Data Dii | rection Re | 11 1111     | 11 1111 |        |                          |                                 |
| 94h                   | SSPSTAT | SMP                  | CKE         | D/A        | Р        | S          | R/W         | UA      | BF     | 0000 0000                | 0000 0000                       |

#### TABLE 9-1:REGISTERS ASSOCIATED WITH SPI OPERATION

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the SSP in SPI mode.

**Note 1:** Bits PSPIE and PSPIF are reserved on the PIC16F73/76; always maintain these bits clear.

#### 9.3.1.1 Addressing

Once the SSP module has been enabled, it waits for a START condition to occur. Following the START condition, the 8-bits are shifted into the SSPSR register. All incoming bits are sampled with the rising edge of the clock (SCL) line. The value of register SSPSR<7:1> is compared to the value of the SSPADD register. The address is compared on the falling edge of the eighth clock (SCL) pulse. If the addresses match, and the BF and SSPOV bits are clear, the following events occur:

- a) The SSPSR register value is loaded into the SSPBUF register.
- b) The buffer full bit, BF is set.
- c) An ACK pulse is generated.
- d) SSP interrupt flag bit, SSPIF (PIR1<3>) is set (interrupt is generated if enabled) - on the falling edge of the ninth SCL pulse.

In 10-bit Address mode, two address bytes need to be received by the slave (Figure 9-7). The five Most Significant bits (MSbs) of the first address byte specify if this is a 10-bit address. Bit R/W (SSPSTAT<2>) must specify a write so the slave device will receive the second address byte. For a 10-bit address, the first byte would equal '1111 0 A9 A8 0', where A9 and A8 are the two MSbs of the address. The sequence of events for 10-bit address is as follows, with steps 7 - 9 for slave-transmitter:

- 1. Receive first (high) byte of address (bits SSPIF, BF, and bit UA (SSPSTAT<1>) are set).
- Update the SSPADD register with second (low) byte of address (clears bit UA and releases the SCL line).
- 3. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 4. Receive second (low) byte of address (bits SSPIF, BF, and UA are set).
- 5. Update the SSPADD register with the first (high) byte of address, if match releases SCL line, this will clear bit UA.
- 6. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 7. Receive Repeated START condition.
- 8. Receive first (high) byte of address (bits SSPIF and BF are set).
- 9. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.

| Status Bits as Data<br>Transfer is Received |       | $SSPSR \to SSPBUF$ | Generate ACK<br>Pulse | Set bit SSPIF<br>(SSP Interrupt occurs |
|---------------------------------------------|-------|--------------------|-----------------------|----------------------------------------|
| BF                                          | SSPOV |                    | Fuise                 | if enabled)                            |
| 0                                           | 0     | Yes                | Yes                   | Yes                                    |
| 1                                           | 0     | No                 | No                    | Yes                                    |
| 1                                           | 1     | No                 | No                    | Yes                                    |
| 0                                           | 1     | No                 | No                    | Yes                                    |

# TABLE 9-2: DATA TRANSFER RECEIVED BYTE ACTIONS

**Note:** Shaded cells show the conditions where the user software did not properly clear the overflow condition.

#### 9.3.1.2 Reception

When the R/W bit of the address byte is clear and an address match occurs, the R/W bit of the SSPSTAT register is cleared. The received address is loaded into the SSPBUF register.

When the address byte overflow condition exists, then no Acknowledge (ACK) pulse is given. An overflow condition is defined as either bit BF (SSPSTAT<0>) is set, or bit SSPOV (SSPCON<6>) is set. This is an error condition due to the user's firmware. An SSP interrupt is generated for each data transfer byte. Flag bit SSPIF (PIR1<3>) must be cleared in software. The SSPSTAT register is used to determine the status of the byte.

## 11.1 A/D Acquisition Requirements

For the A/D converter to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The analog input model is shown in Figure 11-2. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), see Figure 11-2. The source impedance affects the offset voltage at the analog input (due to pin leakage current). The maximum recommended impedance for analog sources is 10 k $\Omega$ . After the analog input channel is selected (changed), the acquisition period must pass before the conversion can be started.

To calculate the minimum acquisition time, TACQ, see the PICmicro<sup>TM</sup> Mid-Range MCU Family Reference Manual (DS33023). In general, however, given a maximum source impedance of 10 k $\Omega$  and at a temperature of 100°C, TACQ will be no more than 16 µsec.



#### TABLE 11-1: TAD vs. MAXIMUM DEVICE OPERATING FREQUENCIES (STANDARD DEVICES (C))

| AD Cloc                 | Maximum Device Frequency |          |
|-------------------------|--------------------------|----------|
| Operation               | ADCS1:ADCS0              | Max.     |
| 2Tosc                   | 0.0                      | 1.25 MHz |
| 8Tosc                   | 01                       | 5 MHz    |
| 32Tosc                  | 10                       | 20 MHz   |
| RC <sup>(1, 2, 3)</sup> | 11                       | (Note 1) |

Note 1: The RC source has a typical TAD time of 4 µs but can vary between 2-6 µs.

2: When the device frequencies are greater than 1 MHz, the RC A/D conversion clock source is only recommended for SLEEP operation.

3: For extended voltage devices (LC), please refer to the Electrical Specifications section.

#### TABLE 13-2: PIC16F7X INSTRUCTION SET

| Mnemonic,<br>Operands                  |         | Description                                          | Cuolos        |        | 14-Bit    | Opcode   | Status    | Notes        |         |  |
|----------------------------------------|---------|------------------------------------------------------|---------------|--------|-----------|----------|-----------|--------------|---------|--|
|                                        |         | Description                                          | Cycles        | MSb    |           |          | LSb       | Affected     | Notes   |  |
| BYTE-ORIENTED FILE REGISTER OPERATIONS |         |                                                      |               |        |           |          |           |              |         |  |
| ADDWF                                  | f, d    | Add W and f                                          | 1             | 00     | 0111      | dfff     | ffff      | C,DC,Z       | 1,2     |  |
| ANDWF                                  | f, d    | AND W with f                                         | 1             | 00     | 0101      | dfff     | ffff      | Z            | 1,2     |  |
| CLRF                                   | f       | Clear f                                              | 1             | 00     | 0001      | lfff     | ffff      | Z            | 2       |  |
| CLRW                                   | -       | Clear W                                              | 1             | 00     | 0001      | 0xxx     | xxxx      | Z            |         |  |
| COMF                                   | f, d    | Complement f                                         | 1             | 00     | 1001      | dfff     | ffff      | Z            | 1,2     |  |
| DECF                                   | f, d    | Decrement f                                          | 1             | 00     | 0011      | dfff     | ffff      | Z            | 1,2     |  |
| DECFSZ                                 | f, d    | Decrement f, Skip if 0                               | 1(2)          | 00     | 1011      | dfff     | ffff      |              | 1,2,3   |  |
| INCF                                   | f, d    | Increment f                                          | 1             | 00     | 1010      | dfff     | ffff      | Z            | 1,2     |  |
| INCFSZ                                 | f, d    | Increment f, Skip if 0                               | 1(2)          | 00     | 1111      | dfff     | ffff      |              | 1,2,3   |  |
| IORWF                                  | f, d    | Inclusive OR W with f                                | 1             | 00     | 0100      | dfff     | ffff      | Z            | 1,2     |  |
| MOVF                                   | f, d    | Move f                                               | 1             | 00     | 1000      | dfff     | ffff      | Z            | 1,2     |  |
| MOVWF                                  | f       | Move W to f                                          | 1             | 00     | 0000      | lfff     | ffff      |              |         |  |
| NOP                                    | -       | No Operation                                         | 1             | 00     | 0000      | 0xx0     | 0000      |              |         |  |
| RLF                                    | f, d    | Rotate Left f through Carry                          | 1             | 00     | 1101      | dfff     | ffff      | С            | 1,2     |  |
| RRF                                    | f, d    | Rotate Right f through Carry                         | 1             | 00     | 1100      | dfff     | ffff      | С            | 1,2     |  |
| SUBWF                                  | f, d    | Subtract W from f                                    | 1             | 00     | 0010      | dfff     | ffff      | C,DC,Z       | 1,2     |  |
| SWAPF                                  | f, d    | Swap nibbles in f                                    | 1             | 00     | 1110      | dfff     | ffff      |              | 1,2     |  |
| XORWF                                  | f, d    | Exclusive OR W with f                                | 1             | 00     | 0110      | dfff     | ffff      | Z            | 1,2     |  |
|                                        |         | BIT-ORIENTED FILE REC                                | SISTER OPER   | RATION | IS        |          |           |              |         |  |
| 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 CONT                                     | ROL OPERAT    | 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             | 00     | 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: V                              | Vhen an | I/O register is modified as a function of itself ( e | .g., MOVF POI | RTB, : | 1), the v | alue use | ed will b | e that value | present |  |

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

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

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

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

# 15.2 DC Characteristics: PIC16F73/74/76/77 (Industrial, Extended) PIC16LF73/74/76/77 (Industrial) (Continued)

| DC CHA       | ARACT | ERISTICS                                    | 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 |      |          |        |                                                                        |  |  |  |
|--------------|-------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|--------|------------------------------------------------------------------------|--|--|--|
|              |       |                                             | Operating<br>Section 1                                                                                                                                                                  |      | e VDD ra | nge as | described in DC Specification,                                         |  |  |  |
| Param<br>No. | Sym   | Characteristic Min Typ† Max Units Condition |                                                                                                                                                                                         |      |          |        |                                                                        |  |  |  |
|              | Vol   | Output Low Voltage                          |                                                                                                                                                                                         |      |          |        |                                                                        |  |  |  |
| D080         |       | I/O ports                                   |                                                                                                                                                                                         | —    | 0.6      | V      | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +125°C                           |  |  |  |
| D083         |       | OSC2/CLKOUT (RC osc config)                 | —                                                                                                                                                                                       | —    | 0.6      | V      | IOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +125°C                           |  |  |  |
|              |       |                                             |                                                                                                                                                                                         | —    | 0.6      | V      | IOL = 1.2 mA, VDD = 4.5V,<br>-40°C to +125°C                           |  |  |  |
|              | Vон   | Output High Voltage                         |                                                                                                                                                                                         |      |          |        |                                                                        |  |  |  |
| D090         |       | I/O ports (Note 3)                          | Vdd - 0.7                                                                                                                                                                               | _    | —        | V      | IOH = -3.0 mA, VDD = 4.5V,<br>-40°С to +125°С                          |  |  |  |
| D092         |       | OSC2/CLKOUT (RC osc config)                 | Vdd - 0.7                                                                                                                                                                               | —    | —        | V      | ІОН = -1.3 mA, VDD = 4.5V,<br>-40°С to +125°С                          |  |  |  |
|              |       |                                             | Vdd - 0.7                                                                                                                                                                               | —    | —        | V      | IOH = -1.0 mA, VDD = 4.5V,<br>-40°С to +125°С                          |  |  |  |
| D150*        | Vod   | Open Drain High Voltage                     |                                                                                                                                                                                         | _    | 12       | V      | RA4 pin                                                                |  |  |  |
|              |       | Capacitive Loading Specs on (               | Dutput Pir                                                                                                                                                                              | IS   |          |        |                                                                        |  |  |  |
| D100         | Cosc2 | OSC2 pin                                    | _                                                                                                                                                                                       | —    | 15       | pF     | In XT, HS and LP modes when<br>external clock is used to drive<br>OSC1 |  |  |  |
| D101         | Сю    | All I/O pins and OSC2<br>(in RC mode)       | —                                                                                                                                                                                       | —    | 50       | pF     |                                                                        |  |  |  |
| D102         | Св    | SCL, SDA in I <sup>2</sup> C mode           | —                                                                                                                                                                                       | —    | 400      | pF     |                                                                        |  |  |  |
|              |       | Program FLASH Memory                        |                                                                                                                                                                                         | I I  |          |        | 1                                                                      |  |  |  |
| D130         | ЕΡ    | Endurance                                   | 100                                                                                                                                                                                     | 1000 | _        | E/W    | 25°C at 5V                                                             |  |  |  |
| D131         | Vpr   | VDD for Read                                | 2.0                                                                                                                                                                                     | —    | 5.5      | V      |                                                                        |  |  |  |

\* These parameters are characterized but not tested.

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

**Note 1:** In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16F7X be driven with external clock in RC mode.

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

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



# FIGURE 15-6: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING

#### FIGURE 15-7: BROWN-OUT RESET TIMING



# TABLE 15-3:RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,<br/>AND BROWN-OUT RESET REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic Min                                        |     | Тур†      | Max | Units | Conditions               |
|------------------|-------|-----------------------------------------------------------|-----|-----------|-----|-------|--------------------------|
| 30               | TmcL  | MCLR Pulse Width (low)                                    | 2   | _         |     | μs    | VDD = 5V, -40°C to +85°C |
| 31*              | Twdt  | Watchdog Timer Time-out Period<br>(No Prescaler)          | 7   | 18        | 33  | ms    | VDD = 5V, -40°C to +85°C |
| 32               | Tost  | Oscillation Start-up Timer Period                         | _   | 1024 Tosc | _   | _     | Tosc = OSC1 period       |
| 33*              | TPWRT | Power-up Timer Period                                     | 28  | 72        | 132 | ms    | VDD = 5V, -40°C to +85°C |
| 34               | Tioz  | I/O Hi-Impedance from MCLR Low<br>or Watchdog Timer Reset | —   | _         | 2.1 | μs    |                          |
| 35               | TBOR  | Brown-out Reset Pulse Width                               | 100 | _         | _   | μs    | VDD ≤ VBOR (D005)        |

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





#### TABLE 15-13: A/D CONVERSION REQUIREMENTS

| Param<br>No. | Sym  | Characteristic                                       |           | Min | Тур†   | Мах | Units | Conditions                                                                                                                                                                                                                       |
|--------------|------|------------------------------------------------------|-----------|-----|--------|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 130          | Tad  | A/D clock period                                     | PIC16F7X  | 1.6 | —      |     | μs    | Tosc based, VREF $\geq 3.0V$                                                                                                                                                                                                     |
|              |      |                                                      | PIC16LF7X | 2.0 | _      | _   | μs    | Tosc based, $2.0V \le VREF \le 5.5V$                                                                                                                                                                                             |
|              |      |                                                      | PIC16F7X  | 2.0 | 4.0    | 6.0 | μs    | A/D RC mode                                                                                                                                                                                                                      |
|              |      |                                                      | PIC16LF7X | 3.0 | 6.0    | 9.0 | μs    | A/D RC mode                                                                                                                                                                                                                      |
| 131          | Тслу | Conversion time (not in<br>S/H time) <b>(Note 1)</b> | 9         |     | 9      | Tad |       |                                                                                                                                                                                                                                  |
| 132          | TACQ | Acquisition time                                     |           | 5*  | _      |     | μs    | The minimum time is the<br>amplifier settling time. This<br>may be used if the "new" input<br>voltage has not changed by<br>more than 1 LSb (i.e.,<br>20.0 mV @ 5.12V) from the<br>last sampled voltage (as<br>stated on CHOLD). |
| 134          | TGO  | Q4 to A/D clock start                                |           | _   | Tosc/2 |     |       | If the A/D clock source is selected as RC, a time of TCY is added before the A/D clock starts. This allows the SLEEP instruction to be executed.                                                                                 |

\* 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:** ADRES register may be read on the following TCY cycle.

2: See Section 11.1 for minimum conditions.



FIGURE 16-17: TYPICAL, MINIMUM AND MAXIMUM Vol vs. lol (VDD = 5V, -40°C TO 125°C)





# 17.0 PACKAGING INFORMATION

# 17.1 Package Marking Information



#### 28-Lead SOIC



Example



# Example



### 28-Lead SSOP



28-Lead MLF



# Example



# Example



| Legend | I: XXX<br>Y<br>YY<br>WW<br>NNN | Customer specific information*<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code |
|--------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:  | be carried                     | nt the full Microchip part number cannot be marked on one line, it will<br>over to the next line thus limiting the number of available characters<br>her specific information.                          |

\* Standard PICmicro device marking consists of Microchip part number, year code, week code, and traceability code. For PICmicro device marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price.

# 44-Lead Plastic Leaded Chip Carrier (L) – Square (PLCC)



|                          |     | INCHES* |      | MILLIMETERS |       |       |       |
|--------------------------|-----|---------|------|-------------|-------|-------|-------|
| Dimensi                  | MIN | NOM     | 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    |

\* 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: MO-047 Drawing No. C04-048

# APPENDIX C: CONVERSION CONSIDERATIONS

Considerations for converting from previous versions of devices to the ones listed in this data sheet are listed in Table C-1.

## TABLE C-1: CONVERSION CONSIDERATIONS

| Characteristic | PIC16C7X                                         | PIC16F87X                                               | PIC16F7X                                         |
|----------------|--------------------------------------------------|---------------------------------------------------------|--------------------------------------------------|
| Pins           | 28/40                                            | 28/40                                                   | 28/40                                            |
| Timers         | 3                                                | 3                                                       | 3                                                |
| Interrupts     | 11 or 12                                         | 13 or 14                                                | 11 or 12                                         |
| Communication  | PSP, USART, SSP<br>(SPI, I <sup>2</sup> C Slave) | PSP, USART, SSP<br>(SPI, I <sup>2</sup> C Master/Slave) | PSP, USART, SSP<br>(SPI, I <sup>2</sup> C Slave) |
| Frequency      | 20 MHz                                           | 20 MHz                                                  | 20 MHz                                           |
| A/D            | 8-bit                                            | 10-bit                                                  | 8-bit                                            |
| ССР            | 2                                                | 2                                                       | 2                                                |
| Program Memory | 4K, 8K EPROM                                     | 4K, 8K FLASH<br>(1,000 E/W cycles)                      | 4K, 8K FLASH<br>(100 E/W cycles typical)         |
| RAM            | 192, 368 bytes                                   | 192, 368 bytes                                          | 192, 368 bytes                                   |
| EEPROM Data    | None                                             | 128, 256 bytes                                          | None                                             |
| Other          | _                                                | In-Circuit Debugger,<br>Low Voltage Programming         | _                                                |

# **ON-LINE SUPPORT**

Microchip provides on-line support on the Microchip World Wide Web (WWW) site.

The web site is used by Microchip as a means to make files and information easily available to customers. To view the site, the user must have access to the Internet and a web browser, such as Netscape or Microsoft Explorer. Files are also available for FTP download from our FTP site.

#### Connecting to the Microchip Internet Web Site

The Microchip web site is available by using your favorite Internet browser to attach to:

#### www.microchip.com

The file transfer site is available by using an FTP service to connect to:

#### ftp://ftp.microchip.com

The web site and file transfer site provide a variety of services. Users may download files for the latest Development Tools, Data Sheets, Application Notes, User's Guides, Articles and Sample Programs. A variety of Microchip specific business information is also available, including listings of Microchip sales offices, distributors and factory representatives. Other data available for consideration is:

- Latest Microchip Press Releases
- Technical Support Section with Frequently Asked
   Questions
- Design Tips
- Device Errata
- Job Postings
- Microchip Consultant Program Member Listing
- Links to other useful web sites related to Microchip Products
- Conferences for products, Development Systems, technical information and more
- · Listing of seminars and events

#### Systems Information and Upgrade Hot Line

The Systems Information and Upgrade Line provides system users a listing of the latest versions of all of Microchip's development systems software products. Plus, this line provides information on how customers can receive any currently available upgrade kits.The Hot Line Numbers are:

1-800-755-2345 for U.S. and most of Canada, and

1-480-792-7302 for the rest of the world.

013001



# WORLDWIDE SALES AND SERVICE

#### AMERICAS

**Corporate Office** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com

**Rocky Mountain** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456

#### Atlanta

500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307

Boston

2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821

Chicago 333 Pierce Road, Suite 180

Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075 Dallas

4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924

Detroit

Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260

Kokomo

2767 S. Albright Road Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387 Los Angeles

18201 Von Karman, Suite 1090 Irvine, CA 92612

Tel: 949-263-1888 Fax: 949-263-1338

New York 150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335

San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

Toronto

6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Australia

Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 China - Beijing

Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104 China - Chengdu

Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-6766200 Fax: 86-28-6766599

#### China - Fuzhou

Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521 China - Shanghai

Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060

#### China - Shenzhen

Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1315, 13/F, Shenzhen Kerry Centre, Renminnan Lu Shenzhen 518001, China Tel: 86-755-2350361 Fax: 86-755-2366086 Hong Kong Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza

223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

#### India

Microchip Technology Inc. India Liaison Office **Divyasree Chambers** 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062

#### Japan

Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122 Korea Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934 Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-334-8870 Fax: 65-334-8850 Taiwan Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

#### **EUROPE**

Denmark

Microchip Technology Nordic ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 France Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany

Microchip Technology GmbH Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44

Italy

Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883

United Kingdom

Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820

01/18/02