



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | 8051                                                                    |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 16MHz                                                                   |
| Connectivity               | EBI/EMI, UART/USART                                                     |
| Peripherals                | POR, PWM, WDT                                                           |
| Number of I/O              | 32                                                                      |
| Program Memory Size        | 32KB (32K x 8)                                                          |
| Program Memory Type        | ОТР                                                                     |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 512 x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                             |
| Data Converters            | -                                                                       |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 44-QFP                                                                  |
| Supplier Device Package    | 44-PQFP (10x10)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p87c51rc-4b-557 |
|                            |                                                                         |

Email: info@E-XFL.COM

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

#### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# LOGIC SYMBOL



# PIN CONFIGURATIONS

# **DUAL IN-LINE PACKAGE PIN FUNCTIONS**



# PLASTIC LEADED CHIP CARRIER PIN FUNCTIONS

| -       | -         |        | -   | -               |    |          |                    |
|---------|-----------|--------|-----|-----------------|----|----------|--------------------|
|         |           | 7      | 6   |                 | 40 | 39       |                    |
|         |           |        |     |                 |    | <u> </u> |                    |
|         |           | -      |     |                 |    | -        |                    |
|         |           |        | 18  |                 | 28 |          |                    |
|         |           |        |     |                 |    |          |                    |
| Pin     | Function  |        | Pin | Function        |    | Pin      | Function           |
| 1       | NIC*      |        | 16  | P3.4/T0         |    | 31       | P2.7/A15           |
| 2       | P1.0/T2   |        | 17  | P3.5/T1         |    | 32       | PSEN               |
| 3       | P1.1/T2EX |        | 18  | P3.6/WR         |    | 33       | ALE/PROG           |
| 4       | P1.2/ECI  |        | 19  | P3.7/RD         |    | 34       | NIC*               |
| 5       | P1.3/CEX0 |        | 20  | XTAL2           |    | 35       | EA/V <sub>PP</sub> |
| 6       | P1.4/CEX1 |        | 21  | XTAL1           |    | 36       | P0.7/AD7           |
| 7       | P1.5/CEX2 |        | 22  | V <sub>SS</sub> |    | 37       | P0.6/AD6           |
| 8       | P1.6/CEX3 |        | 23  | NIC*            |    | 38       | P0.5/AD5           |
| 9       | P1.7/CEX4 |        | 24  | P2.0/A8         |    | 39       | P0.4/AD4           |
| 10      | RST       |        | 25  | P2.1/A9         |    | 40       | P0.3/AD3           |
| 11      | P3.0/RxD  |        | 26  | P2.2/A10        |    | 41       | P0.2/AD2           |
| 12      | NIC*      |        | 27  | P2.3/A11        |    | 42       | P0.1/AD1           |
| 13      | P3.1/TxD  |        | 28  | P2.4/A12        |    | 43       | P0.0/AD0           |
| 14      | P3.2/INT0 |        | 29  | P2.5/A13        |    | 44       | V <sub>CC</sub>    |
| 15      | P3.3/INT1 |        | 30  | P2.6/A14        |    |          |                    |
| * NO IN | TERNAL CO | NECTIO | NC  |                 |    |          | SU00023            |

# PLASTIC QUAD FLAT PACK PIN FUNCTIONS



Philips Semiconductors

80C51 8-bit microcontroller family 8K–64K/256–1K OTP/ROM/ROMless, low voltage (2.7V–5.5V), low power, high speed (33MHz)

Product specification

|     | MEMORY SIZE<br>8K × 8 | MEMORY SIZE<br>16K × 8 | MEMORY SIZE 32K × 8 | MEMORY SIZE<br>64K × 8 | ROMless       | TEMPERATURE RANGE °C<br>AND PACKAGE | VOLTAGE<br>RANGE | FREQ.<br>(MHz) | DWG.<br># |
|-----|-----------------------|------------------------|---------------------|------------------------|---------------|-------------------------------------|------------------|----------------|-----------|
| ROM | P83C51RA+4N           | P83C51RB+4N            | P83C51RC+4N         | P83C51RD+4N            | P80C51RA+4N   | 0 to +70,                           | 2.7V to 5.5V     | 0 to 16        | SOT129-1  |
| OTP | P87C51RA+4N           | P87C51RB+4N            | P87C51RC+4N         | P87C51RD+4N            | F 60C5 TKA+4N | 40-Pin Plastic Dual In-line Pkg.    | 2.7 0 10 5.5 0   | 01010          | 301129-1  |
| ROM | P83C51RA+4A           | P83C51RB+4A            | P83C51RC+4A         | P83C51RD+4A            | P80C51RA+4A   | 0 to +70,                           | 2.7V to 5.5V     | 0.1- 10        | SOT187-2  |
| OTP | P87C51RA+4A           | P87C51RB+4A            | P87C51RC+4A         | P87C51RD+4A            | P60C51RA+4A   | 44-Pin Plastic Leaded Chip Carrier  | 2.7 V 10 5.5 V   | 0 to 16        | 301107-2  |
| ROM | P83C51RA+4B           | P83C51RB+4B            | P83C51RC+4B         | P83C51RD+4B            |               | 0 to +70,                           |                  | 0 40 40        | SOT307-2  |
| OTP | P87C51RA+4B           | P87C51RB+4B            | P87C51RC+4B         | P87C51RD+4B            | P80C51RA+4B   | 44-Pin Plastic Quad Flat Pack       | 2.7V to 5.5V     | 0 to 16        | 501307-2  |
| ROM | P83C51RA+5N           | P83C51RB+5N            | P83C51RC+5N         | P83C51RD+5N            |               | -40 to +85,                         |                  | 0.1.40         | 007400.4  |
| OTP | P87C51RA+5N           | P87C51RB+5N            | P87C51RC+5N         | P87C51RD+5N            | P80C51RA+5N   | 40-Pin Plastic Dual In-line Pkg.    | 2.7V to 5.5V     | 0 to 16        | SOT129-1  |
| ROM | P83C51RA+5A           | P83C51RB+5A            | P83C51RC+5A         | P83C51RD+5A            | Deeosta       | -40 to +85,                         |                  | 0 to 16        | 007407.0  |
| OTP | P87C51RA+5A           | P87C51RB+5A            | P87C51RC+5A         | P87C51RD+5A            | P80C51RA+5A   | 44-Pin Plastic Leaded Chip Carrier  | 2.7V to 5.5V     |                | SOT187-2  |
| ROM | P83C51RA+5B           | P83C51RB+5B            | P83C51RC+5B         | P83C51RD+5B            |               | -40 to +85,                         | 2.7V to 5.5V     | a              | 0.07007.0 |
| OTP | P87C51RA+5B           | P87C51RB+5B            | P87C51RC+5B         | P87C51RD+5B            | P80C51RA+5B   | 44-Pin Plastic Quad Flat Pack       |                  | 0 to 16        | SOT307-2  |
| ROM | P83C51RA+IN           | P83C51RB+IN            | P83C51RC+IN         | P83C51RD+IN            |               | 0 to +70,                           | E\/              | 0 to 33        | SOT129-1  |
| OTP | P87C51RA+IN           | P87C51RB+IN            | P87C51RC+IN         | P87C51RD+IN            | P80C51RA+IN   | 40-Pin Plastic Dual In-line Pkg.    | 5V               |                |           |
| ROM | P83C51RA+IA           | P83C51RB+IA            | P83C51RC+IA         | P83C51RD+IA            | P80C51RA+IA   | 0 to +70,                           | 5V               | 0 to 33        | SOT197 2  |
| OTP | P87C51RA+IA           | P87C51RB+IA            | P87C51RC+IA         | P87C51RD+IA            | POUCSTRATIA   | 44-Pin Plastic Leaded Chip Carrier  | 50               | 0 10 33        | SOT187-2  |
| ROM | P83C51RA+IB           | P83C51RB+IB            | P83C51RC+IB         | P83C51RD+IB            | P80C51RA+IB   | 0 to +70,                           | 5V               | 0 to 33        | SOT307-2  |
| OTP | P87C51RA+IB           | P87C51RB+IB            | P87C51RC+IB         | P87C51RD+IB            | POUCSTRATID   | 44-Pin Plastic Quad Flat Pack       | 50               | 0 10 33        | 501307-2  |
| ROM | P83C51RA+JN           | P83C51RB+JN            | P83C51RC+JN         | P83C51RD+JN            |               | -40 to +85,                         | <b>E</b> V(      | 0.45.00        | 007400.4  |
| OTP | P87C51RA+JN           | P87C51RB+JN            | P87C51RC+JN         | P87C51RD+JN            | P80C51RA+JN   | 40-Pin Plastic Dual In-line Pkg.    | 5V               | 0 to 33        | SOT129-1  |
| ROM | P83C51RA+JA           | P83C51RB+JA            | P83C51RC+JA         | P83C51RD+JA            |               | -40 to +85,                         | 5) (             | a /            | 007/07.0  |
| OTP | P87C51RA+JA           | P87C51RB+JA            | P87C51RC+JA         | P87C51RD+JA            | P80C51RA+JA   | 44-Pin Plastic Leaded Chip Carrier  | 5V               | 0 to 33        | SOT187-2  |
| ROM | P83C51RA+JB           | P83C51RB+JB            | P83C51RC+JB         | P83C51RD+JB            |               | -40 to +85,                         |                  | 0 to 22        |           |
| OTP | P87C51RA+JB           | P87C51RB+JB            | P87C51RC+JB         | P87C51RD+JB            | P80C51RA+JB   | 44-Pin Plastic Quad Flat Pack       | 5V               | 0 to 33        | SOT307-2  |

Note: For Multi Time Programmable devices, See P89C51RX+ Flash datasheet.

# LOW POWER MODES

#### Stop Clock Mode

The static design enables the clock speed to be reduced down to 0 MHz (stopped). When the oscillator is stopped, the RAM and Special Function Registers retain their values. This mode allows step-by-step utilization and permits reduced system power consumption by lowering the clock frequency down to any value. For lowest power consumption the Power Down mode is suggested.

#### Idle Mode

In the idle mode (see Table 3), 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**

To save even more power, a Power Down mode (see Table 3) 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 down to 2.0V and care must be taken to return  $V_{CC}$  to the minimum specified operating voltages before the Power Down Mode is terminated.

Either a hardware reset or external interrupt can be used to exit from Power Down. Reset redefines all the SFRs but does not change the on-chip RAM. An external interrupt allows both the SFRs and the 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 10ms).

With an external interrupt, INT0 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.

#### LPEP

The LPEP bit (AUXR.4), only needs to be set for applications operating at  $V_{CC}$  less than 4V.

### **POWER OFF FLAG**

The Power Off Flag (POF) is set by on-chip circuitry when the V<sub>CC</sub> level on the 8XC51FX/8XC51RX+ rises from 0 to 5V. The POF bit can be set or cleared by software allowing a user to determine if the reset is the result of a power-on or a warm start after powerdown. The V<sub>CC</sub> level must remain above 3V for the POF to remain unaffected by the V<sub>CC</sub> level.

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

# **ONCE™ Mode**

The ONCE ("On-Circuit Emulation") Mode facilitates testing and debugging of systems without the device 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 device 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.

## **Programmable Clock-Out**

A 50% duty cycle clock can be programmed to come out on P1.0. This pin, besides being a regular I/O pin, has two alternate functions. It can be programmed:

- 1. to input the external clock for Timer/Counter 2, or
- 2. to output a 50% duty cycle clock ranging from 61Hz to 4MHz at a 16MHz operating frequency.

To configure the Timer/Counter 2 as a clock generator, bit  $C/\overline{T}2$  (in T2CON) must be cleared and bit T20E in T2MOD must be set. Bit TR2 (T2CON.2) also must be set to start the timer.

The Clock-Out frequency depends on the oscillator frequency and the reload value of Timer 2 capture registers (RCAP2H, RCAP2L) as shown in this equation:

 $\frac{\text{Oscillator Frequency}}{4 \times (65536 - \text{RCAP2H}, \text{RCAP2L})}$ 

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

In the Clock-Out mode Timer 2 roll-overs will not generate an interrupt. This is similar to when it is used as a baud-rate generator. It is possible to use Timer 2 as a baud-rate generator and a clock generator simultaneously. Note, however, that the baud-rate and the Clock-Out frequency will be the same.

## Table 3. External Pin Status During Idle and Power-Down Mode

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



Figure 4. Timer 2 in Auto-Reload Mode (DCEN = 0)



Figure 5. Timer 2 Auto Reload Mode (DCEN = 1)

When Timer 2 is in the baud rate generator mode, one should not try to read or write TH2 and TL2. As a baud rate generator, Timer 2 is incremented every state time (osc/2) or asynchronously from pin T2; under these conditions, a read or write of TH2 or TL2 may not be accurate. The RCAP2 registers may be read, but should not be written to, because a write might overlap a reload and cause write and/or reload errors. The timer should be turned off (clear TR2) before accessing the Timer 2 or RCAP2 registers.

Table 5 shows commonly used baud rates and how they can be obtained from Timer 2.

## Summary Of Baud Rate Equations

Timer 2 is in 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}$ 

If Timer 2 is being clocked internally , the baud rate is:

Baud Rate = 
$$\frac{I_{OSC}}{[32 \times [65536 - (RCAP2H, RCAP2L)]]}$$

Where f<sub>OSC</sub>= Oscillator Frequency

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

$$\text{RCAP2H, RCAP2L} = 65536 - \left(\frac{f_{\text{OSC}}}{32 \times \text{Baud Rate}}\right)$$

### **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 6 for set-up of Timer 2 as a timer. Also see Table 7 for set-up of Timer 2 as a counter.

# Table 6. Timer 2 as a Timer

|                                                         | T20                          | ON                           |
|---------------------------------------------------------|------------------------------|------------------------------|
| MODE                                                    | 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 7. Timer 2 as a Counter

|             | TMOD                         |                              |  |  |  |  |
|-------------|------------------------------|------------------------------|--|--|--|--|
| MODE        | 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.

|                                                             |              | SCON Add                      | dress = 98H                 |                               |                             |                                     |               |               | F           | Reset Value = 0000 0000B                                        |
|-------------------------------------------------------------|--------------|-------------------------------|-----------------------------|-------------------------------|-----------------------------|-------------------------------------|---------------|---------------|-------------|-----------------------------------------------------------------|
|                                                             | Bit Ac       | dressable                     |                             |                               |                             |                                     |               | 1             |             | _                                                               |
|                                                             |              | SM0/FE                        | SM1                         | SM2                           | REN                         | TB8                                 | RB8           | ті            | RI          |                                                                 |
|                                                             | Bit:         | 7                             | 6                           | 5                             | 4                           | 3                                   | 2             | 1             | 0           |                                                                 |
|                                                             |              | (SMOD0 =                      | 0/1)*                       |                               |                             |                                     |               |               |             |                                                                 |
| Symbol                                                      | Fun          | ction                         |                             |                               |                             |                                     |               |               |             |                                                                 |
| FE                                                          |              | ning Error b<br>nes but shou  |                             |                               |                             |                                     |               |               |             | t is not cleared by valid<br>e FE bit.                          |
| SM0                                                         | Seri         | al Port Mod                   | e Bit 0, (SN                | OD0 must                      | = 0 to acce                 | ss bit SM0)                         |               |               |             |                                                                 |
| SM1                                                         |              | al Port Mod                   |                             |                               |                             |                                     |               |               |             |                                                                 |
|                                                             | SMO          |                               | Mode                        |                               | iption                      | Baud Rate                           | **            |               |             |                                                                 |
|                                                             | 0            | 0                             | 0                           | shift re                      | 0                           | f <sub>OSC</sub> /12                |               |               |             |                                                                 |
|                                                             | 0<br>1       | 1<br>0                        | 1<br>2                      | 8-bit L<br>9-bit L            |                             | variable<br>f <sub>OSC</sub> /64 or | faaa/32       |               |             |                                                                 |
|                                                             | 1            | 1                             | 3                           | 9-bit L                       |                             | variable                            | 1090/32       |               |             |                                                                 |
| SM2                                                         | rece<br>In N | vived 9th dat                 | ta bit (RB8)<br>12 = 1 then | is 1, indica<br>RI will not b | ting an add<br>be activated | ress, and th<br>unless a va         | e received    | byte is a G   | iven or Bro | ot be set unless the<br>adcast Address.<br>e received byte is a |
| REN                                                         | Ena          | bles serial r                 | eception. S                 | et by softwa                  | are to enabl                | e reception.                        | Clear by s    | oftware to    | disable rec | eption.                                                         |
| TB8                                                         | The          | 9th data bit                  | that will be                | transmitted                   | in Modes                    | 2 and 3. Set                        | t or clear by | v software a  | as desired. |                                                                 |
| RB8                                                         |              | odes 2 and<br>lode 0, RB8     |                             |                               | was receiv                  | ed. In Mode                         | 1, if SM2 =   | = 0, RB8 is   | the stop bi | t that was received.                                            |
| ТІ                                                          |              | nsmit interru<br>er modes, in |                             |                               |                             |                                     |               | /lode 0, or a | at the begi | nning of the stop bit in the                                    |
| RI                                                          |              | eive interrup<br>other modes  |                             |                               |                             |                                     |               |               |             | ough the stop bit time in                                       |
| NOTE:<br>*SMOD0 is locate<br>**f <sub>OSC</sub> = oscillato |              |                               |                             |                               |                             |                                     |               |               |             | SU00043                                                         |

Figure 7. SCON: Serial Port Control Register

### Interrupt Priority Structure

The 8XC51FA/FB/FC and 8XC51RA+/RB+/RC+/RD+ have a 7-source four-level interrupt structure (see Table 8). The 80C54/58 have a 6-source four-level interrupt structure because these devices do not have a PCA.

There are 3 SFRs associated with the four-level interrupt. They are the IE, IP, and IPH. (See Figures 10, 11, and 12.) The IPH (Interrupt Priority High) register makes the four-level interrupt structure possible. The IPH is located at SFR address B7H. The structure of the IPH register and a description of its bits is shown in Figure 12.

The function of the IPH SFR is simple and when combined with the IP SFR determines the priority of each interrupt. The priority of each interrupt is determined as shown in the following table:

| PRIORI |      |                            |  |  |  |  |
|--------|------|----------------------------|--|--|--|--|
| IPH.x  | IP.x | INTERROFT FRIORITT LEVEL   |  |  |  |  |
| 0      | 0    | Level 0 (lowest priority)  |  |  |  |  |
| 0      | 1    | Level 1                    |  |  |  |  |
| 1      | 0    | Level 2                    |  |  |  |  |
| 1      | 1    | Level 3 (highest priority) |  |  |  |  |

The priority scheme for servicing the interrupts is the same as that for the 80C51, except there are four interrupt levels rather than two as on the 80C51. An interrupt will be serviced as long as an interrupt of equal or higher priority is not already being serviced. If an interrupt of equal or higher level priority is being serviced, the new interrupt will wait until it is finished before being serviced. If a lower priority level interrupt is being serviced, it will be stopped and the new interrupt serviced. When the new interrupt is finished, the lower priority level interrupt that was stopped will be completed.

## Table 8.Interrupt Table

| SOURCE | POLLING PRIORITY | REQUEST BITS        | HARDWARE CLEAR?                       | VECTOR ADDRESS |
|--------|------------------|---------------------|---------------------------------------|----------------|
| X0     | 1                | IE0                 | N (L) <sup>1</sup> Y (T) <sup>2</sup> | 03H            |
| ТО     | 2                | TF0                 | Y                                     | 0B             |
| X1     | 3                | IE1                 | N (L) Y (T)                           | 13             |
| T1     | 4                | TF1                 | Y                                     | 1B             |
| PCA    | 5                | CF, CCFn<br>n = 0–4 | N                                     | 33             |
| SP     | 6                | RI, TI              | N                                     | 23             |
| T2     | 7                | TF2, EXF2           | N                                     | 2B             |

NOTES:

L = Level activated

2. T = Transition activated

|      |           | 7      | 6                          | 5                        | 4         | 3                          | 2         | 1           | 0         |
|------|-----------|--------|----------------------------|--------------------------|-----------|----------------------------|-----------|-------------|-----------|
|      | IE (0A8H) | EA     | EC                         | ET2                      | ES        | ET1                        | EX1       | ET0         | EX0       |
|      |           |        | Bit = 1 ena<br>Bit = 0 dis | ables the i<br>ables it. | nterrupt. |                            |           |             |           |
| BIT  | SYMBOL    | FUNC   | TION                       |                          |           |                            |           |             |           |
| IE.7 | EA        |        |                            |                          |           | rrupts are<br>earing its e |           |             | each inte |
| IE.6 | EC        | PCA ir | nterrupt er                | hable bit fo             | or FX and | RX+ only                   | - otherwi | se it is no | t impleme |
| IE.5 | ET2       | Timer  | 2 interrup                 | t enable b               | it.       |                            |           |             |           |
| IE.4 | ES        | Serial | Port interr                | upt enabl                | e bit.    |                            |           |             |           |
| IE.3 | ET1       | Timer  | 1 interrup                 | t enable b               | it.       |                            |           |             |           |
| IE.2 | EX1       | Extern | al interrup                | t 1 enable               | e bit.    |                            |           |             |           |
| IE.1 | ET0       | Timer  | 0 interrup                 | t enable b               | it.       |                            |           |             |           |
| IE.0 | EX0       | Extern | al interrup                | ot 0 enable              | e bit.    |                            |           |             |           |



#### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# (8XC51FX and 8XC51RX+ ONLY)

| CCAPMn / | Address | CCAI<br>CCAI<br>CCAI<br>CCAI | PM1 0DE<br>PM2 0DC                    | SH<br>CH     |              |               |                  |                 | R                  | eset Value = X000 0000E              |
|----------|---------|------------------------------|---------------------------------------|--------------|--------------|---------------|------------------|-----------------|--------------------|--------------------------------------|
|          |         | CCA                          | PM4 ODE                               | H            |              |               |                  |                 |                    |                                      |
|          | Not Bit | Addressa                     | able                                  |              |              |               |                  |                 |                    | _                                    |
|          |         | -                            | ECOMn                                 | CAPPn        | CAPNn        | MATn          | TOGn             | PWMn            | ECCFn              |                                      |
|          | Bit:    | 7                            | 6                                     | 5            | 4            | 3             | 2                | 1               | 0                  | ]                                    |
| Symbol   | Funct   | ion                          |                                       |              |              |               |                  |                 |                    |                                      |
| _        | Not im  | plemente                     | ed, reserved                          | for future u | se*.         |               |                  |                 |                    |                                      |
| ECOMn    | Enable  | e Compar                     | rator. ECOM                           | n = 1 enabl  | es the comp  | parator fund  | ction.           |                 |                    |                                      |
| CAPPn    | Captu   | re Positiv                   | e, CAPPn =                            | 1 enables    | positive edg | e capture.    |                  |                 |                    |                                      |
| CAPNn    | Captu   | re Negati <sup>,</sup>       | ve, CAPNn =                           | = 1 enables  | negative e   | dge capture   | Э.               |                 |                    |                                      |
| MATn     |         |                              | IATn = 1, a r<br>set, flagging        |              |              | ter with this | module's c       | compare/ca      | pture registe      | er causes the CCFn bit               |
| TOGn     | 00      | e. When T<br>toggle.         | OGn = 1, a                            | match of th  | e PCA cour   | nter with thi | s module's       | compare/ca      | apture regis       | ter causes the CEXn                  |
| PWMn     | Pulse   | Width Mc                     | dulation Mo                           | de. PWMn     | = 1 enables  | the CEXn      | pin to be us     | sed as a pu     | lse width me       | odulated output.                     |
| ECCFn    | Enable  | e CCF int                    | errupt. Enab                          | les compar   | e/capture fl | ag CCFn ir    | the CCON         | register to     | generate ar        | n interrupt.                         |
|          |         |                              | eserved bits. The<br>1. The value rea | ,            |              |               | oducts to invoke | e new features. | . In that case, th | ne reset or inactive value of the ne |

| Figure 19  | CCAPMn: PCA   | Modules Con | nare/Canture  | Registers   |
|------------|---------------|-------------|---------------|-------------|
| rigule 13. | COAL MILL LOA | wouldes con | ipale/Gaptule | ricegisters |

| - | ECOMn | CAPPn | CAPNn | MATn | TOGn | PWMn | ECCFn | MODULE FUNCTION                                   |  |
|---|-------|-------|-------|------|------|------|-------|---------------------------------------------------|--|
| Х | 0     | 0     | 0     | 0    | 0    | 0    | 0     | No operation                                      |  |
| Х | Х     | 1     | 0     | 0    | 0    | 0    | Х     | 16-bit capture by a positive-edge trigger on CEXn |  |
| Х | Х     | 0     | 1     | 0    | 0    | 0    | Х     | 16-bit capture by a negative trigger on CEXn      |  |
| Х | Х     | 1     | 1     | 0    | 0    | 0    | Х     | 16-bit capture by a transition on CEXn            |  |
| Х | 1     | 0     | 0     | 1    | 0    | 0    | Х     | 16-bit Software Timer                             |  |
| Х | 1     | 0     | 0     | 1    | 1    | 0    | Х     | 16-bit High Speed Output                          |  |
| Х | 1     | 0     | 0     | 0    | 0    | 1    | 0     | 8-bit PWM                                         |  |
| Х | 1     | 0     | 0     | 1    | Х    | 0    | Х     | Watchdog Timer                                    |  |

Figure 20. PCA Module Modes (CCAPMn Register)

#### PCA Capture Mode

To use one of the PCA modules in the capture mode either one or both of the CCAPM bits CAPN and CAPP for that module must be set. The external CEX input for the module (on port 1) is sampled for a transition. When a valid transition occurs the PCA hardware loads the value of the PCA counter registers (CH and CL) into the module's capture registers (CCAPnL and CCAPnH). If the CCFn bit for the module in the CCON SFR and the ECCFn bit in the CCAPMn SFR are set then an interrupt will be generated. Refer to Figure 21.

#### 16-bit Software Timer Mode

The PCA modules can be used as software timers by setting both the ECOM and MAT bits in the modules CCAPMn register. The PCA timer will be compared to the module's capture registers and when a match occurs an interrupt will occur if the CCFn (CCON SFR) and the ECCFn (CCAPMn SFR) bits for the module are both set (see Figure 22).

#### High Speed Output Mode

In this mode the CEX output (on port 1) associated with the PCA module will toggle each time a match occurs between the PCA counter and the module's capture registers. To activate this mode the TOG, MAT, and ECOM bits in the module's CCAPMn SFR must be set (see Figure 23).

#### Pulse Width Modulator Mode

All of the PCA modules can be used as PWM outputs. Figure 24 shows the PWM function. The frequency of the output depends on the source for the PCA timer. All of the modules will have the same frequency of output because they all share the PCA timer. The duty cycle of each module is independently variable using the module's capture register CCAPLn. When the value of the PCA CL SFR is less than the value in the module's CCAPLn SFR the output will be low, when it is equal to or greater than the output will be high. When CL overflows from FF to 00, CCAPLn is reloaded with the value in CCAPHn. the allows updating the PWM without glitches. The PWM and ECOM bits in the module's CCAPMn register must be set to enable the PWM mode.

### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# (8XC51FX and 8XC51RX+ ONLY)



Figure 21. PCA Capture Mode



Figure 22. PCA Compare Mode

### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# (8XC51FX and 8XC51RX+ ONLY)



Figure 23. PCA High Speed Output Mode



Figure 24. PCA PWM Mode

#### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# (8XC51FX and 8XC51RX+ ONLY)



Figure 25. PCA Watchdog Timer m(Module 4 only)

#### PCA Watchdog Timer

An on-board watchdog timer is available with the PCA to improve the reliability of the system without increasing chip count. Watchdog timers are useful for systems that are susceptible to noise, power glitches, or electrostatic discharge. Module 4 is the only PCA module that can be programmed as a watchdog. However, this module can still be used for other modes if the watchdog is not needed.

Figure 25 shows a diagram of how the watchdog works. The user pre-loads a 16-bit value in the compare registers. Just like the other compare modes, this 16-bit value is compared to the PCA timer value. If a match is allowed to occur, an internal reset will be generated. This will not cause the RST pin to be driven high.

In order to hold off the reset, the user has three options:

- 1. periodically change the compare value so it will never match the PCA timer,
- 2. periodically change the PCA timer value so it will never match the compare values, or
- disable the watchdog by clearing the WDTE bit before a match occurs and then re-enable it.

The first two options are more reliable because the watchdog timer is never disabled as in option #3. If the program counter ever goes astray, a match will eventually occur and cause an internal reset. The second option is also not recommended if other PCA modules are being used. Remember, the PCA timer is the time base for **all** modules; changing the time base for other modules would not be a good idea. Thus, in most applications the first solution is the best option.

Figure 26 shows the code for initializing the watchdog timer. Module 4 can be configured in either compare mode, and the WDTE bit in CMOD must also be set. The user's software then must periodically change (CCAP4H,CCAP4L) to keep a match from occurring with the PCA timer (CH,CL). This code is given in the WATCHDOG routine in Figure 26.

This routine should not be part of an interrupt service routine, because if the program counter goes astray and gets stuck in an infinite loop, interrupts will still be serviced and the watchdog will keep getting reset. Thus, the purpose of the watchdog would be defeated. Instead, call this subroutine from the main program within  $2^{16}$  count of the PCA timer.

# (8XC51RX+ ONLY)

# Expanded Data RAM Addressing (8XC51RX+ ONLY)

The 8XC51RX+ have internal data memory that is mapped into four separate segments: the lower 128 bytes of RAM, upper 128 bytes of RAM, 128 bytes Special Function Register (SFR), and 256 bytes (768 for RD+) expanded RAM (EXTRAM).

The four segments are:

- 1. The Lower 128 bytes of RAM (addresses 00H to 7FH) are directly and indirectly addressable.
- 2. The Upper 128 bytes of RAM (addresses 80H to FFH) are indirectly addressable only.
- 3. The Special Function Registers, SFRs, (addresses 80H to FFH) are directly addressable only.
- 4. The 256-bytes (768 for RD+) expanded RAM ((EXTRAM (256-bytes) 00H-FFH)) and ((EXTRAM (768-bytes for RD+) 00H - 2FFH)) are indirectly accessed by move external instruction, MOVX, and with the EXTRAM bit cleared, see Figure 27.

The Lower 128 bytes can be accessed by either direct or indirect addressing. The Upper 128 bytes can be accessed by indirect addressing only. The Upper 128 bytes occupy the same address space as the SFR. That means they have the same address, but are physically separate from SFR space.

When an instruction accesses an internal location above address 7FH, the CPU knows whether the access is to the upper 128 bytes of data RAM or to SFR space by the addressing mode used in the instruction. Instructions that use direct addressing access SFR space. For example:

MOV 0A0H,#data

accesses the SFR at location 0A0H (which is P2). Instructions that use indirect addressing access the Upper 128 bytes of data RAM.

For example:

MOV @R0,#data

where R0 contains 0A0H, accesses the data byte at address 0A0H, rather than P2 (whose address is 0A0H).

The EXTRAM can be accessed by indirect addressing, with EXTRAM bit cleared and MOVX instructions. This part of memory is physically located on-chip, logically occupies the first 256-bytes (768 for RD+) of external data memory.

With EXTRAM = 0, the EXTRAM is indirectly addressed, using the MOVX instruction in combination with any of the registers R0, R1 of the selected bank or DPTR. An access to EXTRAM will not affect ports P0, P3.6 (WR#) and P3.7 (RD#). P2 SFR is output during external addressing. For example, with EXTRAM = 0,

MOVX @R0,#data

where R0 contains 0A0H, access the EXTRAM at address 0A0H rather than external memory. An access to external data memory locations higher than FFH (2FF for RD+) (i.e., 0100H to FFFFH) will be performed with the MOVX DPTR instructions in the same way as in the standard 80C51, so with P0 and P2 as data/address bus, and P3.6 and P3.7 as write and read timing signals. Refer to Figure 28.

With EXTRAM = 1, MOVX @Ri and MOVX @DPTR will be similar to the standard 80C51. MOVX @ Ri will provide an 8-bit address multiplexed with data on Port 0 and any output port pins can be used to output higher order address bits. This is to provide the external paging capability. MOVX @DPTR will generate a 16-bit address. Port 2 outputs the high-order eight address bits (the contents of DPH) while Port 0 multiplexes the low-order eight address bits (DPL) with data. MOVX @Ri and MOVX @DPTR will generate either read or write signals on P3.6 (#WR) and P3.7 (#RD).

The stack pointer (SP) may be located anywhere in the 256 bytes RAM (lower and upper RAM) internal data memory. The stack may not be located in the EXTRAM.

| AUXR   |                                                         |      | R                                                                      |               |              |              |              |          |    |      |
|--------|---------------------------------------------------------|------|------------------------------------------------------------------------|---------------|--------------|--------------|--------------|----------|----|------|
|        | Not Bit Addressable                                     |      |                                                                        |               |              |              |              |          |    | _    |
|        | Bit:                                                    |      | _                                                                      | <br>6 5       | 4            | - 3          | _            | EXTRAM   | AO |      |
|        |                                                         |      | 6                                                                      |               |              |              | 2            | 1        | 0  |      |
| Symbol | Func                                                    | tion |                                                                        |               |              |              |              |          |    |      |
| AO     | Disable/Enable ALE                                      |      |                                                                        |               |              |              |              |          |    |      |
|        | AO                                                      |      | Operating Mode                                                         |               |              |              |              |          |    |      |
|        | 0                                                       |      | ALE is em                                                              | itted at a co | onstant rate | of 1/6 the o | scillator fr | equency. |    |      |
|        | 1 ALE is active only during a MOVX or MOVC instruction. |      |                                                                        |               |              |              |              |          |    |      |
| EXTRAM | AM Internal/External RAM access using MOVX @Ri/@DPTR    |      |                                                                        |               |              |              |              |          |    |      |
|        | EXTRAM Operating Mode                                   |      |                                                                        |               |              |              |              |          |    |      |
|        | 0                                                       |      | Internal ERAM (00H–FFH) (00H–2FFH for RD+) access using MOVX @Ri/@DPTR |               |              |              |              |          |    | DPTR |
|        | 1                                                       |      | External d                                                             | ata memory    | access.      |              |              |          |    |      |
|        | Not implemented, reserved for future use*.              |      |                                                                        |               |              |              |              |          |    |      |

Figure 27. AUXR: Auxiliary Register (RX+ only)

#### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# (8XC51RX+ ONLY)



Figure 28. Internal and External Data Memory Address Space with EXTRAM = 0

# HARDWARE WATCHDOG TIMER (ONE-TIME ENABLED WITH RESET-OUT FOR 89C51RC+/RD+)

The WDT is intended as a recovery method in situations where the CPU may be subjected to software upset. The WDT consists of a 14-bit counter and the WatchDog Timer reset (WDTRST) SFR. The WDT is disabled at reset. To enable the WDT, user must write 01EH and 0E1H in sequence to the WDTRST, SFR location 0A6H. When WDT is enabled, it will increment every machine cycle while the oscillator is running and there is no way to disable the WDT except through reset (either hardware reset or WDT overflow reset). When WDT overflows, it will drive an output reset HIGH pulse at the RST-pin.

# Using the WDT

To enable the WDT, user must write 01EH and 0E1H in sequence to the WDTRST. SFR location 0A6H. When WDT is enabled, the user needs to service it by writing to 01EH and 0E1H to WDTRST to avoid WDT overflow. The 14-bit counter overflows when it reaches 16383 (3FFFH) and this will reset the device. When using the WDT, a 1Kohm resistor must be inserted between RST of the device and the Power On Reset circuitry. When WDT is enabled, it will increment every machine cycle while the oscillator is running. This means the user must reset the WDT at least every 16383 machine cycles. To reset the WDT, the user must write 01EH and 0E1H to WDTRST. WDTRST is a write only register. The WDT counter cannot be read or written. When WDT overflows, it will generate an output RESET pulse at the reset pin. The RESET pulse duration is  $98 \times T_{OSC}$ , where  $T_{OSC} = 1/f_{OSC}$ . To make the best use of the WDT, it should be serviced in those sections of code that will periodically be executed within the time required to prevent a WDT reset.

In applications using the Hardware Watchdog Timer of the P8xC51RD+, a series resistor (1K $\Omega \pm 20\%$ ) needs to be included between the reset pin and any external components. Without this resistor the watchdog timer will not function.

8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# **ABSOLUTE MAXIMUM RATINGS1**, 2, 3

| PARAMETER                                                                                    | RATING                 | UNIT |
|----------------------------------------------------------------------------------------------|------------------------|------|
| Operating temperature under bias                                                             | 0 to +70 or -40 to +85 | °C   |
| Storage temperature range                                                                    | -65 to +150            | °C   |
| Voltage on EA/V <sub>PP</sub> pin to V <sub>SS</sub>                                         | 0 to +13.0             | V    |
| Voltage on any other pin to V <sub>SS</sub>                                                  | -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:

 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.

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 maximum.
 Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise

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

# AC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0^{\circ}C$  to +70°C or -40°C to +85°C

|                     |        |                                                                         | CLOCK FREQUENCY<br>RANGE –f |          |            |
|---------------------|--------|-------------------------------------------------------------------------|-----------------------------|----------|------------|
| SYMBOL              | FIGURE | PARAMETER                                                               | MIN                         | MAX      | UNIT       |
| 1/t <sub>CLCL</sub> | 33     | Oscillator frequency<br>Speed versions : 4:5:S (16MHz)<br>I:J:U (33MHz) | 0<br>0                      | 16<br>33 | MHz<br>MHz |

#### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# **AC ELECTRICAL CHARACTERISTICS**

 $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^{1, 2, 3}$ 

|                   |        |                                          | VARIABL                  | E CLOCK <sup>4</sup>                 | 33MHz | CLOCK |      |
|-------------------|--------|------------------------------------------|--------------------------|--------------------------------------|-------|-------|------|
| SYMBOL            | FIGURE | PARAMETER                                | MIN                      | MAX                                  | MIN   | MAX   | דואט |
| t <sub>LHLL</sub> | 29     | ALE pulse width                          | 2t <sub>CLCL</sub> -40   |                                      | 21    |       | ns   |
| t <sub>AVLL</sub> | 29     | Address valid to ALE low                 | t <sub>CLCL</sub> -25    |                                      | 5     |       | ns   |
| t <sub>LLAX</sub> | 29     | Address hold after ALE low               | t <sub>CLCL</sub> -25    |                                      |       |       | ns   |
| t <sub>LLIV</sub> | 29     | ALE low to valid instruction in          |                          | 4t <sub>CLCL</sub> –65               |       | 55    | ns   |
| t <sub>LLPL</sub> | 29     | ALE low to PSEN low                      | t <sub>CLCL</sub> -25    |                                      | 5     |       | ns   |
| t <sub>PLPH</sub> | 29     | PSEN pulse width                         | 3t <sub>CLCL</sub> -45   |                                      | 45    |       | ns   |
| t <sub>PLIV</sub> | 29     | PSEN low to valid instruction in         |                          | 3t <sub>CLCL</sub> –60               |       | 30    | ns   |
| t <sub>PXIX</sub> | 29     | Input instruction hold after PSEN        | 0                        |                                      | 0     |       | ns   |
| t <sub>PXIZ</sub> | 29     | Input instruction float after PSEN       |                          | t <sub>CLCL</sub> -25                |       | 5     | ns   |
| t <sub>AVIV</sub> | 29     | Address to valid instruction in          |                          | 5t <sub>CLCL</sub> –80               |       | 70    | ns   |
| t <sub>PLAZ</sub> | 29     | PSEN low to address float                |                          | 10                                   |       | 10    | ns   |
| Data Memor        | У      | -                                        | •                        |                                      |       |       |      |
| t <sub>RLRH</sub> | 30, 31 | RD pulse width                           | 6t <sub>CLCL</sub> -100  |                                      | 82    |       | ns   |
| t <sub>WLWH</sub> | 30, 31 | WR pulse width                           | 6t <sub>CLCL</sub> -100  |                                      | 82    |       | ns   |
| t <sub>RLDV</sub> | 30, 31 | RD low to valid data in                  |                          | 5t <sub>CLCL</sub> –90               |       | 60    | ns   |
| t <sub>RHDX</sub> | 30, 31 | Data hold after RD                       | 0                        |                                      | 0     |       | ns   |
| t <sub>RHDZ</sub> | 30, 31 | Data float after RD                      |                          | 2t <sub>CLCL</sub> –28               |       | 32    | ns   |
| t <sub>LLDV</sub> | 30, 31 | ALE low to valid data in                 |                          | 8t <sub>CLCL</sub> -150              |       | 90    | ns   |
| t <sub>AVDV</sub> | 30, 31 | Address to valid data in                 |                          | 9t <sub>CLCL</sub> -165              |       | 105   | ns   |
| t <sub>LLWL</sub> | 30, 31 | ALE low to RD or WR low                  | 3t <sub>CLCL</sub> -50   | 3t <sub>CLCL</sub> +50               | 40    | 140   | ns   |
| t <sub>AVWL</sub> | 30, 31 | Address valid to WR low or RD low        | 4t <sub>CLCL</sub> -75   |                                      | 45    |       | ns   |
| t <sub>QVWX</sub> | 30, 31 | Data valid to WR transition              | t <sub>CLCL</sub> -30    |                                      | 0     |       | ns   |
| t <sub>WHQX</sub> | 30, 31 | Data hold after WR                       | t <sub>CLCL</sub> -25    |                                      | 5     |       | ns   |
| t <sub>QVWH</sub> | 31     | Data valid to WR high                    | 7t <sub>CLCL</sub> -130  |                                      | 80    |       | ns   |
| t <sub>RLAZ</sub> | 30, 31 | RD low to address float                  |                          | 0                                    |       | 0     | ns   |
| t <sub>WHLH</sub> | 30, 31 | RD or WR high to ALE high                | t <sub>CLCL</sub> -25    | t <sub>CLCL</sub> +25                | 5     | 55    | ns   |
| External Clo      | ock    | -                                        |                          |                                      |       |       |      |
| <sup>t</sup> снсх | 33     | High time                                | 0.38t <sub>CLCL</sub>    | t <sub>CLCL</sub> -t <sub>CLCX</sub> |       |       | ns   |
| t <sub>CLCX</sub> | 33     | Low time                                 | 0.38t <sub>CLCL</sub>    | tCLCL-tCHCX                          |       |       | ns   |
| t <sub>CLCH</sub> | 33     | Rise time                                |                          | 5                                    |       |       | ns   |
| t <sub>CHCL</sub> | 33     | Fall time                                |                          | 5                                    |       |       | ns   |
| Shift Regist      | er     | -                                        |                          | -                                    | -     | •     | -    |
| t <sub>XLXL</sub> | 32     | Serial port clock cycle time             | 12t <sub>CLCL</sub>      |                                      | 360   |       | ns   |
| t <sub>QVXH</sub> | 32     | Output data setup to clock rising edge   | 10t <sub>CLCL</sub> -133 |                                      | 167   |       | ns   |
| t <sub>XHQX</sub> | 32     | Output data hold after clock rising edge | 2t <sub>CLCL</sub> -80   |                                      |       |       | ns   |
| t <sub>XHDX</sub> | 32     | Input data hold after clock rising edge  | 0                        |                                      | 0     | 1     | ns   |
| t <sub>XHDV</sub> | 32     | Clock rising edge to input data valid    |                          | 10t <sub>CLCL</sub> -133             |       | 167   | 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 microcontroller to devices with float times up to 45ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.

4. For frequencies equal or less than 16MHz, see 16MHz "AC Electrical Characteristics", page 38.

5. Parts are guaranteed to operate down to 0Hz.

### **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 longer a valid logic level
- Z Float



Figure 29. External Program Memory Read Cycle



Figure 30. External Data Memory Read Cycle



Figure 31. External Data Memory Write Cycle



Figure 32. Shift Register Mode Timing



Figure 33. External Clock Drive

### 8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+



### Figure 34. AC Testing Input/Output







Figure 36.  $I_{CC}$  vs. FREQ Valid only within frequency specifications of the device under test

8XC54/58 8XC51FA/FB/FC/80C51FA 8XC51RA+/RB+/RC+/RD+/80C51RA+

# EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS

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

| 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 <sup>1</sup>     | 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 V <sub>PP</sub> | 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:

1. Not tested.



#### NOTES:

\* FOR PROGRAMMING CONFIGURATION SEE FIGURE 41.

FOR VERIFICATION CONDITIONS SEE FIGURE 43.

\*\* SEE TABLE 9.

Figure 44. EPROM Programming and Verification

NOTES