### 80C32/87C52

#### DESCRIPTION

The Philips 80C32/87C52 is a high-performance microcontroller fabricated with Philips high-density CMOS technology. The Philips CMOS technology combines the high speed and density characteristics of HMOS with the low power attributes of CMOS. Philips epitaxial substrate minimizes latch-up sensitivity.

The 87C52 contains an  $8k \times 8$  EPROM and the 80C32 is ROMless. Both contain a  $256 \times 8$  RAM, 32 I/O lines, three 16-bit counter/timers, a six-source, two-priority level nested interrupt structure, a serial I/O port for either multi-processor communications, I/O expansion or full duplex UART, and on-chip oscillator and clock circuits.

In addition, the 80C32/87C52 has two software selectable modes of power reduction—idle mode and power-down mode. The idle mode freezes the CPU while allowing the RAM, timers, serial port, and interrupt system to continue functioning. The power-down mode saves the RAM contents but freezes the oscillator, causing all other chip functions to be inoperative.

See 80C52/80C54/80C58 datasheet for ROM device specifications.

#### FEATURES

- 80C51 based architecture
- 8032 compatible
  - 8k × 8 EPROM (87C52)
  - ROMless (80C32)
  - 256 × 8 RAM
  - Three 16-bit counter/timers
  - Full duplex serial channel
  - Boolean processor
- Memory addressing capability
   64k ROM and 64k RAM
- Power control modes:
  - Idle mode
- Power-down mode
- CMOS and TTL compatible
- Three speed ranges:
  - 3.5 to 16MHz
  - 3.5 to 24MHz
  - 3.5 to 33MHz
- Five package styles
- Extended temperature ranges
- OTP package available

#### **PIN CONFIGURATIONS**



#### **ORDERING INFORMATION**

| ROMIess     | EPROM <sup>1</sup> |     | TEMPERATURE RANGE °C<br>AND PACKAGE      | FREQ<br>MHz | DRAWING<br>NUMBER |
|-------------|--------------------|-----|------------------------------------------|-------------|-------------------|
| P80C32EBP N | P87C52EBP N        | OTP | 0 to +70, Plastic Dual In-line Package   | 16          | SOT129-1          |
| P80C32EBA A | P87C52EBA A        | OTP | 0 to +70, Plastic Leaded Chip Carrier    | 16          | SOT187-2          |
|             | P87C52EBF FA       | UV  | 0 to +70, Ceramic Dual In-line Package   | 16          | 0590B             |
|             | P87C52EBL KA       | UV  | 0 to +70, Ceramic Leaded Chip Carrier    | 16          | 1472A             |
| P80C32EBB B | P87C52EBB B        | OTP | 0 to +70, Plastic Quad Flat Pack         | 16          | SOT307-2          |
| P80C32EFP N | P87C52EFP N        | OTP | -40 to +85, Plastic Dual In-line Package | 16          | SOT129-1          |
| P80C32EFA A | P87C52EFA A        | OTP | -40 to +85, Plastic Leaded Chip Carrier  | 16          | SOT187-2          |
|             | P87C52EFF FA       | UV  | -40 to +85, Ceramic Dual In-line Package | 16          | 0590B             |
| P80C32EFB B | P87C52EFB B        | OTP | -40 to +85, Plastic Quad Flat Pack       | 16          | SOT307-2          |
| P80C32IBP N | P87C52IBP N        | OTP | 0 to +70, Plastic Dual In-line Package   | 24          | SOT129-1          |
| P80C32IBA A | P87C52IBA A        | OTP | 0 to +70, Plastic Leaded Chip Carrier    | 24          | SOT187-2          |
| P80C32IBB B |                    |     | 0 to +70, Plastic Quad Flat Pack         | 24          | SOT307-2          |
|             | P87C52IBF FA       | UV  | 0 to +70, Ceramic Dual In-line Package   | 24          | 0590B             |
|             | P87C52IBL KA       | UV  | 0 to +70, Ceramic Leaded Chip Carrier    | 24          | 1472A             |
| P80C32IFP N | P87C52IFP N        | OTP | -40 to +85, Plastic Dual In-line Package | 24          | SOT129-1          |
| P80C32IFA A | P87C52IFA A        | OTP | -40 to +85, Plastic Leaded Chip Carrier  | 24          | SOT187-2          |
| P80C32IFB B |                    |     | -40 to +85, Plastic Quad Flat Pack       | 24          | SOT307-2          |
|             | P87C52IFF FA       | UV  | -40 to +85, Ceramic Dual In-line Package | 24          | 0590B             |
| P80C32NBA A |                    |     | 0 to +70, Plastic Leaded Chip Carrier    | 33          | SOT187-2          |
| P80C32NBP N |                    |     | 0 to +70, Plastic Dual In-line Package   | 33          | SOT129-1          |
| P80C32NBB B |                    |     | 0 to +70, Plastic Quad Flat Pack         | 33          | SOT307-2          |
| P80C32NFA A |                    |     | -40 to +85, Plastic Leaded Chip Carrier  | 33          | SOT187-2          |
| P80C32NFP N |                    |     | -40 to +85, Plastic Dual In-line Package | 33          | SOT129-1          |
| P80C32NFB B |                    |     | -40 to +85, Plastic Quad Flat Pack       | 33          | SOT307-2          |

#### NOTE:

OTP = One Time Programmable EPROM. UV = UV erasable EPROM
 For 33MHz ROM 80C52 operation, see 80C52/80C54/80C58 data sheet.

### 80C32/87C52

# CERAMIC AND PLASTIC LEADED CHIP CARRIER PIN FUNCTIONS



#### LOGIC SYMBOL



#### PLASTIC QUAD FLAT PACK PIN FUNCTIONS



### 80C32/87C52

#### **BLOCK DIAGRAM**



SYMBOL

RESET

VALUE

00H

00H

00H

M0

### CMOS single-chip 8-bit microcontrollers

DIRECT

ADDRESS

MSB

### 80C32/87C52

LSB

|                           |                                                                 |                          | -    |      |      |      |       |             |      | -      | -                        |
|---------------------------|-----------------------------------------------------------------|--------------------------|------|------|------|------|-------|-------------|------|--------|--------------------------|
| ACC*                      | Accumulator                                                     | E0H                      | E7   | E6   | E5   | E4   | E3    | E2          | E1   | E0     | 00H                      |
| В*                        | B register                                                      | F0H                      | F7   | F6   | F5   | F4   | F3    | F2          | F1   | F0     | 00H                      |
| DPTR:<br>DPH<br>DPL       | Data pointer (2 bytes)<br>Data pointer high<br>Data pointer low | 83H<br>82H               |      |      |      |      |       |             |      |        | 00H<br>00H               |
|                           |                                                                 |                          | AF   | AE   | AD   | AC   | AB    | AA          | A9   | A8     |                          |
| IE*                       | Interrupt enable                                                | A8H                      | EA   | -    | ET2  | ES   | ET1   | EX1         | ET0  | EX0    | 0x000000B                |
|                           |                                                                 |                          | BF   | BE   | BD   | BC   | BB    | BA          | B9   | B8     |                          |
| IP*                       | Interrupt priority                                              | B8H                      | -    | -    | PT2  | PS   | PT1   | PX1         | PT0  | PX0    | xx000000B                |
|                           |                                                                 |                          | 87   | 86   | 85   | 84   | 83    | 82          | 81   | 80     |                          |
| P0*                       | Port 0                                                          | 80H                      | AD7  | AD6  | AD5  | AD4  | AD3   | AD2         | AD1  | AD0    | FFH                      |
|                           |                                                                 |                          | 97   | 96   | 95   | 94   | 93    | 92          | 91   | 90     |                          |
| P1*                       | Port 1                                                          | 90H                      | -    | -    | -    | -    | -     | -           | T2EX | T2     | FFH                      |
|                           |                                                                 |                          | A7   | A6   | A5   | A4   | A3    | A2          | A1   | A0     |                          |
| P2*                       | Port 2                                                          | A0H                      | A15  | A14  | A13  | A12  | A11   | A10         | A9   | A8     | FFH                      |
|                           |                                                                 |                          | B7   | B6   | B5   | B4   | B3    | B2          | B1   | B0     |                          |
| P3*                       | Port 3                                                          | B0H                      | RD   | WR   | T1   | Т0   | INT1  | <b>INTO</b> | TxD  | RxD    | FFH                      |
| PCON <sup>1</sup>         | Power control                                                   | 87H                      | SMOD | -    | -    | -    | GF1   | GF0         | PD   | IDL    | 0xxxxxxB                 |
|                           |                                                                 |                          | D7   | D6   | D5   | D4   | D3    | D2          | D1   | D0     |                          |
| PSW*                      | Program status word                                             | D0H                      | CY   | AC   | F0   | RS1  | RS0   | OV          | -    | Р      | 00H                      |
| RCAP2H#<br>RCAPL#         | Capture high<br>Capture low                                     | CBH<br>CAH               |      |      |      |      |       |             |      |        | 00H<br>00H               |
| SBUF                      | Serial data buffer                                              | 99H                      |      |      |      |      |       |             |      |        | xxxxxxxB                 |
|                           |                                                                 |                          | 9F   | 9E   | 9D   | 9C   | 9B    | 9A          | 99   | 98     |                          |
| SCON*                     | Serial controller                                               | 98H                      | SM0  | SM1  | SM2  | REN  | TB8   | RB8         | TI   | RI     | 00H                      |
| SP                        | Stack pointer                                                   | 81H                      |      |      |      |      |       |             |      |        | 07H                      |
|                           |                                                                 |                          | 8F   | 8E   | 8D   | 8C   | 8B    | 8A          | 89   | 88     |                          |
| TCON*                     | Timer control                                                   | 88H                      | TF1  | TR1  | TF0  | TR0  | IE1   | IT1         | IE0  | IT0    | оон                      |
|                           |                                                                 |                          |      |      | •    |      |       |             |      |        | 1                        |
|                           |                                                                 |                          | CF   | CE   | CD   | CC   | СВ    | CA          | C9   | C8     |                          |
| T2CON*#                   | Timer 2 control                                                 | C8H                      | TF2  | EXF2 | RCLK | TCLK | EXEN2 | TR2         | C/T2 | CP/RL2 | 00H                      |
| TH0<br>TH1<br>TH2#<br>TL0 | Timer high 0<br>Timer high 1<br>Timer high 2<br>Timer low 0     | 8CH<br>8DH<br>CDH<br>8AH |      |      |      |      |       |             |      |        | 00H<br>00H<br>00H<br>00H |

BIT ADDRESS, SYMBOL, OR ALTERNATIVE PORT FUNCTION

 Table 1.
 8XC52 Special Function Registers

DESCRIPTION

Bit addressable

# SFRs are modified from or added to the 80C51 SFRs.

Timer low 1

Timer low 2

Timer mode

1. Bits GF1, GF0, PD, and IDL of the PCON register are not implemented in the NMOS 8XC52.

GATE

C/T

8BH

CCH

89H

TL1 TL2#

TMOD

M1

M0

GATE

C/T

M1

### 80C32/87C52

### **PIN DESCRIPTION**

|                    |        | PIN NO.      |              | PIN NO. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PIN NO. |  | PIN NO. |  | PIN NO. |  | PIN NO. |  | PIN NO. |  | PIN NO. |  |  |  |
|--------------------|--------|--------------|--------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|---------|--|---------|--|---------|--|---------|--|---------|--|--|--|
| MNEMONIC           | DIP    | LCC          | QFP          | TYPE    | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| V <sub>SS</sub>    | 20     | 22           | 16           | I       | Ground: 0V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| V <sub>CC</sub>    | 40     | 44           | 38           | I       | <b>Power Supply:</b> This is the power supply voltage for normal, idle, and power-down operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| P0.0–0.7           | 39–32  | 43–36        | 37–30        | I/O     | <b>Port 0:</b> Port 0 is an open-drain, bidirectional I/O port. Port 0 pins that have 1s written to them float and can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program and data memory. In this application, it uses strong internal pull-ups when emitting 1s. Port 0 also outputs the code bytes during program verification in the 87C52. External pull-ups are required during program verification.                                                                                                                                                                                                                                                                       |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| P1.0–P1.7          | 1–8    | 2–9          | 40–44<br>1–3 | I/O     | <b>Port 1:</b> Port 1 is an 8-bit bidirectional I/O port with internal pull-ups. Port 1 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 1 pins that are externally pulled low will source current because of the internal pull-ups. (See DC Electrical Characteristics: $I_{IL}$ ). Pins P1.0 and P1.1 also. Port 1 also receives the low-order address byte during program memory verification. Port 1 also serves alternate functions for timer 2:                                                                                                                                                                                                                                         |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 1<br>2 | 2<br>3       | 40<br>41     |         | T2 (P1.0): Timer/counter 2 external count input.T2EX (P1.1): Timer/counter 2 trigger input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| P2.0-P2.7          | 21–28  | 24–31        | 18–25        | I/O     | <b>Port 2:</b> Port 2 is an 8-bit bidirectional I/O port with internal pull-ups. Port 2 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 2 pins that are externally being pulled low will source current because of the internal pull-ups. (See DC Electrical Characteristics: I <sub>IL</sub> ). Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR). In this application, it uses strong internal pull-ups when emitting 1s. During accesses to external data memory that use 8-bit addresses (MOV @Ri), port 2 emits the contents of the P2 special function register. |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| P3.0–P3.7          | 10–17  | 11,<br>13–19 | 5,<br>7–13   | I/O     | <b>Port 3:</b> Port 3 is an 8-bit bidirectional I/O port with internal pull-ups. Port 3 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 3 pins that are externally being pulled low will source current because of the pull-ups. (See DC Electrical Characteristics: $I_{IL}$ ). Port 3 also serves the special features of the 80C51 family, as listed below:                                                                                                                                                                                                                                                                                                                               |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 10     | 11           | 5            | 1       | RxD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 11     | 13           | 7            | 0       | TxD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 12     | 14           | 8            | 1       | INT0 (P3.2): External interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 13     | 15           | 9            | I I     | INT1 (P3.3): External interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 14     | 16           | 10           | 1       | T0 (P3.4): Timer 0 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 15     | 17           | 11           |         | T1 (P3.5): Timer 1 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 16     | 18           | 12           | 0       | WR (P3.6): External data memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
|                    | 17     | 19           | 13           | 0       | RD (P3.7): External data memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| RST                | 9      | 10           | 4            | 1       | <b>Reset:</b> A high on this pin for two machine cycles while the oscillator is running, resets the device. An internal diffused resistor to $V_{SS}$ permits a power-on reset using only an external capacitor to $V_{CC}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| ALE/PROG           | 30     | 33           | 27           | I/O     | Address Latch Enable/Program Pulse: Output pulse for latching the low byte of the address during an access to external memory. In normal operation, ALE is emitted at a constant rate of 1/6 the oscillator frequency, and can be used for external timing or clocking. Note that one ALE pulse is skipped during each access to external data memory. This pin is also the program pulse input (PROG) during EPROM programming.                                                                                                                                                                                                                                                                                                                                   |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| PSEN               | 29     | 32           | 26           | 0       | <b>Program Store Enable:</b> The read strobe to external program memory. When the device is executing code from the external program memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory. PSEN is not activated during fetches from internal program memory.                                                                                                                                                                                                                                                                                                                                                                                                               |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| ĒĀ/V <sub>PP</sub> | 31     | 35           | 29           | I       | <b>External Access Enable/Programming Supply Voltage:</b> $\overrightarrow{EA}$ must be externally held low to enable the device to fetch code from external program memory locations 0000H to 1FFFH. If $\overrightarrow{EA}$ is held high, the device executes from internal program memory unless the program counter contains an address greater than 1FFFH. This pin also receives the 12.75V programming supply voltage (V <sub>PP</sub> ) during EPROM programming.                                                                                                                                                                                                                                                                                         |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| XTAL1              | 19     | 21           | 15           | I       | Crystal 1: Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |  |         |  |         |  |         |  |         |  |         |  |  |  |
| XTAL2              | 18     | 20           | 14           | 0       | Crystal 2: Output from the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |  |         |  |         |  |         |  |         |  |         |  |  |  |

### 80C32/87C52

#### **DIFFERENCES FROM THE 80C51**

#### **Special Function Registers**

The special function register space is the same as the 80C51 except that the 80C32/87C52 contains the additional special function registers T2CON, RCAP2L, RCAP2H, TL2, and TH2. Since the standard 80C51 on-chip functions are identical in the 8XC52, the SFR locations, bit locations, and operation are likewise identical. The only exceptions are in the interrupt mode and interrupt priority SFRs (see Table 1).

#### **Timer/Counters**

In addition to timer/counters 0 and 1 of the 80C51, the 80C32/87C52 contains timer/counter 2. Like timers 0 and 1, timer 2 can operate as either an event timer or as an event counter. This is selected by bit C/T2 in the special function register T2CON (see Figure 1). It has three operating modes: capture, auto-load, and baud rate generator, which are selected by bits in the T2CON as shown in Table 2.

In the Capture Mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then Timer 2 is a 16-bit timer or counter which upon overflowing sets bit TF2, the Timer 2 overflow bit, which can be used to generate an interrupt. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively. (RCAP2L and RCAP2H are new special function registers in the 80C52.) In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2 like TF2 can generate an interrupt. The Capture Mode is illustrated in Figure 2.

In the auto-reload mode, there are again two options, which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then when Timer 2 rolls over it not only sets TF2 but also causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0

transition at external input T2EX will also trigger the 16-bit reload and set EXF2. The auto-reload mode is illustrated in Figure 3.

The baud rate generation mode is selected by RCLK = 1 and/or TCLK = 1. It will be described in conjunction with the serial port.

#### **Serial Port**

The serial port of the 8XC52 is identical to that of the 80C51 except that counter/timer 2 can be used to generate baud rates.

In the 8XC52, Timer 2 is selected as the baud rate generator by setting TCLK and/or RCLK in T2CON (see Figure 1). Note that the baud rate for transmit and receive can be simultaneously different. Setting RCLK and/or TCLK puts Timer into its baud rate generator mode, as shown in Figure 4.

The baud rate generator mode is similar to the auto-reload mode, in that a rollover in TH2 causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2H and RCAP2L, which are preset by software.

Now, the baud rates in Modes 1 and 3 are determined by Timer 2's overflow rate as follows:

Modes 1, 3 Baud Rate = 
$$\frac{\text{Timer 2 Overflow Rate}}{16}$$

The timer can be configured for either "timer" or "counter" operation. In the most typical applications, it is configured for "timer" operation (C/T2 = 0). "Timer" operation is a little different for Timer 2 when it's being used as a baud rate generator. Normally, as a timer it would increment every machine cycle (thus at 1/12 the oscillator frequency). As a baud rate generator, however, it increments every state time (thus at 1/2 the oscillator frequency). In that case the baud rate is given by the formula:

```
Modes 1, 3 Baud Rate = \frac{\text{Oscillator Frequency}}{32 \times [65536 - (\text{RCAP2H}, \text{RCAP2L})]}
```

where (RCAP2H, RCAP2L) is the content of RCAP2H and RCAP2L taken as a 16-bit unsigned integer.

|        |          | (MSB)    |              |              |             |                            |              |             | (LSB)                           |               |              |            |            |
|--------|----------|----------|--------------|--------------|-------------|----------------------------|--------------|-------------|---------------------------------|---------------|--------------|------------|------------|
|        |          | TF2      | EXF2         | RCLK         | TCLK        | EXEN2                      | TR2          | C/T2        | CP/RL2                          |               |              |            |            |
| Symbol | Position | Name ar  | nd Signific  | ance         |             |                            |              |             |                                 |               |              |            |            |
| TF2    | T2CON.7  | Timer 2  | overflow fl  | ag set by a  | Timer 2 o   | verflow and                | must be c    | leared by s | software. TF2                   | will not be   | set when e   | ither RCLK | or TCLK =  |
| EXF2   | T2CON.6  |          |              |              |             |                            |              |             | negative tran<br>2 interrupt ro |               |              |            |            |
| RCLK   | T2CON.5  |          |              |              |             | e serial por<br>he receive |              | ner 2 over  | flow pulses fo                  | r its receive | clock in m   | odes 1 and | 3. RCLK    |
| TCLK   | T2CON.4  |          |              |              |             | ne serial po<br>the transm |              | mer 2 over  | rflow pulses f                  | r its transm  | iit clock in | modes 1 an | id 3. TCLK |
| EXEN2  | T2CON.3  |          |              |              |             |                            |              |             | cur as a resul<br>events at T2  |               | ve transitio | on on T2EX | if Timer 2 |
| TR2    | T2CON.2  | Start/st | op control f | or Timer 2.  | A logic 1 s | tarts the tin              | ner.         |             |                                 |               |              |            |            |
| C/T2   | T2CON.1  | Timer o  |              | nternal time | er (ÓSC/12  | )<br>(falling edg          | ge triggered | d).         |                                 |               |              |            |            |
| CP/RL2 | T2CON.0  | occur e  | ither with T |              | flows or ne | egative tran               | sitions at T | 2EX when    | ns at T2EX if<br>n EXEN2 = 1.   |               |              |            |            |

Figure 1. Timer/Counter 2 (T2CON) Control Register



Figure 2. Timer 2 in Capture Mode



Figure 3. Timer 2 in Auto-Reload Mode

### 80C32/87C52



Figure 4. Timer 2 in Baud Rate Generator Mode

|             | operating incase |     |                     |
|-------------|------------------|-----|---------------------|
| RCLK + TCLK | CP/RL2           | TR2 | MODE                |
| 0           | 0                | 1   | 16-bit Auto-reload  |
| 0           | 1                | 1   | 16-bit Capture      |
| 1           | Х                | 1   | Baud rate generator |
| Х           | Х                | 0   | (off)               |

Table 2. Timer 2 Operating Modes

Timer 2 as a baud rate generator is shown in Figure 4. This figure is valid only if RCLK + TCLK = 1 in T2CON. Note that a rollover in TH2 does not set TF2, and will not generate an interrupt. Therefore, the Timer 2 interrupt does not have to be disabled when Timer 2 is in the baud rate generator mode. Note too, that if EXEN2 is set, a 1-to-0 transition in T2EX will set EXF2 but will not cause a reload from (RCAP2H, RCAP2L) to (TH2, TL2). Thus when Timer 2 is in use as a baud rate generator, T2EX can be used as an extra external interrupt, if desired.

It should be noted that when Timer 2 is running (TR2 = 1) in "timer" function in the baud rate generator mode, one should not try to read or write TH2 or TL2. Under these conditions the timer is being incremented every state time, and the results of a read or write may not be accurate. The RCAP registers may be read, but should not be written to, because a write might overlap a reload and cause write and/or reload errors. Turn the timer off (clear TR2) before accessing the Timer 2 or RCAP registers, in this case.

#### Timer/Counter 2 Set-up

Except for the baud rate generator mode, the values given for T2CON do not include the setting of the TR2 bit. Therefore, bit TR2 must be set, separately, to turn the timer on. See Table 3 for set-up of timer 2 as a timer. See Table 4 for set-up of timer 2 as a counter.

#### Using Timer/Counter 2 to Generate Baud Rates

For this purpose, Timer 2 must be used in the baud rate generating mode. If Timer 2 is being clocked through pin T2 (P1.0) the baud rate is:

Baud Rate = 
$$\frac{\text{Timer 2 Overflow Rate}}{16}$$

And if it is being clocked internally, the baud rate is:

Baud Rate = 
$$\frac{\text{Oscillator Frequency}}{32 \times [65536 - (\text{RCAP2H}, \text{RCAP2L})]}$$

To obtain the reload value for RCAP2H and RCA02L, the above equation can be rewritten as:

 $RCAP2H, RCAP2L = 65536 - \frac{Oscillator Frequency}{32 \times Baud Rate}$ 

### 80C32/87C52

#### Interrupts

The 80C32/87C52 has 6 interrupt sources. All except TF2 and EXF2 are identical sources to those in the 80C51.

The Interrupt Enable Register and the Interrupt Priority Register are modified to include the additional 80C32/87C52 interrupt sources. The operation of these registers is identical to the 80C51.

In the 80C32/87C52, the Timer 2 Interrupt is generated by the logical OR of TF2 and EXF2. Neither of these flags is cleared by hardware when the service routine is vectored to. In fact, the service routine may have to determine whether it was TF2 or EXF2 that generated the interrupt, and the bit will have to be cleared in software.

All of the bits that generate interrupts can be set or cleared by software, with the same result as though it has been set or cleared

by hardware. That is, interrupts can be generated or pending interrupts can be canceled in software.

The interrupt vector addresses and the interrupt priority for requests in the same priority level are given in the following:

|    | Source     | Vector  | <b>Priority Within</b> |
|----|------------|---------|------------------------|
|    |            | Address | Level                  |
| 1. | IE0        | 0003H   | (highest)              |
| 2. | TF0        | 000BH   |                        |
| 3. | IE1        | 0013H   |                        |
| 4. | TF1        | 001BH   |                        |
| 5. | RI + TI    | 0023H   |                        |
| 6. | TF2 + EXF2 | 002BH   | (lowest)               |

Note that they are identical to those in the 80C51 except for the addition of the Timer 2 (TF1 and EXF2) interrupt at 002BH and at the lowest priority within a level.

#### Table 3. Timer 2 as a Timer

| MODE                                                    | T20                          | CON                          |
|---------------------------------------------------------|------------------------------|------------------------------|
|                                                         | INTERNAL CONTROL<br>(Note 1) | EXTERNAL CONTROL<br>(Note 2) |
| 16-bit Auto-Reload                                      | 00H                          | 08H                          |
| 16-bit Capture                                          | 01H                          | 09H                          |
| Baud rate generator receive and transmit same baud rate | 34H                          | 36H                          |
| Receive only                                            | 24H                          | 26H                          |
| Transmit only                                           | 14H                          | 16H                          |

#### Table 4. Timer 2 as a Counter

| MODE        | ТМ                           | OD                           |
|-------------|------------------------------|------------------------------|
|             | INTERNAL CONTROL<br>(Note 1) | EXTERNAL CONTROL<br>(Note 2) |
| 16-bit      | 02H                          | 0AH                          |
| Auto-Reload | 03H                          | 0BH                          |

NOTES:

1. Capture/reload occurs only on timer/counter overflow.

2. Capture/reload occurs on timer/counter overflow and a 1-to-0 transition on T2EX (P1.1) pin except when timer 2 is used in the baud rate generator mode.

80C32/87C52

#### **OSCILLATOR CHARACTERISTICS**

XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier. The pins can be configured for use as an on-chip oscillator, as shown in the Logic Symbol, page 3-168.

To drive the device from an external clock source, XTAL1 should be driven while XTAL2 is left unconnected. There are no requirements on the duty cycle of the external clock signal, because the input to the internal clock circuitry is through a divide-by-two flip-flop. However, minimum and maximum high and low times specified in the data sheet must be observed.

#### RESET

A reset is accomplished by holding the RST pin high for at least two machine cycles (24 oscillator periods), while the oscillator is running. To insure a good power-up reset, the RST pin must be high long enough to allow the oscillator time to start up (normally a few milliseconds) plus two machine cycles.

#### **IDLE MODE**

In idle mode, the CPU puts itself to sleep while all of the on-chip peripherals stay active. The instruction to invoke the idle mode is the last instruction executed in the normal operating mode before the idle mode is activated. The CPU contents, the on-chip RAM, and all of the special function registers remain intact during this mode. The idle mode can be terminated either by any enabled interrupt (at which time the process is picked up at the interrupt service routine and continued), or by a hardware reset which starts the processor in the same manner as a power-on reset.

#### **POWER-DOWN MODE**

In the power-down mode, the oscillator is stopped and the instruction to invoke power-down is the last instruction executed. Only the contents of the on-chip RAM are preserved. A hardware reset is the only way to terminate the power-down mode. the control bits for the reduced power modes are in the special function register PCON.

#### **DESIGN CONSIDERATIONS**

At power-on, the voltage on  $V_{\mbox{CC}}$  and RST must come up at the same time for a proper start-up.

Table 5 shows the state of I/O ports during low current operating modes.

As a precaution to coming out of an unexpected power down, INTO and INT1 should be disabled prior to enterring power down.

#### Table 5. External Pin Status During Idle and Power-Down Modes

| MODE       | PROGRAM MEMORY | ALE | PSEN | PORT 0 | PORT 1 | PORT 2  | PORT 3 |
|------------|----------------|-----|------|--------|--------|---------|--------|
| Idle       | Internal       | 1   | 1    | Data   | Data   | Data    | Data   |
| Idle       | External       | 1   | 1    | Float  | Data   | Address | Data   |
| Power-down | Internal       | 0   | 0    | Data   | Data   | Data    | Data   |
| Power-down | External       | 0   | 0    | Float  | Data   | Data    | Data   |

### 80C32/87C52

#### Electrical Deviations from Commercial Specifications for Extended Temperature Range (87C52)

DC and AC parameters not included here are the same as in the commercial temperature range table.

#### DC ELECTRICAL CHARACTERISTICS

 $T_{amb} = -40^{\circ}C$  to +85°C,  $V_{CC} = 5V \pm 10\%$ ,  $V_{SS} = 0V$ 

|                  |                                                                      | TEST                                                             | LIMITS                  |                          |                |
|------------------|----------------------------------------------------------------------|------------------------------------------------------------------|-------------------------|--------------------------|----------------|
| SYMBOL           | PARAMETER                                                            | CONDITIONS                                                       | MIN                     | MAX                      | UNIT           |
| V <sub>IL</sub>  | Input low voltage, except EA                                         |                                                                  | -0.5                    | 0.2V <sub>CC</sub> -0.15 | V              |
| V <sub>IL1</sub> | Input low voltage to EA                                              |                                                                  | 0                       | 0.2V <sub>CC</sub> -0.35 | V              |
| V <sub>IH</sub>  | Input high voltage, except XTAL1, RST                                |                                                                  | 0.2V <sub>CC</sub> +1   | V <sub>CC</sub> +0.5     | V              |
| V <sub>IH1</sub> | Input high voltage to XTAL1, RST                                     |                                                                  | 0.7V <sub>CC</sub> +0.1 | V <sub>CC</sub> +0.5     | V              |
| I <sub>IL</sub>  | Logical 0 input current, ports 1, 2, 3                               | V <sub>IN</sub> = 0.45V                                          |                         | -75                      | μA             |
| I <sub>TL</sub>  | Logical 1-to-0 transition current, ports 1, 2, 3                     | V <sub>IN</sub> = 2.0V                                           |                         | -750                     | μΑ             |
| Icc              | Power supply current:<br>Active mode<br>Idle mode<br>Power-down mode | V <sub>CC</sub> = 4.5–5.5V,<br>Frequency range =<br>3.5 to 16MHz |                         | 32<br>5<br>50            | mA<br>mA<br>μA |

#### ABSOLUTE MAXIMUM RATINGS<sup>1, 2, 3</sup>

| PARAMETER                                                                                    | RATING                 | UNIT |
|----------------------------------------------------------------------------------------------|------------------------|------|
| Operating temperature under bias                                                             | 0 to +70 or -40 to +85 | °C   |
| Storage temperature range                                                                    | -65 to +150            | °C   |
| Voltage on $\overline{EA}/V_{PP}$ pin to $V_{SS}$                                            | 0 to +13.0             | V    |
| Voltage on any other pin to $V_{SS}$                                                         | -0.5 to +6.5           | V    |
| Maximum I <sub>OL</sub> per I/O pin                                                          | 15                     | mA   |
| Power dissipation (based on package heat transfer limitations, not device power consumption) | 1.5                    | W    |

NOTES:

1. 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 these or any conditions other than those described in the AC and DC Electrical Characteristics section of this specification is not implied.

2. This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maxima.

3. Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted.

#### DC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0^{\circ}C$  to +70°C or -40°C to +85°C,  $V_{CC} = 5V \pm 10\%$ ,  $V_{SS} = 0V$  (87C52)

 $T_{amb} = 0^{\circ}C \text{ to } +70^{\circ}C \text{ or } -40^{\circ}C \text{ to } +85^{\circ}C, V_{CC} = 5V \pm 10\%, V_{SS} = 0V (80C32)$ 

|                  |                                                                                                                                                                                    | TEST                                                                             |                                                  |                  |                         |                |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------|------------------|-------------------------|----------------|--|
| SYMBOL           | PARAMETER                                                                                                                                                                          | CONDITIONS                                                                       | MIN                                              | TYP <sup>1</sup> | MAX                     | UNIT           |  |
| V <sub>IL</sub>  | Input low voltage, except EA <sup>7</sup>                                                                                                                                          |                                                                                  | -0.5                                             |                  | 0.2V <sub>CC</sub> -0.1 | V              |  |
| V <sub>IL1</sub> | Input low voltage to EA <sup>7</sup>                                                                                                                                               |                                                                                  | 0                                                |                  | 0.2V <sub>CC</sub> -0.3 | V              |  |
| V <sub>IH</sub>  | Input high voltage, except XTAL1, RST <sup>7</sup>                                                                                                                                 |                                                                                  | 0.2V <sub>CC</sub> +0.9                          |                  | V <sub>CC</sub> +0.5    | V              |  |
| V <sub>IH1</sub> | Input high voltage, XTAL1, RST <sup>7</sup>                                                                                                                                        |                                                                                  | 0.7V <sub>CC</sub>                               |                  | V <sub>CC</sub> +0.5    | V              |  |
| V <sub>OL</sub>  | Output low voltage, ports 1, 2, 3 <sup>9</sup>                                                                                                                                     | I <sub>OL</sub> = 1.6mA <sup>2</sup>                                             |                                                  |                  | 0.45                    | V              |  |
| V <sub>OL1</sub> | Output low voltage, port 0, ALE, PSEN <sup>9</sup>                                                                                                                                 | $I_{OL} = 3.2 \text{mA}^2$                                                       |                                                  |                  | 0.45                    | V              |  |
| V <sub>OH</sub>  | Output high voltage, ports 1, 2, 3, ALE, PSEN <sup>3</sup>                                                                                                                         | $I_{OH} = -60\mu A,$<br>$I_{OH} = -25\mu A$<br>$I_{OH} = -10\mu A$               | 2.4<br>0.75V <sub>CC</sub><br>0.9V <sub>CC</sub> |                  |                         | V<br>V<br>V    |  |
| V <sub>OH1</sub> | Output high voltage (port 0 in external bus mode)                                                                                                                                  | I <sub>OH</sub> = -800μA,<br>I <sub>OH</sub> = -300μA<br>I <sub>OH</sub> = -80μA | 2.4<br>0.75V <sub>CC</sub><br>0.9V <sub>CC</sub> |                  |                         | V<br>V<br>V    |  |
| IIL              | Logical 0 input current, ports 1, 2, 3 <sup>7</sup>                                                                                                                                | V <sub>IN</sub> = 0.45V                                                          |                                                  |                  | -50                     | μΑ             |  |
| I <sub>TL</sub>  | Logical 1-to-0 transition current, ports 1, 2, 37                                                                                                                                  | See note 4                                                                       |                                                  |                  | -650                    | μA             |  |
| ILI              | Input leakage current, port 0                                                                                                                                                      | $V_{IN} = V_{IL} \text{ or } V_{IH}$                                             |                                                  |                  | ±10                     | μΑ             |  |
| I <sub>CC</sub>  | Power supply current:7<br>Active mode @ 16MHz5<br>Idle mode @ 16MHzPower-down mode $T_{amb} = 0 \text{ to } 70^{\circ}\text{C}$<br>$T_{amb} = -40 \text{ to } +85^{\circ}\text{C}$ | See note 6                                                                       |                                                  | 11.5<br>1.3<br>3 | 32<br>5<br>50<br>75     | mA<br>mA<br>μA |  |
| R <sub>RST</sub> | Internal reset pull-down resistor                                                                                                                                                  |                                                                                  | 50                                               |                  | 300                     | kΩ             |  |
| C <sub>IO</sub>  | Pin capacitance <sup>10</sup>                                                                                                                                                      |                                                                                  |                                                  |                  | 15                      | pF             |  |

#### NOTES:

1. Typical ratings are not guaranteed. The values listed are at room temperature, 5V.

 Capacitive loading on ports 0 and 2 may cause the V<sub>OH</sub> on ALE and PSEN to momentarily fall below the 0.9V<sub>CC</sub> specification when the address bits are stabilizing.

 Pins of ports 1, 2 and 3 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when V<sub>IN</sub> is approximately 2V.

5.  $I_{CCMAX}$  at other frequencies is given by: Active mode:  $I_{CCMAX} = 1.5 \times FREQ + 8.0$ : Idle mode:  $I_{CCMAX} = 0.14 \times FREQ + 2.31$ ,

where FREQ is the external oscillator frequency in MHz. I<sub>CCMAX</sub> is given in mA. See Figure 12.

6. See Figures 13 through 16 for  $I_{CC}$  test conditions.

7. These values apply only to  $T_{amb} = 0^{\circ}C$  to  $+70^{\circ}C$ . For  $T_{amb} = -40^{\circ}C$  to  $+85^{\circ}C$ , see table on previous page.

8. Load capacitance for port 0, ALE, and PSEN = 100pF, load capacitance for all other outputs = 80pF.

9. Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows:

Maximum I<sub>OL</sub> per port pin: 15mA (\*NOTE: This is 85°C specification.)

|                                    | 101101 |
|------------------------------------|--------|
| Maximum IOL per 8-bit port:        | 26mA   |
| Maximum total IOL for all outputs: | 67mA   |

If I<sub>OL</sub> exceeds the test condition, V<sub>OL</sub> may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

10. This limit is for plastic packages. For ceramic packages, the maximum limit is 20pF.

<sup>2.</sup> Capacitive loading on ports 0 and 2 may cause spurious noise to be superimposed on the V<sub>OL</sub>s of ALE and ports 1 and 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100pF), the noise pulse on the ALE pin may exceed 0.8V. In such cases, it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input. I<sub>OL</sub> can exceed these conditions provided that no single output sinks more than 5mA and no more than two outputs exceed the test conditions.

80C32/87C52

### CMOS single-chip 8-bit microcontrollers

AC ELECTRICAL CHARACTERISTICS T<sub>amb</sub> = 0°C to +70°C or -40°C to +85°C, V<sub>CC</sub> = 5V  $\pm$ 10%, V<sub>SS</sub> = 0V (87C52)<sup>1, 2, 3</sup>

|                     |        |                                            | 16MHz CLOCK |     | VARIABLE CLOCK           |                                      |     |
|---------------------|--------|--------------------------------------------|-------------|-----|--------------------------|--------------------------------------|-----|
| SYMBOL I            | FIGURE | PARAMETER                                  | MIN MAX     |     | MIN                      | тил Т                                |     |
| 1/t <sub>CLCL</sub> | 5      | Oscillator frequency<br>Speed versions : E |             |     | 3.5                      | 16                                   | MHz |
| t <sub>LHLL</sub>   | 5      | ALE pulse width                            | 85          |     | 2t <sub>CLCL</sub> -40   |                                      | ns  |
| t <sub>AVLL</sub>   | 5      | Address valid to ALE low                   | 22          |     | t <sub>CLCL</sub> -40    |                                      | ns  |
| t <sub>LLAX</sub>   | 5      | Address hold after ALE low                 | 32          |     | t <sub>CLCL</sub> -30    |                                      | ns  |
| t <sub>LLIV</sub>   | 5      | ALE low to valid instruction in            |             | 150 |                          | 4t <sub>CLCL</sub> -100              | ns  |
| t <sub>LLPL</sub>   | 5      | ALE low to PSEN low                        | 32          |     | t <sub>CLCL</sub> -30    |                                      | ns  |
| t <sub>PLPH</sub>   | 5      | PSEN pulse width                           | 142         |     | 3t <sub>CLCL</sub> -45   |                                      | ns  |
| t <sub>PLIV</sub>   | 5      | PSEN low to valid instruction in           |             | 82  |                          | 3t <sub>CLCL</sub> -105              | ns  |
| t <sub>PXIX</sub>   | 5      | Input instruction hold after PSEN          | 0           |     | 0                        |                                      | ns  |
| t <sub>PXIZ</sub>   | 5      | Input instruction float after PSEN         |             | 37  |                          | t <sub>CLCL</sub> -25                | ns  |
| t <sub>AVIV</sub>   | 5      | Address to valid instruction in            |             | 207 |                          | 5t <sub>CLCL</sub> -105              | ns  |
| t <sub>PLAZ</sub>   | 5      | PSEN low to address float                  |             | 10  |                          | 10                                   | ns  |
| Data Mem            | ory    | •                                          |             | •   |                          | •                                    | •   |
| t <sub>RLRH</sub>   | 6, 7   | RD pulse width                             | 275         |     | 6t <sub>CLCL</sub> -100  |                                      | ns  |
| t <sub>WLWH</sub>   | 6, 7   | WR pulse width                             | 275         |     | 6t <sub>CLCL</sub> -100  |                                      | ns  |
| t <sub>RLDV</sub>   | 6, 7   | RD low to valid data in                    |             | 147 |                          | 5t <sub>CLCL</sub> -165              | ns  |
| t <sub>RHDX</sub>   | 6, 7   | Data hold after RD                         | 0           |     | 0                        |                                      | ns  |
| t <sub>RHDZ</sub>   | 6, 7   | Data float after RD                        |             | 65  |                          | 2t <sub>CLCL</sub> -60               | ns  |
| t <sub>LLDV</sub>   | 6, 7   | ALE low to valid data in                   |             | 350 |                          | 8t <sub>CLCL</sub> -150              | ns  |
| t <sub>AVDV</sub>   | 6, 7   | Address to valid data in                   |             | 397 |                          | 9t <sub>CLCL</sub> -165              | ns  |
| t <sub>LLWL</sub>   | 6, 7   | ALE low to RD or WR low                    | 137         | 239 | 3t <sub>CLCL</sub> –50   | 3t <sub>CLCL</sub> +50               | ns  |
| t <sub>AVWL</sub>   | 6, 7   | Address valid to WR low or RD low          | 122         |     | 4t <sub>CLCL</sub> -130  |                                      | ns  |
| t <sub>QVWX</sub>   | 6, 7   | Data valid to WR transition                | 13          |     | t <sub>CLCL</sub> –50    |                                      | ns  |
| t <sub>WHQX</sub>   | 6, 7   | Data hold after WR                         | 13          |     | t <sub>CLCL</sub> -50    |                                      | ns  |
| t <sub>QVWH</sub>   | 7      | Data valid to $\overline{WR}$ high         | 287         |     | 7t <sub>CLCL</sub> -150  |                                      | ns  |
| t <sub>RLAZ</sub>   | 6, 7   | RD low to address float                    |             | 0   |                          | 0                                    | ns  |
| t <sub>WHLH</sub>   | 6, 7   | RD or WR high to ALE high                  | 23          | 103 | t <sub>CLCL</sub> -40    | t <sub>CLCL</sub> +40                | ns  |
| External C          | lock   |                                            |             |     | •                        |                                      |     |
| t <sub>CHCX</sub>   | 9      | High time                                  | 20          |     | 20                       | t <sub>CLCL</sub> -t <sub>CLCX</sub> | ns  |
| t <sub>CLCX</sub>   | 9      | Low time                                   | 20          | 1   | 20                       | t <sub>CLCL</sub> -t <sub>CHCX</sub> | ns  |
| t <sub>CLCH</sub>   | 9      | Rise time                                  |             | 20  |                          | 20                                   | ns  |
| t <sub>CHCL</sub>   | 9      | Fall time                                  |             | 20  |                          | 20                                   | ns  |
| Shift Regi          | ster   |                                            | -           | -   | _                        | -                                    | _   |
| t <sub>XLXL</sub>   | 8      | Serial port clock cycle time               | 750         |     | 12t <sub>CLCL</sub>      |                                      | ns  |
| t <sub>QVXH</sub>   | 8      | Output data setup to clock rising edge     | 492         |     | 10t <sub>CLCL</sub> -133 |                                      | ns  |
| t <sub>XHQX</sub>   | 8      | Output data hold after clock rising edge   | 8           |     | 2t <sub>CLCL</sub> -117  |                                      | ns  |
| t <sub>XHDX</sub>   | 8      | Input data hold after clock rising edge    | 0           |     | 0                        |                                      | ns  |
| t <sub>XHDV</sub>   | 8      | Clock rising edge to input data valid      |             | 492 |                          | 10t <sub>CLCL</sub> -133             | ns  |

NOTES:

1. Parameters are valid over operating temperature range unless otherwise specified.

2. Load capacitance for port 0, ALE, and PSEN = 100pF, load capacitance for all other outputs = 80pF.

3. Interfacing the 80C32/52 to devices with float times up to 45ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.

4. See application note AN457 for external memory interface.

AC ELECTRICAL CHARACTERISTICS Tamb = 0°C to +70°C or -40°C to +85°C, V<sub>CC</sub> = 5V  $\pm$ 10%, V<sub>SS</sub> = 0V<sup>1, 2, 3</sup>

|                     |        | 1                                        | 24MHz CLOCK |     | VARIABLE CLOCK           |                                      | 33MHz CLOCK |     |      |
|---------------------|--------|------------------------------------------|-------------|-----|--------------------------|--------------------------------------|-------------|-----|------|
| SYMBOL              | FIGURE | PARAMETER                                | MIN         | MAX | MIN                      | MAX                                  | MIN         | MAX | דואט |
| 1/t <sub>CLCL</sub> | 5      | Oscillator frequency                     |             |     |                          |                                      |             |     |      |
|                     |        | Speed versions :I<br>:N                  |             |     | 3.5                      | 24                                   | 3.5         | 33  | MH   |
| tLHLL               | 5      | ALE pulse width                          | 43          |     | 2t <sub>CLCL</sub> -40   |                                      | 21          |     | ns   |
| t <sub>AVLL</sub>   | 5      | Address valid to ALE low                 | 17          |     | t <sub>CLCL</sub> -25    |                                      | 5           |     | ns   |
| t <sub>LLAX</sub>   | 5      | Address hold after ALE low               | 17          |     | t <sub>CLCL</sub> -25    |                                      | 5           |     | ns   |
|                     | 5      | ALE low to valid instruction in          |             | 102 |                          | 4t <sub>CLCL</sub> -65               | <u> </u>    | 56  | ns   |
|                     | 5      | ALE low to PSEN low                      | 17          |     | t <sub>CLCL</sub> -25    | NCLUL 00                             | 5           |     | ns   |
| t <sub>PLPH</sub>   | 5      | PSEN pulse width                         | 80          |     | 3t <sub>CLCL</sub> -45   |                                      | <u> </u>    | 46  | ns   |
|                     | 5      | PSEN low to valid instruction in         |             | 65  |                          | 3t <sub>CLCL</sub> -60               |             | 31  | ns   |
| t <sub>PXIX</sub>   | 5      | Input instruction hold after PSEN        | 0           |     | 0                        |                                      | 0           | 0.  | ns   |
|                     | 5      | Input instruction float after PSEN       |             | 17  | -                        | t <sub>CLCL</sub> -25                | -           | 5   | ns   |
| t <sub>AVIV</sub>   | 5      | Address to valid instruction in          |             | 128 |                          | 5t <sub>CLCL</sub> -80               |             | 72  | ns   |
| t <sub>PLAZ</sub>   | 5      | PSEN low to address float                |             | 10  |                          | 10                                   |             | 10  | ns   |
| Data Mem            |        |                                          |             |     |                          |                                      |             |     |      |
| t <sub>RLRH</sub>   | 6,7    | RD pulse width                           | 150         |     | 6t <sub>CLCL</sub> -100  |                                      | 82          |     | ns   |
| twlwh               | 6, 7   | WR pulse width                           | 150         |     | 6t <sub>CLCL</sub> -100  |                                      | 82          |     | ns   |
|                     | 6,7    | RD low to valid data in                  |             | 118 |                          | 5t <sub>CLCL</sub> -90               | -           | 62  | ns   |
| tRHDX               | 6, 7   | Data hold after RD                       | 0           |     | 0                        | OLOL                                 | 0           |     | ns   |
| t <sub>RHDZ</sub>   | 6, 7   | Data float after RD                      |             | 55  |                          | 2t <sub>CLCL</sub> -28               |             | 33  | ns   |
| t <sub>LLDV</sub>   | 6, 7   | ALE low to valid data in                 |             | 183 |                          | 8t <sub>CLCL</sub> -150              |             | 92  | ns   |
| t <sub>AVDV</sub>   | 6, 7   | Address to valid data in                 |             | 210 |                          | 9t <sub>CLCL</sub> -165              |             | 108 | ns   |
| tLLWL               | 6, 7   | ALE low to RD or WR low                  | 75          | 175 | 3t <sub>CLCL</sub> -50   | 3t <sub>CLCL</sub> +50               | 41          | 141 | ns   |
| t <sub>AVWL</sub>   | 6, 7   | Address valid to WR low or RD low        | 92          |     | 4t <sub>CLCL</sub> -75   |                                      | 46          |     | ns   |
| t <sub>QVWX</sub>   | 6, 7   | Data valid to WR transition              | 12          |     | t <sub>CLCL</sub> -30    |                                      | 0.3         |     | ns   |
| t <sub>WHQX</sub>   | 6, 7   | Data hold after WR                       | 17          |     | t <sub>CLCL</sub> -25    |                                      | 5           |     | ns   |
| t <sub>QVWH</sub>   | 7      | Data valid to WR high                    | 162         |     | 7t <sub>CLCL</sub> -130  |                                      | 82          |     | ns   |
| t <sub>RLAZ</sub>   | 6, 7   | RD low to address float                  |             | 0   |                          | 0                                    |             | 0   | ns   |
| t <sub>WHLH</sub>   | 6, 7   | RD or WR high to ALE high                | 17          | 67  | t <sub>CLCL</sub> -25    | t <sub>CLCL</sub> +25                | 5           | 5   | ns   |
| External C          | lock   |                                          |             |     |                          |                                      |             |     | L    |
| tCHCX               | 9      | High time                                | 17          |     | 17                       | tCLCL-tCLCX                          |             |     | ns   |
| t <sub>CLCX</sub>   | 9      | Low time                                 | 17          |     | 17                       | t <sub>CLCL</sub> -t <sub>CHCX</sub> |             |     | ns   |
| t <sub>CLCH</sub>   | 9      | Rise time                                |             | 5   |                          | 5                                    |             |     | ns   |
| t <sub>CHCL</sub>   | 9      | Fall time                                |             | 5   |                          | 5                                    |             |     | ns   |
| Shift Regi          | ster   | •                                        | -           | -   |                          | •                                    |             | -   |      |
| t <sub>XLXL</sub>   | 8      | Serial port clock cycle time             | 505         |     | 12t <sub>CLCL</sub>      |                                      | 363         |     | ns   |
| t <sub>QVXH</sub>   | 8      | Output data setup to clock rising edge   | 283         |     | 10t <sub>CLCL</sub> -133 |                                      | 170         |     | ns   |
| t <sub>XHQX</sub>   | 8      | Output data hold after clock rising edge | 3           |     | 2t <sub>CLCL</sub> -80   |                                      | 19          |     | ns   |
| t <sub>XHDX</sub>   | 8      | Input data hold after clock rising edge  | 0           |     | 0                        |                                      | 0           |     | ns   |
| t <sub>XHDV</sub>   | 8      | Clock rising edge to input data valid    |             | 283 |                          | 10t <sub>CLCL</sub> -133             |             | 170 | ns   |

NOTES:

Parameters are valid over operating temperature range unless otherwise specified.
 Load capacitance for port 0, ALE, and PSEN = 100pF, load capacitance for all other outputs = 80pF.
 Interfacing the 8XC52 to devices with float times up to 45ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.
 Variable clock is specified for oscillator frequencies greater than 16MHz to 33MHz. For frequencies equal or less than 16MHz, see 16MHz

"AC Electrial Characteristics", page 3-179.

80C32/87C52

### CMOS single-chip 8-bit microcontrollers

### **EXPLANATION OF THE AC SYMBOLS**

Each timing symbol has five characters. The first character is always 't' (= time). The other characters, depending on their positions, indicate the name of a signal or the logical status of that signal. The designations are:

- A Address
- C Clock
- D Input data
- H Logic level high
- I Instruction (program memory contents)
- L Logic level low, or ALE

- P PSEN
- Q Output data
- R RD signal
- t Time
- V Valid
- W- WR signal
- $X No \ \text{longer} \ a \ \text{valid} \ \text{logic} \ \text{level}$
- Z Float
- $\label{eq:tau} \begin{array}{l} \mbox{Examples: } t_{AVLL} = \mbox{Time for address valid to ALE low.} \\ t_{LLPL} = \mbox{Time for ALE low to } \overline{\mbox{PSEN}} \mbox{ low.} \end{array}$



Figure 5. External Program Memory Read Cycle



Figure 6. External Data Memory Read Cycle



Figure 7. External Data Memory Write Cycle



Figure 8. Shift Register Mode Timing



Figure 9. External Clock Drive











### 80C32/87C52









Figure 16.  $I_{CC}$  Test Condition, Power Down Mode All other pins are disconnected.  $V_{CC}$  = 2V to 5.5V

### 80C32/87C52

#### **EPROM CHARACTERISTICS**

The 87C52 is programmed by using a modified Quick-Pulse Programming<sup>TM</sup> algorithm. It differs from older methods in the value used for V<sub>PP</sub> (programming supply voltage) and in the width and number of the ALE/PROG pulses.

The 87C52 contains two signature bytes that can be read and used by an EPROM programming system to identify the device. The signature bytes identify the device as an 87C52 manufactured by Philips.

Table 6 shows the logic levels for reading the signature byte, and for programming the program memory, the encryption table, and the security bits. The circuit configuration and waveforms for quick-pulse programming are shown in Figures 17 and 18. Figure 19 shows the circuit configuration for normal program memory verification.

#### **Quick-Pulse Programming**

The setup for microcontroller quick-pulse programming is shown in Figure 17. Note that the 87C52 is running with a 4 to 6MHz oscillator. The reason the oscillator needs to be running is that the device is executing internal address and program data transfers.

The address of the EPROM location to be programmed is applied to ports 1 and 2, as shown in Figure 17. The code byte to be programmed into that location is applied to port 0. RST, <u>PSEN</u> and pins of ports 2 and 3 specified in Table 6 are held at the 'Program Code Data' levels indicated in Table 6. The ALE/PROG is pulsed low 25 times as shown in Figure 18.

To program the encryption table, repeat the 25 pulse programming sequence for addresses 0 through 1FH, using the 'Pgm Encryption Table' levels. Do not forget that after the encryption table is programmed, verification cycles will produce only encrypted data.

To program the security bits, repeat the 25 pulse programming sequence using the 'Pgm Security Bit' levels. After one security bit is programmed, further programming of the code memory and encryption table is disabled. However, the other security bit can still be programmed.

Note that the  $\overline{EA}/V_{PP}$  pin must not be allowed to go above the maximum specified  $V_{PP}$  level for any amount of time. Even a narrow glitch above that voltage can cause permanent damage to the device. The  $V_{PP}$  source should be well regulated and free of glitches and overshoot.

#### **Program Verification**

If security bit 2 has not been programmed, the on-chip program memory can be read out for program verification. The address of the program memory locations to be read is applied to ports 1 and 2 as shown in Figure 19. The other pins are held at the 'Verify Code Data' levels indicated in Table 6. The contents of the address location will be emitted on port 0. External pull-ups are required on port 0 for this operation.

If the encryption table has been programmed, the data presented at port 0 will be the exclusive NOR of the program byte with one of the encryption bytes. The user will have to know the encryption table contents in order to correctly decode the verification data. The encryption table itself cannot be read out.

#### **Reading the Signature Bytes**

The signature bytes are read by the same procedure as a normal verification of locations 030H and 031H, except that P3.6 and P3.7 need to be pulled to a logic low. The values are: (030H) = 15H indicates manufactured by Philips (031H) = 97H indicates 87C52

#### **Program/Verify Algorithms**

Any algorithm in agreement with the conditions listed in Table 6, and which satisfies the timing specifications, is suitable.

#### **Erasure Characteristics**

Erasure of the EPROM begins to occur when the chip is exposed to light with wavelengths shorter than approximately 4,000 angstroms. Since sunlight and fluorescent lighting have wavelengths in this range, exposure to these light sources over an extended time (about 1 week in sunlight, or 3 years in room level fluorescent lighting) could cause inadvertent erasure. For this and secondary effects, it is recommended that an opaque label be placed over the window. For elevated temperature or environments where solvents are being used, apply Kapton tape Fluorglas part number 2345–5, or equivalent.

The recommended erasure procedure is exposure to ultraviolet light (at 2537 angstroms) to an integrated dose of at least 15W-s/cm<sup>2</sup>. Exposing the EPROM to an ultraviolet lamp of 12,000 $\mu$ W/cm<sup>2</sup> rating for 20 to 39 minutes, at a distance of about 1 inch, should be sufficient.

Erasure leaves the array in an all 1s state.

| MODE                 | RST | PSEN | ALE/PROG | EA/V <sub>PP</sub> | P2.7 | P2.6 | P3.7 | P3.6 |
|----------------------|-----|------|----------|--------------------|------|------|------|------|
| Read signature       | 1   | 0    | 1        | 1                  | 0    | 0    | 0    | 0    |
| Program code data    | 1   | 0    | 0*       | V <sub>PP</sub>    | 1    | 0    | 1    | 1    |
| Verify code data     | 1   | 0    | 1        | 1                  | 0    | 0    | 1    | 1    |
| Pgm encryption table | 1   | 0    | 0*       | V <sub>PP</sub>    | 1    | 0    | 1    | 0    |
| Pgm security bit 1   | 1   | 0    | 0*       | V <sub>PP</sub>    | 1    | 1    | 1    | 1    |
| Pgm security bit 2   | 1   | 0    | 0*       | V <sub>PP</sub>    | 1    | 1    | 0    | 0    |

#### Table 6. EPROM Programming Modes

NOTES:

<sup>1. &#</sup>x27;0' = Valid low for that pin, '1' = valid high for that pin.

<sup>2.</sup>  $V_{PP} = 12.75V \pm 0.25V.$ 

<sup>3.</sup>  $V_{CC} = 5V \pm 10\%$  during programming and verification.

 <sup>\*</sup>ALE/PROG receives 25 programming pulses while V<sub>PP</sub> is held at 12.75V. Each programming pulse is low for 100μs (±10μs) and high for a minimum of 10μs.

<sup>&</sup>lt;sup>™</sup>Trademark phrase of Intel Corporation.



Figure 17. Programming Configuration



Figure 18. PROG Waveform



Figure 19. Program Verification

### 80C32/87C52

#### EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS

 $T_{amb} = 21^{\circ}C$  to +27°C,  $V_{CC} = 5V\pm10\%$ ,  $V_{SS} = 0V$  (See Figure 20)

| SYMBOL              | PARAMETER                         | MIN                 | MAX                 | UNIT |
|---------------------|-----------------------------------|---------------------|---------------------|------|
| V <sub>PP</sub>     | Programming supply voltage        | 12.5                | 13.0                | V    |
| I <sub>PP</sub>     | Programming supply current        |                     | 50                  | mA   |
| 1/t <sub>CLCL</sub> | Oscillator frequency              | 4                   | 6                   | MHz  |
| t <sub>AVGL</sub>   | Address setup to PROG low         | 48t <sub>CLCL</sub> |                     |      |
| t <sub>GHAX</sub>   | Address hold after PROG           | 48t <sub>CLCL</sub> |                     |      |
| t <sub>DVGL</sub>   | Data setup to PROG low            | 48t <sub>CLCL</sub> |                     |      |
| t <sub>GHDX</sub>   | Data hold after PROG              | 48t <sub>CLCL</sub> |                     |      |
| t <sub>EHSH</sub>   | P2.7 (ENABLE) high to VPP         | 48t <sub>CLCL</sub> |                     |      |
| t <sub>SHGL</sub>   | V <sub>PP</sub> setup to PROG low | 10                  |                     | μs   |
| t <sub>GHSL</sub>   | V <sub>PP</sub> hold after PROG   | 10                  |                     | μs   |
| t <sub>GLGH</sub>   | PROG width                        | 90                  | 110                 | μs   |
| t <sub>AVQV</sub>   | Address to data valid             |                     | 48t <sub>CLCL</sub> |      |
| t <sub>ELQZ</sub>   | ENABLE low to data valid          |                     | 48t <sub>CLCL</sub> |      |
| t <sub>EHQZ</sub>   | Data float after ENABLE           | 0                   | 48t <sub>CLCL</sub> |      |
| t <sub>GHGL</sub>   | PROG high to PROG low             | 10                  |                     | μs   |



#### NOTE:

FOR PROGRAMMING VERIFICATION SEE FIGURE 17.

FOR VERIFICATION CONDITIONS SEE FIGURE 19.

