



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                      | 10MHz                                                                     |
| 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        | OTP                                                                       |
| EEPROM Size                |                                                                           |
| RAM Size                   | 192 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | $4V \sim 6V$                                                              |
| Data Converters            | A/D 8x8b                                                                  |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                  |
| Supplier Device Package    | 40-PDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c74a-10i-p |
|                            |                                                                           |

Email: info@E-XFL.COM

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

#### 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16CXX family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16CXX uses a Harvard architecture, in which, program and data are accessed from separate memories using separate buses. This improves bandwidth over traditional von Neumann architecture in which program and data are fetched from the same memory using the same bus. Separating program and data buses further allows instructions to be sized differently than the 8-bit wide data word. Instruction opcodes are 14-bits wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. A twostage pipeline overlaps fetch and execution of instructions (Example 3-1). Consequently, all instructions (35) execute in a single cycle (200 ns @ 20 MHz) except for program branches.

The table below lists program memory (EPROM) and data memory (RAM) for each PIC16C7X device.

| Device    | Program<br>Memory | Data Memory |
|-----------|-------------------|-------------|
| PIC16C72  | 2K x 14           | 128 x 8     |
| PIC16C73  | 4K x 14           | 192 x 8     |
| PIC16C73A | 4K x 14           | 192 x 8     |
| PIC16C74  | 4K x 14           | 192 x 8     |
| PIC16C74A | 4K x 14           | 192 x 8     |
| PIC16C76  | 8K x 14           | 368 x 8     |
| PIC16C77  | 8K x 14           | 386 x 8     |

The PIC16CXX can directly or indirectly address its register files or data memory. All special function registers, including the program counter, are mapped in the data memory. The PIC16CXX has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16CXX simple yet efficient. In addition, the learning curve is reduced significantly.

PIC16CXX devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between the data in the working register and any register file.

The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the working register (W register). The other operand is a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a borrow bit and a digit borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

#### TABLE 3-2:PIC16C73/73A/76 PINOUT DESCRIPTION

| Pin Name                | DIP<br>Pin# | SOIC<br>Pin# | I/O/P<br>Type | Buffer<br>Type         | Description                                                                                                                                                                                                  |
|-------------------------|-------------|--------------|---------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1/CLKIN              | 9           | 9            | I             | ST/CMOS <sup>(3)</sup> | Oscillator crystal input/external clock source input.                                                                                                                                                        |
| OSC2/CLKOUT             | 10          | 10           | 0             | -                      | Oscillator crystal output. Connects to crystal or resonator in crystal oscillator mode. In RC mode, the OSC2 pin outputs CLKOUT which has 1/4 the frequency of OSC1, and denotes the instruction cycle rate. |
| MCLR/Vpp                | 1           | 1            | I/P           | ST                     | Master clear (reset) input or programming voltage input. This pin is an active low reset to the device.                                                                                                      |
|                         |             |              |               |                        | PORTA is a bi-directional I/O port.                                                                                                                                                                          |
| RA0/AN0                 | 2           | 2            | I/O           | TTL                    | RA0 can also be analog input0                                                                                                                                                                                |
| RA1/AN1                 | 3           | 3            | I/O           | TTL                    | RA1 can also be analog input1                                                                                                                                                                                |
| RA2/AN2                 | 4           | 4            | I/O           | TTL                    | RA2 can also be analog input2                                                                                                                                                                                |
| RA3/AN3/VREF            | 5           | 5            | I/O           | TTL                    | RA3 can also be analog input3 or analog reference voltage                                                                                                                                                    |
| RA4/T0CKI               | 6           | 6            | I/O           | ST                     | RA4 can also be the clock input to the Timer0 module.<br>Output is open drain type.                                                                                                                          |
| RA5/ <del>SS</del> /AN4 | 7           | 7            | I/O           | TTL                    | RA5 can also be analog input4 or the slave select for the<br>synchronous serial port.                                                                                                                        |
|                         |             |              |               |                        | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-up on all inputs.                                                                                                |
| RB0/INT                 | 21          | 21           | I/O           | TTL/ST(1)              | RB0 can also be the external interrupt pin.                                                                                                                                                                  |
| RB1                     | 22          | 22           | I/O           | TTL                    |                                                                                                                                                                                                              |
| RB2                     | 23          | 23           | I/O           | TTL                    |                                                                                                                                                                                                              |
| RB3                     | 24          | 24           | I/O           | TTL                    |                                                                                                                                                                                                              |
| RB4                     | 25          | 25           | I/O           | TTL                    | Interrupt on change pin.                                                                                                                                                                                     |
| RB5                     | 26          | 26           | I/O           | TTL                    | Interrupt on change pin.                                                                                                                                                                                     |
| RB6                     | 27          | 27           | I/O           | TTL/ST(2)              | Interrupt on change pin. Serial programming clock.                                                                                                                                                           |
| RB7                     | 28          | 28           | I/O           | TTL/ST(2)              | Interrupt on change pin. Serial programming data.                                                                                                                                                            |
|                         |             |              |               |                        | PORTC is a bi-directional I/O port.                                                                                                                                                                          |
| RC0/T1OSO/T1CKI         | 11          | 11           | I/O           | ST                     | RC0 can also be the Timer1 oscillator output or Timer1 clock input.                                                                                                                                          |
| RC1/T1OSI/CCP2          | 12          | 12           | I/O           | ST                     | RC1 can also be the Timer1 oscillator input or Capture2 input/Compare2 output/PWM2 output.                                                                                                                   |
| RC2/CCP1                | 13          | 13           | I/O           | ST                     | RC2 can also be the Capture1 input/Compare1 output/<br>PWM1 output.                                                                                                                                          |
| RC3/SCK/SCL             | 14          | 14           | I/O           | ST                     | RC3 can also be the synchronous serial clock input/output for both SPI and I <sup>2</sup> C modes.                                                                                                           |
| RC4/SDI/SDA             | 15          | 15           | I/O           | ST                     | RC4 can also be the SPI Data In (SPI mode) or data I/O (I <sup>2</sup> C mode).                                                                                                                              |
| RC5/SDO                 | 16          | 16           | I/O           | ST                     | RC5 can also be the SPI Data Out (SPI mode).                                                                                                                                                                 |
| RC6/TX/CK               | 17          | 17           | I/O           | ST                     | RC6 can also be the USART Asynchronous Transmit of<br>Synchronous Clock.                                                                                                                                     |
| RC7/RX/DT               | 18          | 18           | I/O           | ST                     | RC7 can also be the USART Asynchronous Receive of<br>Synchronous Data.                                                                                                                                       |
| Vss                     | 8, 19       | 8, 19        | Р             | <u> </u>               | Ground reference for logic and I/O pins.                                                                                                                                                                     |
| VDD                     | 20          | 20           | P             | <u> </u>               | Positive supply for logic and I/O pins.                                                                                                                                                                      |
| Legend: I = input       | O = outp    |              |               | input/output           | P = power                                                                                                                                                                                                    |

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.

| 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 all<br>other resets<br>(2) |
|----------------------------|--------|---------------|-----------------|---------------|------------------|---------------|-----------------|---------------|----------|--------------------------|-------------------------------------|
| Bank 2                     |        | •             |                 |               |                  |               |                 |               |          |                          |                                     |
| 100h <sup>(4)</sup>        | INDF   | Addressing    | this location   | uses conter   | nts of FSR to a  | ddress data r | memory (not     | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 101h                       | TMR0   | Timer0 mod    | lule's registe  | r             |                  |               |                 |               |          | xxxx xxxx                | uuuu uuuu                           |
| 102h <sup>(4)</sup>        | PCL    | Program Co    | ounter's (PC)   | Least Signit  | ficant Byte      |               |                 |               |          | 0000 0000                | 0000 0000                           |
| 103h <sup>(4)</sup>        | STATUS | IRP           | RP1             | RP0           | TO               | PD            | z               | DC            | с        | 0001 1xxx                | 000q quuu                           |
| 104h <sup>(4)</sup>        | FSR    | Indirect data | a memory ad     | ldress pointe | )<br>Pr          |               |                 |               |          | xxxx xxxx                | uuuu uuuu                           |
| 105h                       | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | —                                   |
| 106h                       | PORTB  | PORTB Dat     | a Latch whe     | n written: PC | ORTB pins whe    | n read        |                 |               |          | xxxx xxxx                | uuuu uuuu                           |
| 107h                       | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | —                                   |
| 108h                       | —      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | _                                   |
| 109h                       | —      | Unimpleme     | Jnimplemented — |               |                  |               |                 |               |          | —                        | —                                   |
| 10Ah <b>(1,4)</b>          | PCLATH | -             | —               | —             | Write Buffer fo  | or the upper  | 5 bits of the I | Program Cou   | Inter    | 0 0000                   | 0 0000                              |
| 10Bh <b><sup>(4)</sup></b> | INTCON | GIE           | PEIE            | TOIE          | INTE             | RBIE          | TOIF            | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 10Ch-<br>10Fh              | _      | Unimpleme     | nted            |               |                  | •             |                 |               | •        | _                        | _                                   |
| Bank 3                     |        |               |                 |               |                  |               |                 |               |          |                          |                                     |
| 180h <sup>(4)</sup>        | INDF   | Addressing    | this location   | uses conter   | nts of FSR to ad | ddress data r | nemory (not     | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 181h                       | OPTION | RBPU          | INTEDG          | TOCS          | TOSE             | PSA           | PS2             | PS1           | PS0      | 1111 1111                | 1111 1111                           |
| 182h <sup>(4)</sup>        | PCL    | Program Co    | ounter's (PC)   | Least Sigr    | nificant Byte    | •             |                 |               | •        | 0000 0000                | 0000 0000                           |
| 183h <sup>(4)</sup>        | STATUS | IRP           | RP1             | RP0           | TO               | PD            | z               | DC            | с        | 0001 1xxx                | 000q quuu                           |
| 184h <sup>(4)</sup>        | FSR    | Indirect data | a memory ad     | ldress pointe | )<br>Pr          |               |                 |               |          | xxxx xxxx                | uuuu uuuu                           |
| 185h                       | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | —                                   |
| 186h                       | TRISB  | PORTB Dat     | a Direction F   | Register      |                  |               |                 |               |          | 1111 1111                | 1111 1111                           |
| 187h                       | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | —                                   |
| 188h                       | —      | Unimpleme     | nted            |               |                  |               |                 |               |          | —                        | —                                   |
| 189h                       | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | —                        | —                                   |
| 18Ah <b>(1,4)</b>          | PCLATH | -             | —               | —             | Write Buffer fo  | or the upper  | 5 bits of the I | Program Cou   | unter    | 0 0000                   | 0 0000                              |
| 18Bh <b><sup>(4)</sup></b> | INTCON | GIE           | PEIE            | TOIE          | INTE             | RBIE          | TOIF            | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 18Ch-<br>18Fh              | _      | Unimpleme     | nted            |               |                  |               |                 |               |          | _                        | _                                   |

TABLE 4-3: PIC16C76/77 SPECIAL FUNCTION REGISTER SUMMARY (Cont.'d)

 $\label{eq:legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented read as '0'.$  Shaded locations are unimplemented, read as '0'.

Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8> whose contents are transferred to the upper byte of the program counter.

2: Other (non power-up) resets include external reset through MCLR and Watchdog Timer Reset.

3: Bits PSPIE and PSPIF are reserved on the PIC16C76, always maintain these bits clear.

4: These registers can be addressed from any bank.

5: PORTD and PORTE are not physically implemented on the PIC16C76, read as '0'.

4.2.2.4 PIE1 REGISTER

Applicable Devices

72 73 73A 74 74A 76 77

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

This register contains the individual enable bits for the peripheral interrupts.

#### FIGURE 4-10: PIE1 REGISTER PIC16C72 (ADDRESS 8Ch)

| U-0      | R/W-0                                                                                                                                                 | U-0                                                                                                                            | U-0         | R/W-0 | R/W-0  | R/W-0  | R/W-0  |                                                                                                                        |  |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|-------|--------|--------|--------|------------------------------------------------------------------------------------------------------------------------|--|--|--|
|          | ADIE                                                                                                                                                  | —                                                                                                                              | —           | SSPIE | CCP1IE | TMR2IE | TMR1IE | R = Readable bit                                                                                                       |  |  |  |
| bit7     |                                                                                                                                                       |                                                                                                                                |             |       |        |        | bitO   | <ul> <li>W = Writable bit</li> <li>U = Unimplemented bit,<br/>read as '0'</li> <li>- n = Value at POR reset</li> </ul> |  |  |  |
| bit 7:   | Unimpler                                                                                                                                              | nented: R                                                                                                                      | lead as '0' |       |        |        |        |                                                                                                                        |  |  |  |
| bit 6:   | 1 = Enabl                                                                                                                                             | DIE: A/D Converter Interrupt Enable bit<br>= Enables the A/D interrupt<br>= Disables the A/D interrupt                         |             |       |        |        |        |                                                                                                                        |  |  |  |
| bit 5-4: | Unimpler                                                                                                                                              | nented: R                                                                                                                      | ead as '0'  |       |        |        |        |                                                                                                                        |  |  |  |
| bit 3:   | 1 = Enabl                                                                                                                                             | <b>SSPIE</b> : Synchronous Serial Port Interrupt Enable bit<br>1 = Enables the SSP interrupt<br>0 = Disables the SSP interrupt |             |       |        |        |        |                                                                                                                        |  |  |  |
| bit 2:   | 1 = Enabl                                                                                                                                             | <b>CCP1IE</b> : CCP1 Interrupt Enable bit<br>1 = Enables the CCP1 interrupt<br>0 = Disables the CCP1 interrupt                 |             |       |        |        |        |                                                                                                                        |  |  |  |
| bit 1:   | <b>TMR2IE</b> : TMR2 to PR2 Match Interrupt Enable bit<br>1 = Enables the TMR2 to PR2 match interrupt<br>0 = Disables the TMR2 to PR2 match interrupt |                                                                                                                                |             |       |        |        |        |                                                                                                                        |  |  |  |
| bit 0:   | <b>TMR1IE</b> : TMR1 Overflow Interrupt Enable bit<br>1 = Enables the TMR1 overflow interrupt<br>0 = Disables the TMR1 overflow interrupt             |                                                                                                                                |             |       |        |        |        |                                                                                                                        |  |  |  |

|  | TABLE 5-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 all other resets |
|-----------|--------|-------|------------------------------|-------|-------|-------|-------|-------|-------|--------------------------|---------------------------|
| 06h, 106h | PORTB  | RB7   | RB6                          | RB5   | RB4   | RB3   | RB2   | RB1   | RB0   | xxxx xxxx                | uuuu uuuu                 |
| 86h, 186h | TRISB  | PORTB | ORTB Data Direction Register |       |       |       |       |       |       | 1111 1111                | 1111 1111                 |
| 81h, 181h | OPTION | RBPU  | INTEDG                       | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111                | 1111 1111                 |

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

# 5.5 PORTE and TRISE Register Applicable Devices 72/73/73A/74/74A/76/77

PORTE has three pins RE0/RD/AN5, RE1/WR/AN6 and RE2/CS/AN7, which are individually configurable as inputs or outputs. These pins have Schmitt Trigger input buffers.

I/O PORTE becomes control inputs for the microprocessor port when bit PSPMODE (TRISE<4>) is set. In this mode, the user must make sure that the TRISE<2:0> bits are set (pins are configured as digital inputs) and that register ADCON1 is configured for digital I/O. In this mode the input buffers are TTL.

Figure 5-9 shows the TRISE register, which also controls the parallel slave port operation.

PORTE pins are multiplexed with analog inputs. The operation of these pins is selected by control bits in the ADCON1 register. When selected as an analog input, these pins will read as '0's.

TRISE controls the direction of the RE pins, even when they are being used as analog inputs. The user must make sure to keep the pins configured as inputs when using them as analog inputs.



### FIGURE 5-8: PORTE BLOCK DIAGRAM (IN I/O PORT MODE)



#### FIGURE 5-9: TRISE REGISTER (ADDRESS 89h)

|             | <b>D</b> 0                                                                | D AAA A     | <b>D</b> 444 a                                      |             |             | <b>D</b> 444 4 | <b>D</b> 444 4 |                                                                                                                                                  |  |  |
|-------------|---------------------------------------------------------------------------|-------------|-----------------------------------------------------|-------------|-------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R-0         | R-0                                                                       | R/W-0       | R/W-0                                               | U-0         | R/W-1       | R/W-1          | R/W-1          |                                                                                                                                                  |  |  |
| IBF<br>bit7 | OBF                                                                       | IBOV        | PSPMODE                                             | _           | bit2        | bit1           | bit0<br>bit0   | <ul> <li>R = Readable bit</li> <li>W = Writable bit</li> <li>U = Unimplemented bit,<br/>read as '0'</li> <li>- n = Value at POR reset</li> </ul> |  |  |
| bit 7 :     |                                                                           |             |                                                     |             |             |                |                |                                                                                                                                                  |  |  |
| bit 6:      | 1 = The ou                                                                | tput buffer | ull Status bit<br>still holds a pi<br>has been read |             | ritten word |                |                |                                                                                                                                                  |  |  |
| bit 5:      |                                                                           | occurred    |                                                     |             |             | ,              | (must be cle   | ared in software)                                                                                                                                |  |  |
| bit 4:      | PSPMODE<br>1 = Paralle<br>0 = Genera                                      | I slave por |                                                     | de Select b | bit         |                |                |                                                                                                                                                  |  |  |
| bit 3:      | Unimplem                                                                  | ented: Re   | ad as '0'                                           |             |             |                |                |                                                                                                                                                  |  |  |
| bit 2:      |                                                                           | tion Contro | ction Bits<br>ol bit for pin RI                     | E2/CS/AN7   | 7           |                |                |                                                                                                                                                  |  |  |
| bit 1:      | Bit1: Direction Control bit for pin RE1/WR/AN6<br>1 = Input<br>0 = Output |             |                                                     |             |             |                |                |                                                                                                                                                  |  |  |
| bit 0:      | <b>Bit0</b> : Direc<br>1 = Input<br>0 = Output                            |             | ol bit for pin RI                                   | E0/RD/AN    | 5           |                |                |                                                                                                                                                  |  |  |

#### FIGURE 9-2: T2CON: TIMER2 CONTROL REGISTER (ADDRESS 12h)

| U-0      | R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0                                                                                                     |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| <u> </u> | TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 R = Readable bit                                                                 |  |
| bit7     | bit0<br>W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>- n = Value at POR reset                                           |  |
| bit 7:   | Unimplemented: Read as '0'                                                                                                              |  |
| bit 6-3: | TOUTPS3:TOUTPS0: Timer2 Output Postscale Select bits<br>0000 = 1:1 Postscale<br>0001 = 1:2 Postscale<br>•<br>•<br>1111 = 1:16 Postscale |  |
| bit 2:   | TMR2ON: Timer2 On bit<br>1 = Timer2 is on<br>0 = Timer2 is off                                                                          |  |
| bit 1-0: | <b>T2CKPS1:T2CKPS0</b> : Timer2 Clock Prescale Select bits<br>00 = Prescaler is 1<br>01 = Prescaler is 4<br>1x = Prescaler is 16        |  |

#### **TABLE 9-1: REGISTERS ASSOCIATED WITH TIMER2 AS A TIMER/COUNTER**

| 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                     | TOIE                | INTE                | RBIE    | TOIF   | INTF    | RBIF    | 0000 000x                | 0000 000u                       |
| 0Ch                   | PIR1   | PSPIF <sup>(1,2)</sup> | ADIF                     | RCIF <sup>(2)</sup> | TXIF <sup>(2)</sup> | SSPIF   | CCP1IF | TMR2IF  | TMR1IF  | 0000 0000                | 0000 0000                       |
| 8Ch                   | PIE1   | PSPIE <sup>(1,2)</sup> | ADIE                     | RCIE <sup>(2)</sup> | TXIE <sup>(2)</sup> | SSPIE   | CCP1IE | TMR2IE  | TMR1IE  | 0000 0000                | 0000 0000                       |
| 11h                   | TMR2   | Timer2 mod             | Fimer2 module's register |                     |                     |         |        |         |         | 0000 0000                | 0000 0000                       |
| 12h                   | T2CON  | _                      | TOUTPS3                  | TOUTPS2             | TOUTPS1             | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000 0000                | -000 0000                       |
| 92h                   | PR2    | Timer2 Peri            | imer2 Period Register    |                     |                     |         |        |         |         | 1111 1111                | 1111 1111                       |

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

 Note
 1:
 Bits PSPIE and PSPIF are reserved on the PIC16C73/73A/76, always maintain these bits clear.

 2:
 The PIC16C72 does not have a Parallel Slave Port or a USART, these bits are unimplemented, read as '0'.

#### 14.5.1 INT INTERRUPT

External interrupt on RB0/INT pin is edge triggered: either rising if bit INTEDG (OPTION<6>) is set, or falling, if the INTEDG bit is clear. When a valid edge appears on the RB0/INT pin, flag bit INTF (INTCON<1>) is set. This interrupt can be disabled by clearing enable bit INTE (INTCON<4>). Flag bit INTF must be cleared in software in the interrupt service routine before re-enabling this interrupt. The INT interrupt can wake-up the processor from SLEEP, if bit INTE was set prior to going into SLEEP. The status of global interrupt enable bit GIE decides whether or not the processor branches to the interrupt vector following wake-up. See Section 14.8 for details on SLEEP mode.

#### 14.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set flag bit T0IF (INTCON<2>). The interrupt can be enabled/disabled by setting/clearing enable bit T0IE (INTCON<5>). (Section 7.0)

#### 14.5.3 PORTB INTCON CHANGE

An input change on PORTB<7:4> sets flag bit RBIF (INTCON<0>). The interrupt can be enabled/disabled by setting/clearing enable bit RBIE (INTCON<4>). (Section 5.2)

| Note: | For the PIC16C73/74, if a change on the      |
|-------|----------------------------------------------|
|       | I/O pin should occur when the read opera-    |
|       | tion is being executed (start of the Q2      |
|       | cycle), then the RBIF interrupt flag may not |
|       | get set.                                     |

#### 14.6 <u>Context Saving During Interrupts</u> Applicable Devices

#### 72 73 73A 74 74A 76 77

During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt i.e., W register and STATUS register. This will have to be implemented in software.

Example 14-1 stores and restores the STATUS, W, and PCLATH registers. The register, W\_TEMP, must be defined in each bank and must be defined at the same offset from the bank base address (i.e., if W\_TEMP is defined at 0x20 in bank 0, it must also be defined at 0xA0 in bank 1).

The example:

- a) Stores the W register.
- b) Stores the STATUS register in bank 0.
- c) Stores the PCLATH register.
- d) Executes the ISR code.
- e) Restores the STATUS register (and bank select bit).
- f) Restores the W and PCLATH registers.

#### EXAMPLE 14-1: SAVING STATUS, W, AND PCLATH REGISTERS IN RAM

| MOVWF<br>SWAPF<br>CLRF | W_TEMP<br>STATUS,W<br>STATUS | ;Copy W to TEMP register, could be bank one or zero<br>;Swap status to be saved into W<br>;bank 0, regardless of current bank, Clears IRP,RP1,RP0 |
|------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| MOVWF                  | STATUS_TEMP                  | ;Save status to bank zero STATUS_TEMP register                                                                                                    |
| MOVF                   | PCLATH, W                    | ;Only required if using pages 1, 2 and/or 3                                                                                                       |
| MOVWF                  | PCLATH_TEMP                  | ;Save PCLATH into W                                                                                                                               |
| CLRF                   | PCLATH                       | ;Page zero, regardless of current page                                                                                                            |
| BCF                    | STATUS, IRP                  | ;Return to Bank 0                                                                                                                                 |
| MOVF                   | FSR, W                       | ;Copy FSR to W                                                                                                                                    |
| MOVWF                  | FSR_TEMP                     | ;Copy FSR from W to FSR_TEMP                                                                                                                      |
| :                      |                              |                                                                                                                                                   |
| :(ISR)                 |                              |                                                                                                                                                   |
| :                      |                              |                                                                                                                                                   |
| MOVF                   | PCLATH_TEMP, W               | ;Restore PCLATH                                                                                                                                   |
| MOVWF                  | PCLATH                       | ;Move W into PCLATH                                                                                                                               |
| SWAPF                  | STATUS_TEMP,W                | ;Swap STATUS_TEMP register into W                                                                                                                 |
|                        |                              | ;(sets bank to original state)                                                                                                                    |
| MOVWF                  | STATUS                       | ;Move W into STATUS register                                                                                                                      |
| SWAPF                  | W_TEMP,F                     | ;Swap W_TEMP                                                                                                                                      |
| SWAPF                  | W_TEMP,W                     | ;Swap W_TEMP into W                                                                                                                               |
|                        |                              |                                                                                                                                                   |

## PIC16C7X

#### SLEEP

| [ label ]                                                                                                                                                  | SLEEP                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| None                                                                                                                                                       |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow WDT \mbox{ prescaler}, \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$ |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| TO, PD                                                                                                                                                     |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 00                                                                                                                                                         | 0000                                                                                                                                                                                                                        | 0110                                                                                                                                                                                                                                                                                            | 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| cleared. T<br>set. Watch<br>caler are<br>The proce<br>mode with                                                                                            | Time-out st<br>hdog Time<br>cleared.<br>essor is pu<br>n the oscill                                                                                                                                                         | tatus bit, T<br>er and its p<br>at into SLE<br>ator stopp                                                                                                                                                                                                                                       | Ō is<br>res-<br>EP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| 1                                                                                                                                                          |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 1                                                                                                                                                          |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Q1                                                                                                                                                         | Q2                                                                                                                                                                                                                          | Q3                                                                                                                                                                                                                                                                                              | Q4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| Decode                                                                                                                                                     | No-<br>Operation                                                                                                                                                                                                            | No-<br>Operation                                                                                                                                                                                                                                                                                | Go to<br>Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| SLEEP                                                                                                                                                      |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|                                                                                                                                                            | None<br>$00h \rightarrow V$<br>$0 \rightarrow WD$<br>$1 \rightarrow TO, D$<br>TO, PD<br>TO, PD<br>00<br>The power<br>cleared. T<br>set. Watcl<br>caler are<br>The proce<br>mode with<br>Section 1<br>1<br>1<br>Q1<br>Decode | None<br>00h → WDT,<br>0 → WDT presca<br>1 → TO,<br>0 → PD<br>TO, PD<br>00 0000<br>The power-down sta<br>cleared. Time-out sta<br>set. Watchdog Time<br>caler are cleared.<br>The processor is pur<br>mode with the oscill<br>Section 14.8 for mod<br>1<br>1<br>Q1 Q2<br>Decode No-<br>Operation | None         00h → WDT,         0 → WDT prescaler,         1 → TO,         0 → PD         TO, PD         00       0000         0100       0110         The power-down status bit, PI         cleared. Time-out status bit, T         set. Watchdog Timer and its p         caler are cleared.         The processor is put into SLE         mode with the oscillator stopp         Section 14.8 for more details.         1         Q1       Q2       Q3         Decode       No-       No-         Operation       Operation |  |  |  |  |

| SUBLW             | Subtract         | W from I                           | iteral                                       |              |  |  |  |  |  |
|-------------------|------------------|------------------------------------|----------------------------------------------|--------------|--|--|--|--|--|
| Syntax:           | [ label ]        | SUBLW                              | ′ k                                          |              |  |  |  |  |  |
| Operands:         | $0 \le k \le 25$ | $0 \le k \le 255$                  |                                              |              |  |  |  |  |  |
| Operation:        | k - (W) →        | $k \text{ - } (W) \rightarrow (W)$ |                                              |              |  |  |  |  |  |
| Status Affected:  | C, DC, Z         |                                    |                                              |              |  |  |  |  |  |
| Encoding:         | 11               | 110x                               | kkkk                                         | kkkk         |  |  |  |  |  |
| Description:      | ment meth        | nod) from th                       | ntracted (2's<br>ne eight bit<br>n the W reg | literal 'k'. |  |  |  |  |  |
| Words:            | 1                |                                    |                                              |              |  |  |  |  |  |
| Cycles:           | 1                |                                    |                                              |              |  |  |  |  |  |
| Q Cycle Activity: | Q1               | Q2                                 | Q3                                           | Q4           |  |  |  |  |  |
|                   | Decode           | Read<br>literal 'k'                | Process<br>data                              | Write to W   |  |  |  |  |  |
| Example 1:        | SUBLW            | 0x02                               |                                              |              |  |  |  |  |  |
|                   | Before In        | struction                          |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 1<br>?<br>?                                  |              |  |  |  |  |  |
|                   | After Inst       | ruction                            |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 1<br>1; result is<br>0                       | positive     |  |  |  |  |  |
| Example 2:        | Before In        | struction                          |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 2<br>?<br>?                                  |              |  |  |  |  |  |
|                   | After Inst       | ruction                            |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 0<br>1; result i<br>1                        | s zero       |  |  |  |  |  |
| Example 3:        | Before In        | struction                          |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 3<br>?<br>?                                  |              |  |  |  |  |  |
|                   | After Inst       | ruction                            |                                              |              |  |  |  |  |  |
|                   |                  | W =<br>C =<br>Z =                  | 0xFF<br>0; result is<br>0                    | negative     |  |  |  |  |  |

## PIC16C7X

Applicable Devices 72 73 73A 74 74A 76 77

#### 17.0 ELECTRICAL CHARACTERISTICS FOR PIC16C72

#### Absolute Maximum Ratings †

| 5.1                                                                                                             |                                        |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Ambient temperature under bias                                                                                  |                                        |
| 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 +14V                              |
| 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, Iк (VI < 0 or VI > VDD)                                                                    |                                        |
| Output clamp current, loк (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 and PORTB (combined)                                                              | 200 mA                                 |
| Maximum current sourced by PORTA and PORTB (combined)                                                           | 200 mA                                 |
| Maximum current sunk by PORTC                                                                                   | 200 mA                                 |
| Maximum current sourced by PORTC                                                                                | 200 mA                                 |
| <b>Note 1:</b> Power dissipation is calculated as follows: Pdis = VDD x {IDD - $\sum$ IOH} + $\sum$ {(VD        | d - Voh) x Ioh} + $\Sigma$ (Vol x Iol) |
| <b>Note 2:</b> Voltage spikes below Vss at the $\overline{\text{MCLR}}$ pin inducing currents greater than 80 m | nA may cause latch-up Thus             |

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

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

#### TABLE 17-1: CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES)

| osc | PIC16C72-04                                                                                                 | PIC16C72-10                                                                                                                                        | PIC16C72-20                                                                                                                                        | PIC16LC72-04                                                                                              | JW Devices                                                                                                |
|-----|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| RC  | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                    | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max.                                                        | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 µA typ. at 4V<br>Freq: 4 MHz max.                                                        | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 5.0 μA max. at 3V<br>Freq: 4 MHz max.               | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                  |
| хт  | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                    | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max.                                                        | VDD: 4.5V to 5.5V<br>IDD: 2.7 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max.                                                        | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 5.0 μA max. at 3V<br>Freq: 4 MHz max.               | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                  |
| HS  | VDD: 4.5V to 5.5V<br>IDD: 13.5 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 4 MHz max.              | VDD:         4.5V to 5.5V           IDD:         10 mA max. at 5.5V           IPD:         1.5 μA typ. at 4.5V           Freq:         10 MHz max. | VDD:         4.5V to 5.5V           IDD:         20 mA max. at 5.5V           IPD:         1.5 μA typ. at 4.5V           Freq:         20 MHz max. | Not recommended for use<br>in HS mode                                                                     | VDD: 4.5V to 5.5V<br>IDD: 20 mA max. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 20 MHz max.             |
| LP  | VDD: 4.0V to 6.0V<br>IDD: 52.5 μA typ. at<br>32 kHz, 4.0V<br>IPD: 0.9 μA typ. at 4.0V<br>Freq: 200 kHz max. | Not recommended for use<br>in LP mode                                                                                                              | Not recommended for use<br>in LP mode                                                                                                              | VDD: 2.5V to 6.0V<br>IDD: 48 μA max. at<br>32 kHz, 3.0V<br>IPD: 5.0 μA max. at 3.0V<br>Freq: 200 kHz max. | VDD: 2.5V to 6.0V<br>IDD: 48 μA max. at<br>32 kHz, 3.0V<br>IPD: 5.0 μA max. at 3.0V<br>Freq: 200 kHz max. |

The shaded sections indicate oscillator selections which are tested for functionality, but not for MIN/MAX specifications.

It is recommended that the user select the device type that ensures the specifications required.

#### Applicable Devices 72 73 73A 74 74A 76 77

#### 18.1 DC Characteristics: PIC16C73/74-04 (Commercial, Industrial) PIC16C73/74-10 (Commercial, Industrial) PIC16C73/74-20 (Commercial, Industrial)

| DC CH                 | ARACTERISTICS                                                    |      | <b>Standa</b><br>Operat | -                  |                | ure -4         | itions (unless otherwise stated) $10^{\circ}C$ $\leq TA \leq +85^{\circ}C$ for industrial and $C$ $\leq TA \leq +70^{\circ}C$ for commercial                                                  |
|-----------------------|------------------------------------------------------------------|------|-------------------------|--------------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param<br>No.          | Characteristic                                                   | Sym  | Min                     | Тур†               | Max            | Units          | Conditions                                                                                                                                                                                    |
| D001<br>D001A         | Supply Voltage                                                   | Vdd  | 4.0<br>4.5              |                    | 6.0<br>5.5     | V<br>V         | XT, RC and LP osc configuration<br>HS osc configuration                                                                                                                                       |
| D002*                 | RAM Data Retention<br>Voltage (Note 1)                           | Vdr  | -                       | 1.5                | -              | V              |                                                                                                                                                                                               |
| D003                  | VDD start voltage to<br>ensure internal Power-on<br>Reset signal | VPOR | -                       | Vss                | -              | V              | See section on Power-on Reset for details                                                                                                                                                     |
| D004*                 | VDD rise rate to ensure<br>internal Power-on Reset<br>signal     | SVDD | 0.05                    | -                  | -              | V/ms           | See section on Power-on Reset for details                                                                                                                                                     |
| D010                  | Supply Current (Note 2,5)                                        | IDD  | -                       | 2.7                | 5              | mA             | XT, RC osc configuration<br>Fosc = 4 MHz, VDD = 5.5V (Note 4)                                                                                                                                 |
| D013                  |                                                                  |      | -                       | 13.5               | 30             | mA             | HS osc configuration<br>Fosc = 20 MHz, VDD = 5.5V                                                                                                                                             |
| D020<br>D021<br>D021A | Power-down Current<br>(Note 3,5)                                 | IPD  | -<br>-<br>-             | 10.5<br>1.5<br>1.5 | 42<br>21<br>24 | μΑ<br>μΑ<br>μΑ | $VDD = 4.0V$ , WDT enabled, $-40^{\circ}C$ to $+85^{\circ}C$<br>$VDD = 4.0V$ , WDT disabled, $-0^{\circ}C$ to $+70^{\circ}C$<br>$VDD = 4.0V$ , WDT disabled, $-40^{\circ}C$ to $+85^{\circ}C$ |

\* 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: 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 and 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 tristated, pulled to VDD

 $\overline{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 hi-impedance state and tied to VbD 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 kOhm.

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.

| Applic<br>19.3                                                                                                                                                    | 9.3 DC Characteristics: PIC16C73A/74A-04 (Commercial, Industrial, Extended)<br>PIC16C73A/74A-10 (Commercial, Industrial, Extended)<br>PIC16C73A/74A-20 (Commercial, Industrial, Extended)<br>PIC16LC73A/74A-04 (Commercial, Industrial)                                                                                                                                                                   |       |                          |          |                  |          |                                                                                           |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------|----------|------------------|----------|-------------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                                                                                                   | Standard Operating Conditions (unless otherwise stated)<br>Operating temperature $-40^{\circ}C$ $\leq Ta \leq +125^{\circ}C$ for extended,<br>$-40^{\circ}C$ $-40^{\circ}C$ $\leq Ta \leq +85^{\circ}C$ for industrial and<br>$-40^{\circ}C$ $= 40^{\circ}C$ $\leq Ta \leq +85^{\circ}C$ for industrial and<br>$-40^{\circ}C$ $= 40^{\circ}C$ $\leq Ta \leq +85^{\circ}C$ for extended,<br>$-40^{\circ}C$ |       |                          |          |                  |          |                                                                                           |  |  |  |  |
| DC CHARACTERISTICS $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial<br>Operating voltage VDD range as described in DC spec Section 19.1 and<br>Section 19.2. |                                                                                                                                                                                                                                                                                                                                                                                                           |       |                          |          |                  |          |                                                                                           |  |  |  |  |
| Param<br>No.                                                                                                                                                      | Characteristic                                                                                                                                                                                                                                                                                                                                                                                            | Sym   | Min                      | Тур<br>† | Max              | Units    | Conditions                                                                                |  |  |  |  |
|                                                                                                                                                                   | Input Low Voltage                                                                                                                                                                                                                                                                                                                                                                                         | VIL   |                          |          |                  |          |                                                                                           |  |  |  |  |
| D030<br>D030A                                                                                                                                                     | with TTL buffer                                                                                                                                                                                                                                                                                                                                                                                           |       | Vss<br>Vss               | -        | 0.15Vdd<br>0.8V  |          | For entire VDD range $4.5V \le VDD \le 5.5V$                                              |  |  |  |  |
| D031<br>D032                                                                                                                                                      | with Schmitt Trigger buffer<br>MCLR, OSC1 (in RC mode)                                                                                                                                                                                                                                                                                                                                                    |       | Vss<br>Vss               | -        | 0.2VDD<br>0.2VDD | V<br>V   | Neder                                                                                     |  |  |  |  |
| D033                                                                                                                                                              | OSC1 (in XT, HS and LP) Input High Voltage                                                                                                                                                                                                                                                                                                                                                                | Ин    | Vss                      | -        | 0.3Vdd           | V        | Note1                                                                                     |  |  |  |  |
| D040<br>D040A                                                                                                                                                     | I/O ports<br>with TTL buffer                                                                                                                                                                                                                                                                                                                                                                              | VIH   | 2.0<br>0.25VDD<br>+ 0.8V | -        | Vdd<br>Vdd       | V<br>V   | $4.5V \le VDD \le 5.5V$<br>For entire VDD range                                           |  |  |  |  |
| D041<br>D042                                                                                                                                                      | with Schmitt Trigger buffer                                                                                                                                                                                                                                                                                                                                                                               |       | 0.8Vdd<br>0.8Vdd         | -        | Vdd<br>Vdd       | V<br>V   | For entire VDD range                                                                      |  |  |  |  |
| D042A<br>D043                                                                                                                                                     | OSC1 (XT, HS and LP)<br>OSC1 (in RC mode)                                                                                                                                                                                                                                                                                                                                                                 |       | 0.7VDD<br>0.9VDD         | -        | VDD<br>VDD       | V<br>V   | Note1                                                                                     |  |  |  |  |
| D070                                                                                                                                                              | PORTB weak pull-up current Input Leakage Current                                                                                                                                                                                                                                                                                                                                                          | IPURB | 50                       | 250      | 400              | μA       | VDD = 5V, VPIN = VSS                                                                      |  |  |  |  |
| D060                                                                                                                                                              | (Notes 2, 3)<br>I/O ports                                                                                                                                                                                                                                                                                                                                                                                 | lı∟   | -                        | -        | ±1               | μA       | Vss $\leq$ VPIN $\leq$ VDD, Pin at hi-impedance                                           |  |  |  |  |
| D061<br>D063                                                                                                                                                      | MCLR, RA4/T0CKI<br>OSC1                                                                                                                                                                                                                                                                                                                                                                                   |       | -                        | -        | ±5<br>±5         | μΑ<br>μΑ | Vss $\leq$ VPIN $\leq$ VDD<br>Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |  |  |  |
| D080                                                                                                                                                              | Output Low Voltage<br>I/O ports                                                                                                                                                                                                                                                                                                                                                                           | Vol   | -                        | -        | 0.6              | V        | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C                                               |  |  |  |  |
| D080A                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                           |       | -                        | -        | 0.6              | V        | IOL = 7.0  mA,  VDD = 4.5 V,<br>-40°C to +125°C                                           |  |  |  |  |
| D083                                                                                                                                                              | OSC2/CLKOUT (RC osc config)                                                                                                                                                                                                                                                                                                                                                                               |       | -                        | -        | 0.6              | V        | lOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C                                               |  |  |  |  |
| D083A                                                                                                                                                             | These parameters are characteriz                                                                                                                                                                                                                                                                                                                                                                          |       | -                        | -        | 0.6              | V        | IOL = 1.2 mA, VDD = 4.5V,<br>-40°C to +125°C                                              |  |  |  |  |

† 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 PIC16C7X 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.

Applicable Devices 72 73 73A 74 74A 76 77



### FIGURE 19-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING

#### FIGURE 19-5: BROWN-OUT RESET TIMING



### TABLE 19-4: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 +125°C |
| 31*              | Twdt  | Watchdog Timer Time-out Period<br>(No Prescaler)       | 7   | 18       | 33  | ms    | VDD = 5V, -40°C to +125°C |
| 32               | Tost  | Oscillation Start-up Timer Period                      | _   | 1024Tosc | _   | —     | Tosc = OSC1 period        |
| 33*              | Tpwrt | Power up Timer Period                                  | 28  | 72       | 132 | ms    | VDD = 5V, -40°C to +125°C |
| 34               | Tioz  | I/O Hi-impedance from MCLR Low or Watchdog Timer Reset | _   | _        | 2.1 | μs    |                           |
| 35               | TBOR  | Brown-out Reset pulse width                            | 100 |          | _   | μs    | $VDD \le BVDD$ (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.

#### Applicable Devices 72 73 73A 74 74A 76 77

#### FIGURE 19-8: PARALLEL SLAVE PORT TIMING (PIC16C74A)



#### TABLE 19-7: PARALLEL SLAVE PORT REQUIREMENTS (PIC16C74A)

| Parameter<br>No. | Sym      | Characteristic                                                                          | Min                                                                         | Тур† | Max | Units    | Conditions |                        |
|------------------|----------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------|-----|----------|------------|------------------------|
| 62               | TdtV2wrH | Data in valid before $\overline{WR}\uparrow$ or $\overline{CS}\uparrow$ (setup tir      | efore $\overline{WR}^{\uparrow}$ or $\overline{CS}^{\uparrow}$ (setup time) |      |     |          | ns<br>ns   | Extended<br>Range Only |
| 63*              | TwrH2dtl | $\overline{WR}^{\uparrow}$ or $\overline{CS}^{\uparrow}$ to data–in invalid (hold time) | PIC16 <b>C</b> 74A                                                          | 20   | —   | —        | ns         |                        |
|                  |          |                                                                                         | PIC16 <b>LC</b> 74A                                                         | 35   | —   | -        | ns         |                        |
| 64               | TrdL2dtV | $\overline{RD}\downarrow$ and $\overline{CS}\downarrow$ to data–out valid               | to data–out valid                                                           |      | _   | 80<br>90 | ns<br>ns   | Extended<br>Range Only |
| 65               | TrdH2dtl | $\overline{RD}$ or $\overline{CS}$ to data–out invalid                                  |                                                                             | 10   | —   | 30       | 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.

## PIC16C7X

#### Applicable Devices 72 73 73A 74 74A 76 77



#### FIGURE 20-17: A/D CONVERSION TIMING

#### TABLE 20-14: A/D CONVERSION REQUIREMENTS

| Param<br>No. | Sym  | Characteristic                                       |                              | Min    | Тур†     | Мах | Units | Conditions                                                                                                                                                                                                                    |
|--------------|------|------------------------------------------------------|------------------------------|--------|----------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 130          | TAD  | A/D clock period                                     | PIC16 <b>C</b> 76/77         | 1.6    | _        | _   | μs    | Tosc based, VREF ≥ 3.0V                                                                                                                                                                                                       |
|              |      |                                                      | PIC16LC76/77                 | 2.0    | —        |     | μs    | Tosc based, VREF full range                                                                                                                                                                                                   |
|              |      |                                                      | PIC16 <b>C</b> 76/77         | 2.0    | 4.0      | 6.0 | μs    | A/D RC Mode                                                                                                                                                                                                                   |
|              |      |                                                      | PIC16LC76/77                 | 3.0    | 6.0      | 9.0 | μs    | A/D RC Mode                                                                                                                                                                                                                   |
| 131          | TCNV | Conversion time (not including S/H time)<br>(Note 1) |                              | _      | 9.5      | _   | TAD   |                                                                                                                                                                                                                               |
| 132          | TACQ | Acquisition time                                     |                              | Note 2 | 20       |     | μs    |                                                                                                                                                                                                                               |
|              |      |                                                      |                              | 5*     | _        | _   | μs    | The minimum time is the amplifier<br>settling time. This may be used if<br>the "new" input voltage has not<br>changed by more than 1 LSb (i.e.,<br>20.0 mV @ 5.12V) from the last<br>sampled voltage (as stated on<br>CHOLD). |
| 134          | TGO  | Q4 to A/D clock start                                |                              | _      | Tosc/2 § | _   | -     | If the A/D clock source is selected<br>as RC, a time of TcY is added<br>before the A/D clock starts. This<br>allows the SLEEP instruction to be<br>executed.                                                                  |
| 135          | Tswc | Switching from conve                                 | $rt \rightarrow sample time$ | 1.5 §  | _        |     | TAD   |                                                                                                                                                                                                                               |

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

§ This specification ensured by design.

Note 1: ADRES register may be read on the following TCY cycle.

2: See Section 13.1 for min conditions.

## Applicable Devices 72 73 73 74 74 76 77 FIGURE 21-16: TYPICAL IDD vs. FREQUENCY (RC MODE @ 300 pF, 25°C)



FIGURE 21-17: MAXIMUM IDD vs. FREQUENCY (RC MODE @ 300 pF, -40°C TO 85°C)



Data based on matrix samples. See first page of this section for details.

#### Package Marking Information (Cont'd)

#### 40-Lead PDIP



40-Lead CERDIP Windowed



#### 44-Lead PLCC



#### 44-Lead MQFP



Example



Example



#### Example



#### Example



| Legend: | MMM<br>XXX<br>AA<br>BB<br>C | Microchip part number information<br>Customer specific information*<br>Year code (last 2 digits of calender year)<br>Week code (week of January 1 is week '01')<br>Facility code of the plant at which wafer is manufactured.<br>C = Chandler, Arizona, U.S.A.<br>S = Tempe, Arizona, U.S.A. |
|---------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | D <sub>1</sub>              | Mask revision number for microcontroller                                                                                                                                                                                                                                                     |
|         | E                           | Assembly code of the plant or country of origin in which part was assembled.                                                                                                                                                                                                                 |
| Note:   | line, it will               | nt the full Microchip part number cannot be marked on one<br>be carried over to the next line thus limiting the number of<br>characters for customer specific information.                                                                                                                   |

\* Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask revision number, and assembly code. For OTP 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.

#### E.3 PIC16C15X Family of Devices

|             |                                         | PIC16C154                           | PIC16CR154                          | PIC16C156                           | PIC16CR156                          | PIC16C158                           | PIC16CR158                          |
|-------------|-----------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| Clock       | Maximum Frequency<br>of Operation (MHz) | 20                                  | 20                                  | 20                                  | 20                                  | 20                                  | 20                                  |
|             | EPROM Program Memory<br>(x12 words)     | 512                                 |                                     | 1K                                  |                                     | 2К                                  |                                     |
| Memory      | ROM Program Memory<br>(x12 words)       | -                                   | 512                                 | —                                   | 1K                                  | —                                   | 2К                                  |
|             | RAM Data Memory (bytes)                 | 25                                  | 25                                  | 25                                  | 25                                  | 73                                  | 73                                  |
| Peripherals | Timer Module(s)                         | TMR0                                | TMR0                                | TMR0                                | TMR0                                | TMR0                                | TMR0                                |
|             | I/O Pins                                | 12                                  | 12                                  | 12                                  | 12                                  | 12                                  | 12                                  |
|             | Voltage Range (Volts)                   | 3.0-5.5                             | 2.5-5.5                             | 3.0-5.5                             | 2.5-5.5                             | 3.0-5.5                             | 2.5-5.5                             |
| Features    | Number of Instructions                  | 33                                  | 33                                  | 33                                  | 33                                  | 33                                  | 33                                  |
|             | Packages                                | 18-pin DIP,<br>SOIC;<br>20-pin SSOP |

All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability.

#### E.4 PIC16C5X Family of Devices

|             |                                         | PIC16C52            | PIC16C54                            | PIC16C54A                           | PIC16CR54A                          | PIC16C55                     | PIC16C56                            |
|-------------|-----------------------------------------|---------------------|-------------------------------------|-------------------------------------|-------------------------------------|------------------------------|-------------------------------------|
| Clock       | Maximum Frequency<br>of Operation (MHz) | 4                   | 20                                  | 20                                  | 20                                  | 20                           | 20                                  |
|             | EPROM Program Memory<br>(x12 words)     | 384                 | 512                                 | 512                                 | —                                   | 512                          | 1K                                  |
| Memory      | ROM Program Memory<br>(x12 words)       | -                   | —                                   | —                                   | 512                                 | —                            | —                                   |
|             | RAM Data Memory (bytes)                 | 25                  | 25                                  | 25                                  | 25                                  | 24                           | 25                                  |
| Peripherals | Timer Module(s)                         | TMR0                | TMR0                                | TMR0                                | TMR0                                | TMR0                         | TMR0                                |
|             | I/O Pins                                | 12                  | 12                                  | 12                                  | 12                                  | 20                           | 12                                  |
|             | Voltage Range (Volts)                   | 2.5-6.25            | 2.5-6.25                            | 2.0-6.25                            | 2.0-6.25                            | 2.5-6.25                     | 2.5-6.25                            |
| Features    | Number of Instructions                  | 33                  | 33                                  | 33                                  | 33                                  | 33                           | 33                                  |
|             | Packages                                | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 28-pin DIP,<br>SOIC,<br>SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP |

|             |                                         | PIC16C57                     | PIC16CR57B                | PIC16C58A                        | PIC16CR58A                       |
|-------------|-----------------------------------------|------------------------------|---------------------------|----------------------------------|----------------------------------|
| Clock       | Maximum Frequency<br>of Operation (MHz) | 20                           | 20                        | 20                               | 20                               |
|             | EPROM Program Memory<br>(x12 words)     | 2K                           | -                         | 2К                               | —                                |
| Memory      | ROM Program Memory<br>(x12 words)       | -                            | 2К                        | —                                | 2K                               |
|             | RAM Data Memory (bytes)                 | 72                           | 72                        | 73                               | 73                               |
| Peripherals | Timer Module(s)                         | TMR0                         | TMR0                      | TMR0                             | TMR0                             |
|             | I/O Pins                                | 20                           | 20                        | 12                               | 12                               |
|             | Voltage Range (Volts)                   | 2.5-6.25                     | 2.5-6.25                  | 2.0-6.25                         | 2.5-6.25                         |
| Features    | Number of Instructions                  | 33                           | 33                        | 33                               | 33                               |
|             | Packages                                | 28-pin DIP,<br>SOIC,<br>SSOP | 28-pin DIP, SOIC,<br>SSOP | 18-pin DIP, SOIC;<br>20-pin SSOP | 18-pin DIP, SOIC;<br>20-pin SSOP |

All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer (except PIC16C52), selectable code protect and high I/O current capability.

#### E.8 PIC16C8X Family of Devices

|                  |                                         | PIC16F83            | PIC16CR83           | PIC16F84            | PIC16CR84           |
|------------------|-----------------------------------------|---------------------|---------------------|---------------------|---------------------|
| Clock            | Maximum Frequency<br>of Operation (MHz) | 10                  | 10                  | 10                  | 10                  |
|                  | Flash Program Memory                    | 512                 | -                   | 1K                  | —                   |
|                  | EEPROM Program Memory                   | —                   | —                   | —                   | _                   |
| Memory           | ROM Program Memory                      | —                   | 512                 | —                   | 1K                  |
|                  | Data Memory (bytes)                     | 36                  | 36                  | 68                  | 68                  |
|                  | Data EEPROM (bytes)                     | 64                  | 64                  | 64                  | 64                  |
| Peripher-<br>als | Timer Module(s)                         | TMR0                | TMR0                | TMR0                | TMR0                |
|                  | Interrupt Sources                       | 4                   | 4                   | 4                   | 4                   |
|                  | I/O Pins                                | 13                  | 13                  | 13                  | 13                  |
| Features         | Voltage Range (Volts)                   | 2.0-6.0             | 2.0-6.0             | 2.0-6.0             | 2.0-6.0             |
|                  | Packages                                | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC |

All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C8X Family devices use serial programming with clock pin RB6 and data pin RB7.

#### E.9 PIC16C9XX Family Of Devices

|             |                                                 | PIC16C923                                                    | PIC16C924                                                    |
|-------------|-------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|
| Clock       | Maximum Frequency of Operation (MHz)            | 8                                                            | 8                                                            |
| Memory      | EPROM Program Memory                            | 4K                                                           | 4K                                                           |
|             | Data Memory (bytes)                             | 176                                                          | 176                                                          |
|             | Timer Module(s)                                 | TMR0,<br>TMR1,<br>TMR2                                       | TMR0,<br>TMR1,<br>TMR2                                       |
|             | Capture/Compare/PWM Module(s)                   | 1                                                            | 1                                                            |
| Peripherals | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | SPI/I <sup>2</sup> C                                         | SPI/I <sup>2</sup> C                                         |
|             | Parallel Slave Port                             | _                                                            | —                                                            |
|             | A/D Converter (8-bit) Channels                  | —                                                            | 5                                                            |
|             | LCD Module                                      | 4 Com,<br>32 Seg                                             | 4 Com,<br>32 Seg                                             |
|             | Interrupt Sources                               | 8                                                            | 9                                                            |
|             | I/O Pins                                        | 25                                                           | 25                                                           |
|             | Input Pins                                      | 27                                                           | 27                                                           |
|             | Voltage Range (Volts)                           | 3.0-6.0                                                      | 3.0-6.0                                                      |
| Features    | In-Circuit Serial Programming                   | Yes                                                          | Yes                                                          |
|             | Brown-out Reset                                 | _                                                            | —                                                            |
|             | Packages                                        | 64-pin SDIP <sup>(1)</sup> ,<br>TQFP;<br>68-pin PLCC,<br>Die | 64-pin SDIP <sup>(1)</sup> ,<br>TQFP;<br>68-pin PLCC,<br>Die |

All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C9XX Family devices use serial programming with clock pin RB6 and data pin RB7.

#### PIC16C7X PRODUCT IDENTIFICATION SYSTEM

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



\* JW Devices are UV erasable and can be programmed to any device configuration. JW Devices meet the electrical requirement of each oscillator type (including LC devices).

#### Sales and Support

Products supported by a preliminary Data Sheet may possibly have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following:

- 1. The Microchip Website at www.microchip.com
- 2. Your local Microchip sales office (see following page)
- 3. The Microchip Corporate Literature Center U.S. FAX: (602) 786-7277
- 4. The Microchip's Bulletin Board, via your local CompuServe number (CompuServe membership NOT required).

Please specify which device, revision of silicon and Data Sheet (include Literature #) you are using.

For latest version information and upgrade kits for Microchip Development Tools, please call 1-800-755-2345 or 1-602-786-7302.