



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

| Detailo                    |                                                                         |
|----------------------------|-------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                |
| Core Processor             | 8051                                                                    |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 16MHz                                                                   |
| Connectivity               | EBI/EMI, UART/USART                                                     |
| Peripherals                | POR, PWM                                                                |
| Number of I/O              | 32                                                                      |
| Program Memory Size        | 8KB (8K x 8)                                                            |
| Program Memory Type        | OTP                                                                     |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 256 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-LCC (J-Lead)                                                         |
| Supplier Device Package    | 44-PLCC (16.59x16.59)                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p87c51fa-4a-512 |

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



# PIN DESCRIPTIONS (Continued)

|                    | PI  | N NUMB | ER  |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|-----|--------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MNEMONIC           | DIP | LCC    | QFP | TYPE | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PSEN               | 29  | 32     | 26  | 0    | <b>Program Store Enable:</b> The read strobe to external program memory. When executing code from the external program memory, <u>PSEN</u> is activated twice each machine cycle, except that two <u>PSEN</u> activations are skipped during each access to external data memory. <u>PSEN</u> is not activated during fetches from internal program memory.                                                                                                                                                                                                                                                                                                                              |
| EA/V <sub>PP</sub> | 31  | 35     | 29  | I    | <b>External Access Enable/Programming Supply Voltage:</b> EA must be externally held low to enable the device to fetch code from external program memory locations starting with 0000H. If EA is held high, the device executes from internal program memory unless the program counter contains an address greater than 8k Devices (IFFFH), 16k Devices (3FFFH) or 32k Devices (7FFFH). Since the RD+ has 64k Internal Memory, the RD+ will execute only from internal memory when EA is held high. This pin also receives the 12.75 V programming supply voltage (V <sub>PP</sub> ) during EPROM programming. If security bit 1 is programmed, EA will be internally latched on Reset. |
| XTAL1              | 19  | 21     | 15  | I    | Crystal 1: Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| XTAL2              | 18  | 20     | 14  | 0    | Crystal 2: Output from the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### NOTE:

To avoid "latch-up" effect at power-on, the voltage on any pin at any time must not be higher than  $V_{CC}$  + 0.5 V or  $V_{SS}$  – 0.5 V, respectively.

# **8XC54/58 ORDERING INFORMATION**

|     | MEMORY SIZE<br>16K × 8 | MEMORY SIZE<br>32K × 8 | TEMPERATURE RANGE °C<br>AND PACKAGE       | VOLTAGE<br>RANGE | FREQ.<br>(MHz) | DWG.<br># |
|-----|------------------------|------------------------|-------------------------------------------|------------------|----------------|-----------|
| ROM | P80C54SBPN             | P80C58SBPN             | 0 to +70, Plastic Dual In-line Package    | 2.7 V to         | 0 to 16        | SOT129-1  |
| OTP | P87C54SBPN             | P87C58SBPN             | 0 to +70, Plastic Dual III-III e Package  | 5.5 V            | 01010          | 301129-1  |
| ROM | P80C54SBAA             | P80C58SBAA             | 0 to +70, Plastic Leaded Chip Carrier     | 2.7 V to         | 0 to 16        | SOT187-2  |
| OTP | P87C54SBAA             | P87C58SBAA             | 0 to +70, Plastic Leaded Chip Carrier     | 5.5 V            | 01010          | 301107-2  |
| ROM | P80C54SBBB             | P80C58SBBB             | 0 to +70, Plastic Quad Flat Pack          | 2.7 V to         | 0 to 16        | SOT307-2  |
| OTP | P87C54SBBB             | P87C58SBBB             |                                           | 5.5 V            | 01010          | 301307-2  |
| ROM | P80C54SFPN             | P80C58SFPN             | -40 to +85, Plastic Dual In-line Package  | 2.7 V to         | 0 to 16        | SOT129-1  |
| OTP | P87C54SFPN             | P87C58SFPN             | -40 to +03, Flastic Dual III-line Fackage | 5.5 V            | 01010          | 301129-1  |
| ROM | P80C54SFA A            | P80C58SFA A            | -40 to +85, Plastic Leaded Chip Carrier   | 2.7 V to         | 0 to 16        | SOT187-2  |
| OTP | P87C54SFA A            | P87C58SFA A            |                                           | 5.5 V            | 01010          | 301107-2  |
| ROM | P80C54SFBB             | P80C58SFBB             | -40 to +85, Plastic Quad Flat Pack        | 2.7 V to         | 0 to 16        | SOT307-2  |
| OTP | P87C54SFBB             | P87C58SFBB             |                                           | 5.5 V            | 01010          | 301307-2  |
| ROM | P80C54UBAA             | P80C58UBAA             | 0 to +70, Plastic Leaded Chip Carrier     | 5 V              | 0 to 33        | SOT187-2  |
| OTP | P87C54UBAA             | P87C58UBAA             | 0 to +70, Flastic Leaded Chip Camer       | 5.0              | 0 10 33        | 301107-2  |
| ROM | P80C54UBPN             | P80C58UBPN             | 0 to +70, Plastic Dual In-line Package    | 5 V              | 0 to 33        | SOT129-1  |
| OTP | P87C54UBPN             | P87C58UBPN             |                                           | 5.0              | 0 10 33        | 301129-1  |
| ROM | P80C54UBBB             | P80C58UBBB             | 0 to +70, Plastic Quad Flat Pack          | 5 V              | 0 to 33        | SOT307-2  |
| OTP | P87C54UBBB             | P87C58UBBB             |                                           | 5.0              | 0 10 33        | 301307-2  |
| ROM | P80C54UFAA             | P80C58UFA A            | -40 to +85, Plastic Leaded Chip Carrier   | 5 V              | 0 to 33        | SOT187-2  |
| OTP | P87C54UFAA             | P87C58UFA A            |                                           | 5.0              | 0.0.33         | 301107-2  |
| ROM | P80C54UFPN             | P80C58UFPN             | -40 to +85, Plastic Dual In-line Package  | 5 V              | 0 to 33        | SOT129-1  |
| OTP | P87C54UFPN             | P87C58UFPN             | -40 to +03, Flastic Dual III-III Package  | 57               | 0.0.33         | 301129-1  |
| ROM | P80C54UFBB             | P80C58UFBB             | -40 to +85, Plastic Quad Flat Pack        | 5 V              | 0 to 33        | SOT307-2  |
| OTP | P87C54UFBB             | P87C58UFBB             |                                           | 5 V              | 01033          | 301307-2  |

Note: For Multi Time Programmable devices, See P89C51RX+

Flash datasheet.

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 to 16        | 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 10 10        | 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 1 - 40       | 007407.0  |
| OTP | P87C51RA+5A           | P87C51RB+5A            | P87C51RC+5A         | P87C51RD+5A            | P80C51RA+5A   | 44-Pin Plastic Leaded Chip Carrier  | 2.7V to 5.5V     | 0 to 16        | SOT187-2  |
| ROM | P83C51RA+5B           | P83C51RB+5B            | P83C51RC+5B         | P83C51RD+5B            |               | -40 to +85,                         |                  | a              | 0.07007.0 |
| OTP | P87C51RA+5B           | P87C51RB+5B            | P87C51RC+5B         | P87C51RD+5B            | P80C51RA+5B   | 44-Pin Plastic Quad Flat Pack       | 2.7V to 5.5V     | 0 to 16        | SOT307-2  |
| ROM | P83C51RA+IN           | P83C51RB+IN            | P83C51RC+IN         | P83C51RD+IN            |               | 0 to +70,                           | 5) (             | 0.1.00         | 007400.4  |
| OTP | P87C51RA+IN           | P87C51RB+IN            | P87C51RC+IN         | P87C51RD+IN            | P80C51RA+IN   | 40-Pin Plastic Dual In-line Pkg.    | 5V               | 0 to 33        | SOT129-1  |
| ROM | P83C51RA+IA           | P83C51RB+IA            | P83C51RC+IA         | P83C51RD+IA            | P80C51RA+IA   | 0 to +70,                           | 5V               | 0 to 33        | SOT187-2  |
| OTP | P87C51RA+IA           | P87C51RB+IA            | P87C51RC+IA         | P87C51RD+IA            | POUCSTRATIA   | 44-Pin Plastic Leaded Chip Carrier  | 50               | 0 10 33        | 301107-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        | COT400.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,                         | 5)/              | 0 to 22        | SOT207 2  |
| 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.

## TIMER 2 OPERATION

### Timer 2

Timer 2 is a 16-bit Timer/Counter which can operate as either an event timer or an event counter, as selected by  $C/T2^*$  in the special function register T2CON (see Figure 1). Timer 2 has three operating modes: Capture, Auto-reload (up or down counting), and Baud Rate Generator, which are selected by bits in the T2CON as shown in Table 4.

# **Capture Mode**

In the capture mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2=0, then timer 2 is a 16-bit timer or counter (as selected by C/T2\* in T2CON) which, upon overflowing sets bit TF2, the timer 2 overflow bit. This bit can be used to generate an interrupt (by enabling the Timer 2 interrupt bit in the IE register). If EXEN2= 1, Timer 2 operates as described above, but with the added feature that a 1-to-0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively. In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2 like TF2 can generate an interrupt (which vectors to the same location as Timer 2 overflow interrupt. The Timer 2 interrupt service routine can interrogate TF2 and EXF2 to determine which event caused the interrupt). The capture mode is illustrated in Figure 2. (There is no reload value for TL2 and TH2 in this mode. Even when a capture event occurs from T2EX, the counter keeps on counting T2EX pin transitions or osc/12 pulses.)

### Auto-Reload Mode (Up or Down Counter)

In the 16-bit auto-reload mode, Timer 2 can be configured (as either a timer or counter [C/T2\* in T2CON]) then programmed to count up or down. The counting direction is determined by bit DCEN (Down Counter Enable) which is located in the T2MOD register (see

Figure 3). When reset is applied the DCEN=0 which means Timer 2 will default to counting up. If DCEN bit is set, Timer 2 can count up or down depending on the value of the T2EX pin.

Figure 4 shows Timer 2 which will count up automatically since DCEN=0. In this mode there are two options selected by bit EXEN2 in T2CON register. If EXEN2=0, then Timer 2 counts up to 0FFFH and sets the TF2 (Overflow Flag) bit upon overflow. This causes the Timer 2 registers to be reloaded with the 16-bit value in RCAP2L and RCAP2H. The values in RCAP2L and RCAP2H are preset by software means.

If EXEN2=1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input T2EX. This transition also sets the EXF2 bit. The Timer 2 interrupt, if enabled, can be generated when either TF2 or EXF2 are 1.

In Figure 5 DCEN=1, which enables Timer 2 to count up or down. This mode allows pin T2EX to control the direction of count. When a logic 1 is applied at pin T2EX Timer 2 will count up. Timer 2 will overflow at 0FFFFH and set the TF2 flag, which can then generate an interrupt, if the interrupt is enabled. This timer overflow also causes the 16-bit value in RCAP2L and RCAP2H to be reloaded into the timer registers TL2 and TH2.

When a logic 0 is applied at pin T2EX this causes Timer 2 to count down. The timer will underflow when TL2 and TH2 become equal to the value stored in RCAP2L and RCAP2H. Timer 2 underflow sets the TF2 flag and causes 0FFFFH to be reloaded into the timer registers TL2 and TH2.

The external flag EXF2 toggles when Timer 2 underflows or overflows. This EXF2 bit can be used as a 17th bit of resolution if needed. The EXF2 flag does not generate an interrupt in this mode of operation.

|        | ()      | MSB)        |                                                                                                                                                                                                                                                                                                                                        |                               |               |               |              |               | (LSB)                         |                                                    |
|--------|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------------|---------------|--------------|---------------|-------------------------------|----------------------------------------------------|
|        |         | TF2         | EXF2                                                                                                                                                                                                                                                                                                                                   | RCLK                          | TCLK          | EXEN2         | TR2          | C/T2          | CP/RL2                        |                                                    |
| Symbol | Positio | on Nai      | ne and Sigi                                                                                                                                                                                                                                                                                                                            | nificance                     |               |               |              |               |                               |                                                    |
| TF2    | T2CON   |             | er 2 overflov<br>en either RC                                                                                                                                                                                                                                                                                                          |                               |               | overflow and  | d must be cl | eared by so   | oftware. TF2                  | will not be set                                    |
| EXF2   | T2CON   | EXI         | Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX an EXEN2 = 1. When Timer 2 interrupt is enabled, $EXF2 = 1$ will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software. EXF2 does not cause an interrupt in up/down counter mode (DCEN = 1). |                               |               |               |              |               |                               |                                                    |
| RCLK   | T2CON   |             | Receive clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its receive clock in modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock.                                                                                                                                         |                               |               |               |              |               |                               |                                                    |
| TCLK   | T2CON   |             |                                                                                                                                                                                                                                                                                                                                        |                               |               |               |              |               | ow pulses fo<br>transmit cloo | or its transmit cloc<br>k.                         |
| EXEN2  | T2CON   | trar        |                                                                                                                                                                                                                                                                                                                                        | EX if Timer                   |               |               |              |               |                               | of a negative<br>ses Timer 2 to                    |
| TR2    | T2CON   | I.2 Sta     | rt/stop contr                                                                                                                                                                                                                                                                                                                          | ol for Timer                  | 2. A logic 1  | starts the ti | mer.         |               |                               |                                                    |
| C/T2   | T2CON   | l.1 Tim     |                                                                                                                                                                                                                                                                                                                                        | iternal time                  | (OSĆ/12)      | alling edge   | triggered).  |               |                               |                                                    |
| CP/RL2 | T2CON   | clea<br>EXI | ared, auto-re                                                                                                                                                                                                                                                                                                                          | eloads will o<br>ien either R | ccur either v | with Timer 2  | overflows of | or negative t | ransitions at                 | EXEN2 = 1. Wher<br>T2EX when<br>ced to auto-reload |
|        |         |             |                                                                                                                                                                                                                                                                                                                                        |                               |               |               |              |               |                               | SU0072                                             |

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

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

# Table 4. Timer 2 Operating Modes

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



Figure 2. Timer 2 in Capture Mode

| T2MOD      | Addres                                                                                                                                                                                                                                                                                           | Address = 0C9H Reset Value = XXXX XX00                                                       |               |               |     |   |   |   |   |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------|---------------|-----|---|---|---|---|--|--|
|            | Not Bit                                                                                                                                                                                                                                                                                          | Not Bit Addressable                                                                          |               |               |     |   |   |   |   |  |  |
|            |                                                                                                                                                                                                                                                                                                  | T2OE DCEN                                                                                    |               |               |     |   |   |   |   |  |  |
|            | Bit                                                                                                                                                                                                                                                                                              | 7                                                                                            | 6             | 5             | 4   | 3 | 2 | 1 | 0 |  |  |
| Symbol     | Funct                                                                                                                                                                                                                                                                                            | Function                                                                                     |               |               |     |   |   |   |   |  |  |
| _          | Not im                                                                                                                                                                                                                                                                                           | plemented                                                                                    | l, reserved f | or future use | Э.* |   |   |   |   |  |  |
| T2OE       | Timer                                                                                                                                                                                                                                                                                            | 2 Output E                                                                                   | nable bit.    |               |     |   |   |   |   |  |  |
| DCEN       | Down                                                                                                                                                                                                                                                                                             | Down Count Enable bit. When set, this allows Timer 2 to be configured as an up/down counter. |               |               |     |   |   |   |   |  |  |
| In that ca | User software should not write 1s to reserved bits. These bits may be used in future 8051 family products to invoke new features.<br>In that case, the reset or inactive value of the new bit will be 0, and its active value will be 1. The value read from a reserved bit is<br>indeterminate. |                                                                                              |               |               |     |   |   |   |   |  |  |

Figure 3. Timer 2 Mode (T2MOD) Control Register



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



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



Figure 8. UART Framing Error Detection



Figure 9. UART Multiprocessor Communication, Automatic Address Recognition

### Reduced EMI Mode

The AO bit (AUXR.0) in the AUXR register when set disables the ALE output.

#### **Reduced EMI Mode**

### AUXR (8EH)

| 7                | 6 | 5            | 4 | 3                      | 2 | 1      | 0  |
|------------------|---|--------------|---|------------------------|---|--------|----|
| -                | - | -            | - | -                      | - | EXTRAM | AO |
| AUXR.1<br>AUXR.0 |   | EXTRAN<br>AO |   | (RX+ only<br>Turns off |   | put.   |    |

### **Dual DPTR**

The dual DPTR structure (see Figure 13) is a way by which the chip will specify the address of an external data memory location. There are two 16-bit DPTR registers that address the external memory, and a single bit called DPS = AUXR1/bit0 that allows the program code to switch between them.

- New Register Name: AUXR1#
- SFR Address: A2H
- Reset Value: xxxx00x0B

| 7 | 6 | 5 | 4    | 3   | 2 | 1 | 0   |
|---|---|---|------|-----|---|---|-----|
| - | - | - | LPEP | GF3 | 0 | - | DPS |

#### Where:

DPS = AUXR1/bit0 = Switches between DPTR0 and DPTR1.

| Select Reg | DPS |
|------------|-----|
| DPTR0      | 0   |
| DPTR1      | 1   |

The DPS bit status should be saved by software when switching between DPTR0 and DPTR1.

The GF3 bit is a general purpose user-defined flag. Note that bit 2 is not writable and is always read as a zero. This allows the DPS bit to

be quickly toggled simply by executing an INC DPTR instruction without affecting the GF3 or LPEP bits.



Figure 13.

#### **DPTR Instructions**

The instructions that refer to DPTR refer to the data pointer that is currently selected using the AUXR1/bit 0 register. The six instructions that use the DPTR are as follows:

| INC DPTR          | Increments the data pointer by 1          |
|-------------------|-------------------------------------------|
| MOV DPTR, #data16 | Loads the DPTR with a 16-bit constant     |
| MOV A, @ A+DPTR   | Move code byte relative to DPTR to ACC    |
| MOVX A, @ DPTR    | Move external RAM (16-bit address) to ACC |
| MOVX @ DPTR , A   | Move ACC to external RAM (16-bit address) |
| JMP @ A + DPTR    | Jump indirect relative to DPTR            |

The data pointer can be accessed on a byte-by-byte basis by specifying the low or high byte in an instruction which accesses the SFRs. See application note AN458 for more details.

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

# (8XC51FX and 8XC51RX+ ONLY)

|        |        | CIDL        | WDTE                         | -          | -                         | -                | CPS1           | CPS0                 | ECF         |                        |
|--------|--------|-------------|------------------------------|------------|---------------------------|------------------|----------------|----------------------|-------------|------------------------|
|        | Bit:   | 7           | 6                            | 5          | 4                         | 3                | 2              | 1                    | 0           | _                      |
| Symbol | Funct  | ion         |                              |            |                           |                  |                |                      |             |                        |
| CIDL   |        |             | trol: CIDL =<br>during idle. | 0 progran  | ns the PCA                | Counter to       | continue fur   | nctioning du         | ring idle M | ode. CIDL = 1 programs |
| WDTE   | Watch  | dog Timer   | Enable: WI                   | DTE = 0 di | sables Wate               | chdog Tim        | er function o  | n PCA Mod            | ule 4. WDT  | E = 1 enables it.      |
| _      |        |             | , reserved f                 |            |                           | -                |                |                      |             |                        |
| CPS1   | PCA C  | Count Pulse | e Select bit                 | 1.         |                           |                  |                |                      |             |                        |
| CPS0   | PCA C  | count Pulse | e Select bit                 | 0.         |                           |                  |                |                      |             |                        |
|        | CPS1   | CPS0        | Selecte                      | d PCA In   | put**                     |                  |                |                      |             |                        |
|        | 0      | 0           | 0                            | Intern     | al clock, fos             | sc ÷ 12          |                |                      |             |                        |
|        | 0      | 1           | 1                            | Intern     | al clock, f <sub>OS</sub> | <sub>6</sub> ÷ 4 |                |                      |             |                        |
|        |        | 0           | 2                            | Timer      | 0 overflow                |                  |                |                      |             |                        |
|        | 1      |             | 0                            | Extern     | hal clock at              | ECI/P1.2 p       | oin (max. rate | $e = f_{OSC} \div 8$ | )           |                        |
|        | 1<br>1 | 1           | 3                            | LACON      | iai oioon at              | = • · · · · = p  |                |                      |             |                        |

### Figure 17. CMOD: PCA Counter Mode Register

|                         | Bit Add                                                | dressable                                                                                   |                                                                                                |                                                                                             |                                                                                    |                                                                           |                                                                            |                                                                         |                                                                     | _                                                           |
|-------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------|
|                         |                                                        | CF                                                                                          | CR                                                                                             | -                                                                                           | CCF4                                                                               | CCF3                                                                      | CCF2                                                                       | CCF1                                                                    | CCF0                                                                |                                                             |
|                         | Bit:                                                   | 7                                                                                           | 6                                                                                              | 5                                                                                           | 4                                                                                  | 3                                                                         | 2                                                                          | 1                                                                       | 0                                                                   |                                                             |
| Symbol                  | Funct                                                  | ion                                                                                         |                                                                                                |                                                                                             |                                                                                    |                                                                           |                                                                            |                                                                         |                                                                     |                                                             |
| CF                      | PCA (                                                  | Counter O                                                                                   | verflow flag                                                                                   | Set by ha                                                                                   | rdware whei                                                                        | n the counte                                                              | er rolls over                                                              | CF flags a                                                              | n interrupt                                                         | if bit ECF in CMOD is                                       |
| -                       |                                                        |                                                                                             |                                                                                                |                                                                                             | or software                                                                        |                                                                           |                                                                            |                                                                         |                                                                     |                                                             |
| CR                      | set. C                                                 | F may be<br>Counter Ri                                                                      | set by eithe                                                                                   | r hardware                                                                                  | or software                                                                        | but can on                                                                | ly be cleare                                                               | d by softwa                                                             | are.                                                                | oftware to turn the PCA                                     |
| -                       | set. C<br>PCA (<br>counte                              | F may be<br>Counter Ri<br>er off.                                                           | set by eithe                                                                                   | r hardware<br>it. Set by so                                                                 | or software                                                                        | but can on                                                                | ly be cleare                                                               | d by softwa                                                             | are.                                                                |                                                             |
| -                       | set. C<br>PCA C<br>counte<br>Not im                    | F may be<br>Counter Ri<br>er off.<br>plemente                                               | set by eithe<br>un control b<br>d, reserved                                                    | r hardware<br>it. Set by so<br>for future ι                                                 | or software<br>oftware to tu<br>use*.                                              | but can on<br>urn the PCA                                                 | ly be cleare<br>counter on                                                 | ed by softwa<br>. Must be c                                             | are.<br>leared by s                                                 |                                                             |
| CR<br>-                 | set. C<br>PCA C<br>counte<br>Not im<br>PCA N           | F may be<br>Counter Re<br>er off.<br>pplemente<br>Module 4 in                               | set by eithe<br>un control b<br>d, reserved<br>nterrupt flag                                   | r hardware<br>it. Set by se<br>for future u<br>g. Set by ha                                 | or software<br>oftware to tu<br>use*.<br>ardware whe                               | but can on<br>urn the PCA<br>en a match o                                 | ly be cleare<br>counter on<br>or capture o                                 | ed by softwa<br>. Must be c<br>occurs. Mus                              | are.<br>leared by s<br>t be cleared                                 | oftware to turn the PCA                                     |
| CR<br>-<br>CCF4<br>CCF3 | set. Cl<br>PCA C<br>counte<br>Not im<br>PCA M<br>PCA M | F may be<br>Counter Ri<br>er off.<br>plemente<br>Module 4 in<br>Module 3 in                 | set by eithe<br>un control b<br>d, reserved<br>nterrupt flag<br>nterrupt flag                  | r hardware<br>it. Set by so<br>for future u<br>g. Set by ha<br>g. Set by ha                 | or software<br>oftware to tu<br>use*.<br>ardware whe<br>ardware whe                | but can on<br>urn the PCA<br>an a match o<br>an a match o                 | ly be cleare<br>counter on<br>or capture o<br>or capture o                 | ed by softwa<br>. Must be c<br>occurs. Mus                              | are.<br>leared by s<br>t be cleared<br>t be cleared                 | oftware to turn the PCA                                     |
| CR<br>-<br>CCF4         | set. Cl<br>PCA C<br>counte<br>Not im<br>PCA M<br>PCA M | F may be<br>Counter Ri<br>er off.<br>nplemente<br>Aodule 4 in<br>Aodule 3 in<br>Aodule 2 in | set by eithe<br>un control b<br>d, reserved<br>nterrupt flag<br>nterrupt flag<br>nterrupt flag | r hardware<br>it. Set by so<br>for future u<br>g. Set by ha<br>g. Set by ha<br>g. Set by ha | or software<br>oftware to tu<br>use*.<br>ardware whe<br>ardware whe<br>ardware whe | but can on<br>urn the PCA<br>en a match o<br>en a match o<br>en a match o | ly be cleare<br>counter on<br>or capture o<br>or capture o<br>or capture o | d by softwa<br>. Must be c<br>occurs. Mus<br>occurs. Mus<br>occurs. Mus | are.<br>leared by s<br>t be cleared<br>t be cleared<br>t be cleared | oftware to turn the PCA<br>d by software.<br>d by software. |

SU00036

### Figure 18. CCON: PCA Counter Control Register

### 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 | nnare/Cantur   | Registers    |
|------------|----------------|-------------|----------------|--------------|
| riguie 13. | CCAI MILL I CA | wouldes con | iipai e/Gaptui | e ivegialeia |

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

# (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 FR<br>RANG |          |            |
|---------------------|--------|-------------------------------------------------------------------------|------------------|----------|------------|
| 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$  to +70°C or -40°C to +85°C,  $V_{CC} = +2.7V$  to +5.5V,  $V_{SS} = 0V^{1, 2, 3}$ 

|                     |        |                                                             | 16MHz | CLOCK | VARIABL                  | E CLOCK                              |      |
|---------------------|--------|-------------------------------------------------------------|-------|-------|--------------------------|--------------------------------------|------|
| SYMBOL              | FIGURE | PARAMETER                                                   | MIN   | MAX   | MIN                      | MAX                                  | רואט |
| 1/t <sub>CLCL</sub> | 29     | Oscillator frequency <sup>5</sup><br>Speed versions :4; 5;S |       |       | 3.5                      | 16                                   | MHz  |
| t <sub>lhll</sub>   | 29     | ALE pulse width                                             | 85    |       | 2t <sub>CLCL</sub> -40   |                                      | ns   |
| AVLL                | 29     | Address valid to ALE low                                    | 22    |       | t <sub>CLCL</sub> -40    |                                      | ns   |
| t <sub>LLAX</sub>   | 29     | Address hold after ALE low                                  | 32    |       | t <sub>CLCL</sub> -30    |                                      | ns   |
| t <sub>LLIV</sub>   | 29     | ALE low to valid instruction in                             |       | 150   |                          | 4t <sub>CLCL</sub> -100              | ns   |
| t <sub>LLPL</sub>   | 29     | ALE low to PSEN low                                         | 32    |       | t <sub>CLCL</sub> -30    |                                      | ns   |
| t <sub>PLPH</sub>   | 29     | PSEN pulse width                                            | 142   |       | 3t <sub>CLCL</sub> -45   |                                      | ns   |
| t <sub>PLIV</sub>   | 29     | PSEN low to valid instruction in                            |       | 82    |                          | 3t <sub>CLCL</sub> -105              | ns   |
| t <sub>PXIX</sub>   | 29     | Input instruction hold after PSEN                           | 0     |       | 0                        |                                      | ns   |
| t <sub>PXIZ</sub>   | 29     | Input instruction float after PSEN                          |       | 37    |                          | t <sub>CLCL</sub> -25                | ns   |
| t <sub>AVIV</sub> 5 | 29     | Address to valid instruction in                             |       | 207   |                          | 5t <sub>CLCL</sub> -105              | ns   |
| t <sub>PLAZ</sub>   | 29     | PSEN low to address float                                   |       | 10    |                          | 10                                   | ns   |
| Data Memo           | ory    | -                                                           |       |       |                          | -                                    |      |
| t <sub>RLRH</sub>   | 30, 31 | RD pulse width                                              | 275   |       | 6t <sub>CLCL</sub> -100  |                                      | ns   |
| twlwh               | 30, 31 | WR pulse width                                              | 275   |       | 6t <sub>CLCL</sub> -100  |                                      | ns   |
| t <sub>RLDV</sub>   | 30, 31 | RD low to valid data in                                     |       | 147   |                          | 5t <sub>CLCL</sub> -165              | ns   |
| RHDX                | 30, 31 | Data hold after RD                                          | 0     |       | 0                        |                                      | ns   |
| t <sub>RHDZ</sub>   | 30, 31 | Data float after RD                                         |       | 65    |                          | 2t <sub>CLCL</sub> -60               | ns   |
| t <sub>LLDV</sub>   | 30, 31 | ALE low to valid data in                                    |       | 350   |                          | 8t <sub>CLCL</sub> -150              | ns   |
| t <sub>AVDV</sub>   | 30, 31 | Address to valid data in                                    |       | 397   |                          | 9t <sub>CLCL</sub> -165              | ns   |
| tLLWL               | 30, 31 | ALE low to RD or WR low                                     | 137   | 239   | 3t <sub>CLCL</sub> -50   | 3t <sub>CLCL</sub> +50               | ns   |
| t <sub>AVWL</sub>   | 30, 31 | Address valid to WR low or RD low                           | 122   |       | 4t <sub>CLCL</sub> -130  |                                      | ns   |
| t <sub>QVWX</sub>   | 30, 31 | Data valid to $\overline{WR}$ transition                    | 13    |       | t <sub>CLCL</sub> -50    |                                      | ns   |
| t <sub>WHQX</sub>   | 30, 31 | Data hold after WR                                          | 13    |       | t <sub>CLCL</sub> -50    |                                      | ns   |
| tqvwн               | 31     | Data valid to WR high                                       | 287   |       | 7t <sub>CLCL</sub> -150  |                                      | 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                                   | 23    | 103   | t <sub>CLCL</sub> -40    | t <sub>CLCL</sub> +40                | ns   |
| External C          | lock   |                                                             |       |       |                          |                                      |      |
| tснсх               | 33     | High time                                                   | 20    |       | 20                       | t <sub>CLCL</sub> -t <sub>CLCX</sub> | ns   |
| t <sub>CLCX</sub>   | 33     | Low time                                                    | 20    |       | 20                       | t <sub>CLCL</sub> -t <sub>CHCX</sub> | ns   |
| t <sub>CLCH</sub>   | 33     | Rise time                                                   |       | 20    |                          | 20                                   | ns   |
| <sup>t</sup> CHCL   | 33     | Fall time                                                   |       | 20    |                          | 20                                   | ns   |
| Shift Regis         | ster   |                                                             |       |       |                          |                                      |      |
| t <sub>XLXL</sub>   | 32     | Serial port clock cycle time                                | 750   |       | 12t <sub>CLCL</sub>      |                                      | ns   |
| t <sub>QVXH</sub>   | 32     | Output data setup to clock rising edge                      | 492   |       | 10t <sub>CLCL</sub> -133 |                                      | ns   |
| t <sub>XHQX</sub>   | 32     | Output data hold after clock rising edge                    | 8     |       | 2t <sub>CLCL</sub> -117  |                                      | ns   |
| <sup>t</sup> xhdx   | 32     | Input data hold after clock rising edge                     | 0     |       | 0                        |                                      | ns   |
| <sup>t</sup> xhdv   | 32     | Clock rising edge to input data valid                       |       | 492   |                          | 10t <sub>CLCL</sub> -133             | 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. See application note AN457 for external memory interface.

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

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













Figure 40. I<sub>CC</sub> Test Condition, Power Down Mode All other pins are disconnected. V<sub>CC</sub> = 2V to 5.5V

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

# Table 9. EPROM Programming Modes

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

#### NOTES:

1. '0' =Valid low for that pin, '1' =valid high for that pin.

U = Valid low for that pin, T = Valid high for that pin.
V<sub>PP</sub> = 12.75V ±0.25V.
V<sub>CC</sub> = 5V±10% during programming and verification.
\* ALE/PROG receives 5 programming pulses for code data (also for user array; 5 pulses for encryption or security bits) while V<sub>PP</sub> is held at 12.75V. Each programming pulse is low for 100µs (±10µs) and high for a minimum of 10µs.

# Table 10. Program Security Bits for EPROM Devices

| PRO | OGRAM L | оск віте | <b>1</b> , 2 |                                                                                                                                                                                                                        |
|-----|---------|----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | SB1     | SB2      | SB3          | PROTECTION DESCRIPTION                                                                                                                                                                                                 |
| 1   | U       | U        | U            | No Program Security features enabled. (Code verify will still be encrypted by the Encryption Array if programmed.)                                                                                                     |
| 2   | Ρ       | U        | U            | MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory, $\overline{EA}$ is sampled and latched on Reset, and further programming of the EPROM is disabled. |
| 3   | Р       | Р        | U            | Same as 2, also verify is disabled.                                                                                                                                                                                    |
| 4   | Р       | Р        | Р            | Same as 3, external execution is disabled.                                                                                                                                                                             |

NOTES:

1. P - programmed. U - unprogrammed.

2. Any other combination of the security bits is not defined.

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

# MASK ROM DEVICES

### **Security Bits**

With none of the security bits programmed the code in the program memory can be verified. If the encryption table is programmed, the code will be encrypted when verified. When only security bit 1 (see Table 11) is programmed, MOVC instructions executed from external program memory are disabled from fetching code bytes from the internal memory,  $\overline{EA}$  is latched on Reset and all further programming of the EPROM is disabled. When security bits 1 and 2 are programmed, in addition to the above, verify mode is disabled.

#### **Encryption Array**

64 bytes of encryption array are initially unprogrammed (all 1s).

### Table 11. Program Security Bits

| PROGRAM LOCK BITS <sup>1, 2</sup> |     | BITS <sup>1, 2</sup> |                                                                                                                                                                                                           |  |  |  |  |  |  |
|-----------------------------------|-----|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                                   | SB1 | SB2                  | PROTECTION DESCRIPTION                                                                                                                                                                                    |  |  |  |  |  |  |
| 1                                 | U   | U                    | No Program Security features enabled.<br>(Code verify will still be encrypted by the Encryption Array if programmed.)                                                                                     |  |  |  |  |  |  |
| 2                                 | Р   | U                    | MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory, EA is sampled and latched on Reset, and further programming of the EPROM is disabled. |  |  |  |  |  |  |

NOTES:

1. P - programmed. U - unprogrammed.

2. Any other combination of the security bits is not defined.

# ROM CODE SUBMISSION FOR 8K ROM DEVICES (83C51FA, AND 83C51RA+)

When submitting ROM code for the 8k ROM devices, the following must be specified:

1. 8k byte user ROM data

- 2. 64 byte ROM encryption key
- 3. ROM security bits.

| ADDRESS        | CONTENT | BIT(S) | COMMENT                                                           |
|----------------|---------|--------|-------------------------------------------------------------------|
| 0000H to 1FFFH | DATA    | 7:0    | User ROM Data                                                     |
| 2000H to 203FH | KEY     | 7:0    | ROM Encryption Key<br>FFH = no encryption                         |
| 2040H          | SEC     | 0      | ROM Security Bit 1<br>0 = enable security<br>1 = disable security |
| 2040H          | SEC     | 1      | ROM Security Bit 2<br>0 = enable security<br>1 = disable security |

Security Bit 1: When programmed, this bit has two effects on masked ROM parts:

1. External MOVC is disabled, and

2. EA is latched on Reset.

Security Bit 2: When programmed, this bit inhibits Verify User ROM.

**NOTE:** Security Bit 2 cannot be enabled unless Security Bit 1 is enabled.

If the ROM Code file does not include the options, the following information must be included with the ROM code.

For each of the following, check the appropriate box, and send to Philips along with the code:

| Security Bit #1: | Enabled | □ Disabled                        |
|------------------|---------|-----------------------------------|
| Security Bit #2: | Enabled | □ Disabled                        |
| Encryption:      | 🗆 No    | □ Yes If Yes, must send key file. |

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



| UNIT   | A<br>max. | A <sub>1</sub><br>min. | A <sub>2</sub><br>max. | b              | b <sub>1</sub> | с              | D <sup>(1)</sup> | E <sup>(1)</sup> | е    | e <sub>1</sub> | L            | ME             | M <sub>H</sub> | w     | Z <sup>(''</sup><br>max. |
|--------|-----------|------------------------|------------------------|----------------|----------------|----------------|------------------|------------------|------|----------------|--------------|----------------|----------------|-------|--------------------------|
| mm     | 4.7       | 0.51                   | 4.0                    | 1.70<br>1.14   | 0.53<br>0.38   | 0.36<br>0.23   | 52.50<br>51.50   | 14.1<br>13.7     | 2.54 | 15.24          | 3.60<br>3.05 | 15.80<br>15.24 | 17.42<br>15.90 | 0.254 | 2.25                     |
| inches | 0.19      | 0.020                  | 0.16                   | 0.067<br>0.045 | 0.021<br>0.015 | 0.014<br>0.009 | 2.067<br>2.028   | 0.56<br>0.54     | 0.10 | 0.60           | 0.14<br>0.12 | 0.62<br>0.60   | 0.69<br>0.63   | 0.01  | 0.089                    |

#### Note

1. Plastic or metal protrusions of 0.25 mm maximum per side are not included.

| OUTLINE  |        | REFEF  | EUROPEAN  | ISSUE DATE |            |                                  |  |
|----------|--------|--------|-----------|------------|------------|----------------------------------|--|
| VERSION  | IEC    | JEDEC  | EIAJ      |            | PROJECTION | ISSUE DATE                       |  |
| SOT129-1 | 051G08 | MO-015 | SC-511-40 |            |            | <del>-95-01-14</del><br>99-12-27 |  |