

# 80C52/80C32 CHMOS SINGLE-CHIP 8-BIT MICROCOMPUTER

80C52—8K Bytes of Factory Mask Programmable ROM 80C32—CPU with RAM and I/O 80C52/80C32—3.5 MHz to 12 MHz,  $V_{CC}=5V\pm20\%$  80C52-1/80C32-1—3.5 MHz to 16 MHz,  $V_{CC}=5V\pm20\%$ 

- Three 16-Bit Timer/Counters — Timer 2 is an Up/Down Timer/Counter and Capture
- Power Off Flag
- 256 Bytes of On-Chip Data RAM
- **■** Boolean Processor
- 32 Programmable I/O Lines
- **■** 6 Interrupt Sources
- Programmable Serial Channel with:
  - Framing Error Detection
  - Automatic Address Recognition

- TTL and CMOS Compatible Logic Levels
- 64K External Program Memory Space
- **64K External Data Memory Space**
- MCS®-51 Fully Compatible Instruction
- Power Saving Idle and Power Down Modes
- ONCE™ (On-Circuit Emulation) Mode

#### **MEMORY ORGANIZATION**

PROGRAM MEMORY: Up to 8K bytes of the program memory can reside in the on-chip ROM (80C52 only). In addition the device can address up to 64K of program memory external to the chip.

DATA MEMORY: This microcontroller has a 256 x 8 on-chip RAM. In addition it can address up to 64K bytes of external data memory.

The Intel 80C52 is a single-chip control oriented microcontroller which is fabricated on Intel's reliable CHMOS III technology. Being a member of the 8051 family, the 80C52 uses the same powerful instruction set, has the same architecture, and is pin for pin compatible with the existing MCS-51 products. The 80C52 is an enhanced version of the 80C51BH. It's added features make it an even more powerful microcontroller for applications that require up/down counting capabilities such as motor control or a more versatile serial channel to facilitate multi-processor communications.

For the remainder of this document, the 80C52 and 80C32 will be referred to as the 80C52.

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied. Information contained herein supersedes previously published specifications on these devices from Intel. April 1989

Order Number: 270757-001



Figure 1. 80C52 Block Diagram



#### **PACKAGES**

| Part           | Prefix      | Package Type                                       |
|----------------|-------------|----------------------------------------------------|
| 80C52<br>80C32 | P<br>D<br>N | 40-Pin Plastic DIP<br>40-Pin CERDIP<br>44-Pin PLCC |



Figure 2. Pin Connections

### PIN DESCRIPTIONS

V<sub>CC</sub>: Supply voltage.

V<sub>SS</sub>: Circuit ground.

Port 0: Port 0 is an 8-bit, open drain, bidirectional I/O port. As an output port each pin can sink several LS TTL inputs. Port 0 pins that have 1's written to them float, and in that state 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 pullups when emitting1's, and can source and sink several LS TTL inputs.

Port 0 outputs the code bytes during program verification on the 80C52. External pullup resistors are required during program verification.

Port 1: Port 1 is an 8-bit bidirectional I/O port with internal pullups. The Port 1 output buffers can drive LS TTL inputs. Port 1 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (I<sub>IL</sub>, on the data sheet) because of the internal pullups.

In addition, Port 1 serves the functions of the following special features of the 80C52:

| Port Pin | Alternate Function                                                        |
|----------|---------------------------------------------------------------------------|
| P1.0     | T2 (External Count Input to<br>Timer/Counter 2)                           |
| P1.1     | T2EX (Timer/Counter 2<br>Capture/Reload Trigger<br>and Direction Control) |

Port 1 receives the low-order address bytes during ROM verification.

Port 2: Port 2 is an 8-bit bidirectional I/O port with internal pullups. The Port 2 output buffers can drive LS TTL inputs. Port 2 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (I<sub>IL</sub>, on the data sheet) because of the internal pullups.



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 pullups when emitting 1's. During accesses to external Data Memory that use 8-bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register.

Some Port 2 pins receive the high-order address bits during program verification.

Port 3: Port 3 is an 8-bit bidirectional I/O port with internal pullups. The Port 3 output buffers can drive LS TTL inputs. Port 3 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (I<sub>IL</sub>, on the data sheet) because of the pullurs

Port 3 also serves the functions of various special features of the MCS-51 Family, as listed below:

| Port Pin | Alternate Function                     |
|----------|----------------------------------------|
| P3.0     | RXD (serial input port)                |
| P3.1     | TXD (serial output port)               |
| P3.2     | INTO (external interrupt 0)            |
| P3.3     | INT1 (external interrupt 1)            |
| P3.4     | T0 (Timer 0 external input)            |
| P3.5     | T1 (Timer 1 external input)            |
| P3.6     | WR (external data memory write strobe) |
| P3.7     | RD (external data memory read strobe)  |

RST: Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device. An internal pulldown resistor permits a power-on reset with only a capacitor connected to V<sub>CC</sub>.

ALE: Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory.

In normal operation ALE is emitted at a constant rate of  $\frac{1}{6}$  the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external Data Memory.

PSEN: Program Store Enable is the read strobe to external Program Memory.

When the 80C52 is executing code from external Program Memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external Data Memory.

EA/V<sub>PP</sub>: External Access enable. EA must be strapped to V<sub>SS</sub> in order to enable the device to fetch code from external Program Memory locations 0000H to 0FFFFH.

 $\overline{\text{EA}}$  should be strapped to  $V_{CC}$  for internal program executions.

XTAL1: Input to the inverting oscillator amplifier.

XTAL2: Output from the inverting oscillator amplifier.

#### **OSCILLATOR CHARACTERISTICS**

XTAL1 and XTAL2 are the input and output, respectively, of a inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 3. Either a quartz crystal or ceramic resonator may be used. More detailed information concerning the use of the on-chip oscillator is available in Application Note AP-155, "Oscillators for Microcontrollers."

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



Figure 3. Oscillator Connections





Figure 4. External Clock Drive Configuration

#### **IDLE MODE**

The user's software can invoke the Idle Mode. When the microcontroller is in this mode, power consumption is reduced. The Special Function Registers and the onboard RAM retain their values during Idle, but the processor stops executing instructions. Idle Mode will be exited if the chip is reset or if an enabled interrupt occurs.

# **POWER DOWN MODE**

To save even more power, a Power Down mode can be invoked by software. In this mode, the oscillator is stopped and the instruction that invoked Power Down is the last instruction executed. The on-chip RAM and Special Function Registers retain their values until the Power Down mode is terminated.

On the 80C52 either a hardware reset or an external interrupt can cause an exit from Power Down. Reset redefines all the SFRs but does not change the onchip RAM. An external interrupt allows both the SFRs and on-chip RAM to retain their values.

To properly terminate Power Down the reset or external interrupt should not be executed before  $V_{CC}$  is restored to its normal operating level and must be

held active long enough for the oscillator to restart and stabilize (normally less than 10 ms).

With an external interrupt, INTO and INT1 must be enabled and configured as level-sensitive. Holding the pin low restarts the oscillator but bringing the pin back high completes the exit. Once the interrupt is serviced, the next instruction to be executed after RETI will be the one following the instruction that put the device into Power Down.

#### **DESIGN CONSIDERATION**

- When the idle mode is terminated by a hardware reset, the device normally resumes program execution, from where it left off, up to two machine cycles before the internal reset algorithm takes control. On-chip hardware inhibits access to internal RAM in this event, but access to the port pins is not inhibited. To eliminate the possibility of an unexpected write when Idle is terminated by reset, the instruction following the one that invokes Idle should not be one that writes to a port pin or to external memory.
- Writing to unspecified SFR's (see Table 3) may cause unpredictable operation.

#### ONCETM MODE

The ONCE ("On-Circuit Emulation") Mode facilitates testing and debugging of systems using the 80C52 without the 80C52 having to be removed from the circuit. The ONCE Mode is invoked by:

- 1) Pull ALE low while the device is in reset and PSEN is high;
- 2) Hold ALE low as RST is deactivated.

While the device is in ONCE Mode, the Port 0 pins go into a float state, and the other port pins and ALE and PSEN are weakly pulled high. The oscillator circuit remains active. While the 80C52 is in this mode, an emulator or test CPU can be used to drive the circuit. Normal operation is restored when a normal reset is applied.

Table 1. Status of the External Pins during Idle and Power Down

| Table 1. States 5. the |                   |     |      |       |       |         |       |
|------------------------|-------------------|-----|------|-------|-------|---------|-------|
| Mode                   | Program<br>Memory | ALE | PSEN | PORT0 | PORT1 | PORT2   | PORT3 |
| 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  |

#### NOTE

For more detailed information on the reduced power modes refer to current Embedded Controller Handbook, and Application Note AP-252, "Designing with the 80C51BH."



### **ABSOLUTE MAXIMUM RATINGS\***

| Ambient Temperature Under Bias 0°C to +70°C                      |
|------------------------------------------------------------------|
| Storage Temperature65°C to +150°C                                |
| Voltage on EA/V <sub>PP</sub> Pin to V <sub>SS</sub> 0V to +6.5V |
| Voltage on Any Other Pin to $V_{SS} \ \dots -0.5 V$ to $+6.5 V$  |
| Maximum I <sub>OL</sub> per I/O Pin15 mA                         |
| Power Dissipation                                                |

\*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 these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

NOTICE: Specifications contained within the following tables are subject to change.

# **D.C. CHARACTERISTICS:** $T_A = 0$ °C to +70°C; $V_{CC} = 5V \pm 10$ %; $V_{SS} = 0V$

| Symbol           | Parameter                                                                                         | Min                                                                  | Typical<br>(4) | Max                       | Unit           | Test Conditions                                                                           |
|------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------|---------------------------|----------------|-------------------------------------------------------------------------------------------|
| VIL              | Input Low Voltage (Except EA)                                                                     | -0.5                                                                 |                | 0.2 V <sub>CC</sub> - 0.1 | ٧              |                                                                                           |
| V <sub>IL1</sub> | Input Low Voltage EA                                                                              | 0                                                                    |                | 0.2 V <sub>CC</sub> -0.3  | ٧              |                                                                                           |
| V <sub>IH</sub>  | Input High Voltage<br>(Except XTAL1, RST)                                                         | 0.2 V <sub>CC</sub> + 0.9                                            |                | V <sub>CC</sub> +0.5      | ٧              |                                                                                           |
| V <sub>IH1</sub> | Input High Voltage<br>(XTAL1, RST)                                                                | 0.7 V <sub>CC</sub>                                                  |                | V <sub>CC</sub> +0.5      | ٧              |                                                                                           |
| V <sub>OL</sub>  | Output Low Voltage (5)<br>(Ports 1, 2 and 3, ALE/PROG, PSEN)                                      |                                                                      |                | 0.3<br>0.45<br>1.0        | V              | $I_{OL} = 100 \mu\text{A}$<br>$I_{OL} = 1.6 \text{mA}$ (1)<br>$I_{OL} = 3.5 \text{mA}$    |
| V <sub>OL1</sub> | Output Low Voltage (5)<br>(Port 0)                                                                |                                                                      |                | 0.3<br>0.45<br>1.0        | V              | $I_{OL} = 200 \mu\text{A}$<br>$I_{OL} = 3.2 \text{mA}$ (1)<br>$I_{OL} = 7.0 \text{mA}$    |
| V <sub>OH</sub>  | Output High Voltage<br>(Ports 1, 2 and 3<br>ALE/PROG and PSEN)                                    | V <sub>CC</sub> -0.3<br>V <sub>CC</sub> -0.7<br>V <sub>CC</sub> -1.5 |                |                           | V              | $I_{OH} = -10 \mu A$ $I_{OH} = -30 \mu A$ (2) $I_{OH} = -60 \mu A$                        |
| V <sub>OH1</sub> | Output High Voltage<br>(Port 0 in External Bus Mode)                                              | V <sub>CC</sub> -0.3<br>V <sub>CC</sub> -0.7<br>V <sub>CC</sub> -1.5 |                |                           | V              | $I_{OH} = -200 \mu\text{A}$<br>$I_{OH} = -3.2 \text{mA}$ (2)<br>$I_{OH} = -7.0 \text{mA}$ |
| կլ               | Logical 0 Input Current<br>(Ports 1, 2, and 3)                                                    |                                                                      | -10            | - 50                      | μΑ             | V <sub>IN</sub> = 0.45V                                                                   |
| Iլլ              | Input leakage Current<br>(Port 0)                                                                 |                                                                      | 0.02           | ± 10                      | μΑ             | 0 < V <sub>IN</sub> < V <sub>CC</sub>                                                     |
| I <sub>TL</sub>  | Logical 1 to 0 Transition Current (Ports 1, 2, and 3)                                             |                                                                      | -265           | -650                      | μΑ             | V <sub>IN</sub> = 2V                                                                      |
| RRST             | RST Pulldown Resistor                                                                             | 40                                                                   | 100            | 225                       | ΚΩ             |                                                                                           |
| CIO              | Pin Capacitance                                                                                   |                                                                      | 10             |                           | рF             | (Note 6)                                                                                  |
| Icc              | Power Supply Current: Running at 12 MHz (Figure 5) Idle Mode at 12 MHz (Figure 5) Power Down Mode |                                                                      | 15<br>5<br>5   | 7.5<br>75                 | mA<br>mA<br>μA | (Note 3)                                                                                  |



#### NOTES:

- 1. Capacitive loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the Vols of ALE and Ports 1, 2, 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 applications where capacitance loading exceeds 100 pFs, the noise pulse on the ALE signal may exceed 0.8V. In these cases, it may be desirable to qualify ALE with a Schmitt Trigger, or use an Address
- Latch with a Schmitt Trigger Strobe input. 2. Capacitive loading on Ports 0 and 2 cause the VOH on ALE and PSEN to drop below the 0.9 VCC specification when the address lines are stabilizing.
- See Figures 6–9 for test conditions. Minimum V<sub>CC</sub> for power down is 2V.
- 4. Typicals are based on limited number of samples, and are not guaranteed. The values listed are at room temperature and
- 5. Under steady state (non-transient) conditions, IOL must be externally limited as follows:

Maximum IOL per port pin:

Maximum IOL per 8-bit port -

Port 0: 26 mA

Ports 1, 2, and 3: 15 mA

Maximum total IOL for all output pins: 71 mA

If IOL exceeds the test condition, Vol. may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

6. CIO is the adjacent pin capacitance inherent to the package.



Figure 5. I<sub>CC</sub> vs Frequency



Figure 7. I<sub>CC</sub> Test Condition Idle Mode



Figure 6. I<sub>CC</sub> Test Condition, Active Mode



Figure 8. I<sub>CC</sub> Test Condition, Power Down Mode.  $V_{CC} = 2.0V \text{ to 6.0V}.$ 



Figure 9. Clock Signal Waveform for I<sub>CC</sub> Tests in Active and Idle Modes. TCLCH = TCHCL = 5 ns.



# **EXPLANATION OF THE AC SYMBOLS**

Each timing symbol has 5 characters. The first character is always a 'T' (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.

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 longer a valid logic level

Z: Float

For example,

TAVLL = Time from Address Valid to ALE Low

TLLPL = Time from ALE Low to PSEN Low

**A.C. CHARACTERISTICS**  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ ,  $V_{CC} = 5V \pm 20\%$ ,  $V_{SS} = 0V$ , Load Capacitance for Port 0. ALE and  $\overline{PSEN} = 100$  pF, Load Capacitance for All Other Outputs = 80 pF

# **EXTERNAL PROGRAM MEMORY CHARACTERISTICS**

| Cumbal  | Parameter                                | 12 MHz | Oscillator | Variable (   | Variable Oscillator |       |  |
|---------|------------------------------------------|--------|------------|--------------|---------------------|-------|--|
| Symbol  | Parameter                                | Min    | Max        | Min          | Max                 | Units |  |
| 1/TCLCL | Oscillator Frequency<br>80C52<br>80C52-1 |        |            | 3.5<br>3.5   | 12<br>16            | MHz   |  |
| TLHLL   | ALE Pulse Width                          | 127    |            | 2TCLCL-40    |                     | ns    |  |
| TAVLL   | Address Valid to ALE Low                 | 43     |            | TCLCL-40     |                     | ns    |  |
| TLLAX   | Address Hold After ALE Low               | 53     |            | TCLCL-30     |                     | ns    |  |
| TLLIV   | ALE Low to Valid Instruction In          |        | 234        |              | 4TCLCL - 100        | ns    |  |
| TLLPL   | ALE Low to PSEN Low                      | 53     |            | TCLCL-30     |                     | ns    |  |
| TPLPH   | PSEN Pulse Width                         | 205    |            | 3TCLCL-45    |                     | ns    |  |
| TPLIV   | PSEN Low to Valid Instruction In         |        | 145        |              | 3TCLCL - 105        | ns    |  |
| TPXIX   | Input Instruction Hold After PSEN        | 0      |            | 0            |                     | ns    |  |
| TPXIZ   | Input Instruction Float After PSEN       |        | 59         |              | TCLCL-25            | ns    |  |
| TAVIV   | Address to Valid Instruction In          |        | 312        |              | 5TCLCL - 105        | ns    |  |
| TPLAZ   | PSEN Low to Address Float                |        | 10         |              | 10                  | ns    |  |
| TRLRH   | RD Pulse Width                           | 400    | -          | 6TCLCL - 100 |                     | ns    |  |
| TWLWH   | WR Pulse Width                           | 400    |            | 6TCLCL - 100 |                     | ns    |  |
| TRLDV   | RD Low to Valid Data In                  |        | 252        |              | 5TCLCL 165          | ns    |  |
| TRHDX   | Data Hold After RD                       | 0      |            | 0            |                     | ns    |  |
| TRHDZ   | Data Float After RD                      |        | 107        |              | 2TCLCL-60           | ns    |  |
| TLLDV   | ALE Low to Valid Data In                 |        | 517        |              | 8TCLCL - 150        | ns    |  |
| TAVDV   | Address to Valid Data In                 |        | 585        |              | 9TCLCL - 165        | ns    |  |
| TLLWL   | ALE Low to RD or WR Low                  | 200    | 300        | 3TCLCL - 50  | 3TCLCL + 50         | ns    |  |
| TAVWL   | Address Valid to RD or WR Low            | 203    |            | 4TCLCL - 130 |                     | ns    |  |
| TQVWX   | Data Valid to WR Transition              | 33     |            | TCLCL-50     |                     | ns    |  |
| TWHQX   | Data Hold after WR                       | 33     |            | TCLCL - 50   |                     | ns    |  |
| TQVWH   | Data Valid to WR High                    | 433    |            | 7TCLCL - 150 |                     | ns    |  |
| TRLAZ   | RD Low to Address Float                  |        | 0          |              | 0                   | ns    |  |
| TWHLH   | RD or WR High to ALE High                | 43     | 123        | TCLCL-40     | TCLCL+40            | ns    |  |



# EXTERNAL PROGRAM MEMORY READ CYCLE



### **EXTERNAL DATA MEMORY READ CYCLE**





# **EXTERNAL DATA MEMORY WRITE CYCLE**



#### A.C. TESTING INPUT





For timing purposes a port pin is no longer floating when a 100 mV change from load voltage occurs, and begins to float when a 100 mV change from the loaded  $V_{OH}/V_{OL}$  level occurs.  $I_{OL}/I_{OH} \ge \pm 20$  mA.

# SERIAL PORT TIMING—SHIFT REGISTER MODE

**Test Conditions:**  $T_A = 0^{\circ}C$  to  $+70^{\circ}C$ ;  $V_{CC} = 5V \pm 20\%$ ;  $V_{SS} = 0V$ ; Load Capacitance = 80 pF

| Symbol Parameter |                                             | 12 MHz Oscillator |     | Variable      | Units       |    |
|------------------|---------------------------------------------|-------------------|-----|---------------|-------------|----|
| Symbol           | Parameter                                   | Min               | Max | Min           | Max         |    |
| TXLXL            | Serial Port Clock Cycle Time                | 1                 |     | 12TCLCL       |             | μs |
| TQVXH            | Output Data Setup to Clock<br>Rising Edge   | 700               |     | 10TCLCL - 133 |             | ns |
| TXHQX            | Output Data Hold after<br>Clock Rising Edge | 50                |     | 2TCLCL-117    |             | ns |
| TXHDX            | Input Data Hold After Clock<br>Rising Edge  | 0                 |     | 0             |             | ns |
| TXHDV            | Clock Rising Edge to Input<br>Data Valid    |                   | 700 |               | 10TCLCL 133 | ns |



### SHIFT REGISTER MODE TIMING WAVEFORMS



#### **EXTERNAL CLOCK DRIVE**

| Symbol  | Parameter            | Min | Max | Units |
|---------|----------------------|-----|-----|-------|
| 1/TCLCL | Oscillator Frequency |     |     | MHz   |
|         | 80C52/80C32          | 3.5 | 12  |       |
|         | 80C52-1/80C32-1      | 3.5 | 16  |       |
| TCHCX   | High Time            | 20  |     | ns    |
| TCLCX   | Low Time             | 20  |     | ns    |
| TCLCH   | Rise Time            |     | 20  | ns    |
| TCHCL   | Fall Time            |     | 20  | ns    |

# **EXTERNAL CLOCK DRIVE WAVEFORM**





#### **ROM CHARACTERISTICS**

Table 2 shows the logic levels for verifying the code data and reading the signature bytes on the 80C52.

Table 2. ROM Modes

| Mode             | RST | PSEN | ALE | ĒĀ | P2.7 | P2.6 | P3.6 | P3.7 |
|------------------|-----|------|-----|----|------|------|------|------|
| Verify Code Data | 1   | 0    | 1   | 1  | 0    | 0    | 1    | 11   |
| Read Signature   | 1   | 0    | 1   | 1  | 0    | 0    | 0    | 0    |

#### NOTES:

"1" = Valid high for that pin

"0" = Valid low for that pin

# **Program Verification**

The address of the Program Memory location to be read is applied to Port 1 and pins P2.0-P2.4. The other pins should be held at the "Verify" levels indicated in Table 2. The contents of the addressed lo-

cations will come out on Port 0. External pullups are required on Port 0 for this operation.

Figure 10 shows the setup for verifying the program memory.



Figure 10. Verifying the ROM

#### **ROM VERIFICATION CHARACTERISTICS**

 $T_A = 21^{\circ}C \text{ to } 27^{\circ}C; V_{CC} = 5V \pm 0.25V; V_{SS} = 0V$ 

# ADVANCED INFORMATION—CONTACT INTEL FOR DESIGN-IN INFORMATION

| Symbol  | Parameter                | Min | Max     | Units |
|---------|--------------------------|-----|---------|-------|
| 1/TCLCL | Oscillator Frequency     | 4   | 6       | MHz   |
| TAVQV   | Address to Data Valid    |     | 48TCLCL |       |
| TELQV   | ENABLE Low to Data Valid |     | 48TCLCL |       |
| TEHQZ   | Data Float after ENABLE  | 0   | 48TCLCL |       |



### **ROM VERIFICATION WAVEFORMS**



# **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 returned are:

(030H) = 89H indicates manufacture by Intel

(031H) = 53H indicates 80C52

Table 3. 80C52 Special Function Registers

|         | Table of total openial randition riegisters |             |  |  |  |  |  |  |  |
|---------|---------------------------------------------|-------------|--|--|--|--|--|--|--|
| Address | Name                                        | Reset Value |  |  |  |  |  |  |  |
| 80H     | P0*                                         | 11111111B   |  |  |  |  |  |  |  |
| 81H     | SP                                          | 00000111B   |  |  |  |  |  |  |  |
| 82H     | DPL                                         | 0000000B    |  |  |  |  |  |  |  |
| 83H     | DPH                                         | 0000000B    |  |  |  |  |  |  |  |
| 87H     | PCON                                        | 00XX0000B   |  |  |  |  |  |  |  |
| 88H     | TCON*                                       | 0000000B    |  |  |  |  |  |  |  |
| 89H     | TMOD                                        | 0000000B    |  |  |  |  |  |  |  |
| HA8     | TL0                                         | 00000000B   |  |  |  |  |  |  |  |
| 8BH     | TL1                                         | 00000000B   |  |  |  |  |  |  |  |
| 8CH     | THO                                         | 00000000B   |  |  |  |  |  |  |  |
| 8DH     | TH1                                         | 0000000B    |  |  |  |  |  |  |  |
| 90H     | P1*                                         | 11111111B   |  |  |  |  |  |  |  |
| 98H     | SCON*                                       | 0000000B    |  |  |  |  |  |  |  |
| 99H     | SBUF                                        | XXXXXXXXB   |  |  |  |  |  |  |  |
| 0A0H    | P2*                                         | 11111111B   |  |  |  |  |  |  |  |
| 0A8H    | IE*                                         | 00000000B   |  |  |  |  |  |  |  |
| 0A9H    | SADDR                                       | 00000000B   |  |  |  |  |  |  |  |
| 0B0H    | P3*                                         | 11111111B   |  |  |  |  |  |  |  |
| 0B8H    | IP*                                         | X0000000B   |  |  |  |  |  |  |  |
| 0B9H    | SADEN                                       | 00000000B   |  |  |  |  |  |  |  |
| 0C8H    | T2CON*                                      | 00000000B   |  |  |  |  |  |  |  |
| 0C9H    | T2MOD                                       | XXXXXXXX0B  |  |  |  |  |  |  |  |
| 0CAH    | RCAP2L                                      | 0000000B    |  |  |  |  |  |  |  |
| 0CBH    | RCAP2H                                      | 0000000B    |  |  |  |  |  |  |  |
| 0CCH    | TL2                                         | 0000000B    |  |  |  |  |  |  |  |
| 0CDH    | TH2                                         | 00000000B   |  |  |  |  |  |  |  |
| 0D0H    | PSW*                                        | 00000000B   |  |  |  |  |  |  |  |
| 0E0H    | ACC*                                        | 00000000B   |  |  |  |  |  |  |  |
| 0F0H    | B*                                          | 00000000B   |  |  |  |  |  |  |  |

<sup>\* =</sup> Bit Addressable