### NXP USA Inc. - P87C52X2BBD,157 Datasheet





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                      | 33MHz                                                                   |
| Connectivity               | EBI/EMI, UART/USART                                                     |
| Peripherals                | POR                                                                     |
| 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-LQFP                                                                 |
| Supplier Device Package    | 44-LQFP (10x10)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p87c52x2bbd-157 |

Email: info@E-XFL.COM

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

### P80C3xX2; P80C5xX2; P87C5xX2

#### FEATURES

- 80C51 Central Processing Unit
- 4 kbytes ROM/EPROM (P80/P87C51X2)
- 8 kbytes ROM/EPROM (P80/P87C52X2)
- 16 kbytes ROM/EPROM (P80/P87C54X2)
- 32 kbytes ROM/EPROM (P80/P87C58X2)
- 128 byte RAM (P80/P87C51X2 and P80C31X2)
- 256 byte RAM (P80/P87C52/54X2/58X2 and P80C32X2)
- Boolean processor
- Fully static operation
- Low voltage (2.7 V to 5.5 V at 16 MHz) operation
- 12-clock operation with selectable 6-clock operation (via software or via parallel programmer)
- Memory addressing capability
  - Up to 64 kbytes ROM and 64 kbytes RAM
- Power control modes:
  - Clock can be stopped and resumed
  - Idle mode
  - Power-down mode
- CMOS and TTL compatible
- Two speed ranges at V<sub>CC</sub> = 5 V
  - 0 to 30 MHz with 6-clock operation
- 0 to 33 MHz with 12-clock operation

- PLCC, DIP, TSSOP or LQFP packages
- Extended temperature ranges
- Dual Data Pointers
- Security bits:
- ROM (2 bits)
- OTP (3 bits)
- Encryption array 64 bytes
- Four interrupt priority levels
- Six interrupt sources
- Four 8-bit I/O ports
- Full-duplex enhanced UART
  - Framing error detection
  - Automatic address recognition
- Three 16-bit timers/counters T0, T1 (standard 80C51) and additional T2 (capture and compare)
- Programmable clock-out pin
- Asynchronous port reset
- Low EMI (inhibit ALE, slew rate controlled outputs, and 6-clock mode)
- Wake-up from Power Down by an external interrupt.

### P80C3xX2; P80C5xX2; P87C5xX2

#### PART NUMBER DERIVATION

| Memory                                       |                                                                                                                                               | Temperature Range              | Package                                    |                                                |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------------------|------------------------------------------------|
| P87C51X2<br>7 = OTP<br>0 = ROM or<br>ROMless | 1 = 128 BYTES RAM<br>4 KBYTES ROM/OTP<br>2 = 256 BYTES RAM<br>8 KBYTES ROM/OTP<br>4 = 256 BYTES RAM<br>16 KBYTES ROM/OTP<br>8 = 256 BYTES RAM | X2 = 6-clock<br>mode available | B = 0 °C TO +70 °C<br>F = -40 °C TO +85 °C | A = PLCC<br>N = DIP<br>BD = LQFP<br>DH = TSSOP |
|                                              | 32 KBYTES ROM/OTP                                                                                                                             |                                |                                            |                                                |

The following table illustrates the correlation between operating mode, power supply and maximum external clock frequency:

| Operating Mode | Power Supply   | Maximum Clock Frequency |
|----------------|----------------|-------------------------|
| 6-clock        | 5 V ± 10%      | 30 MHz                  |
| 6-clock        | 2.7 V to 5.5 V | 16 MHz                  |
| 12-clock       | 5 V ± 10%      | 33 MHz                  |
| 12-clock       | 2.7 V to 5.5 V | 16 MHz                  |

### P80C3xX2; P80C5xX2; P87C5xX2

#### LOGIC SYMBOL



NOTE:

1. INT0/P3.2 and T1/P3.5 are absent in the TSSOP38 package.

#### PLASTIC DUAL IN-LINE PACKAGE PIN CONFIGURATIONS



### P80C3xX2; P80C5xX2; P87C5xX2

#### PLASTIC LEADED CHIP CARRIER PIN FUNCTIONS



#### LOW PROFILE QUAD FLAT PACK PIN FUNCTIONS



# PLASTIC THIN SHRINK SMALL OUTLINE PACK PIN FUNCTIONS



#### Table 1. Special Function Registers

| SYMBOL             | DESCRIPTION             | DIRECT<br>ADDRESS | B<br>MSB | IT ADDRE | SS, SYM | BOL, OR           | ALTERNA | TIVE PO     | RT FUNC | TION<br>LSB | RESET<br>VALUE |
|--------------------|-------------------------|-------------------|----------|----------|---------|-------------------|---------|-------------|---------|-------------|----------------|
| ACC*               | Accumulator             | E0H               | E7       | E6       | E5      | E4                | E3      | E2          | E1      | E0          | 00H            |
| AUXR#              | Auxiliary               | 8EH               | -        | -        | -       | -                 | -       | -           | - 1     | AO          | xxxxxxx0B      |
| AUXR1#             | Auxiliary 1             | A2H               | -        | _        | _       | LPEP <sup>2</sup> | WUPD    | 0           | - 1     | DPS         | xxx000x0E      |
| B*                 | B register              | F0H               | F7       | F6       | F5      | F4                | F3      | F2          | F1      | F0          | 00H            |
| CKCON              | Clock Control Register  | 8FH               | _        | _        | _       | -                 | -       | -           | -       | X2          | xxx00000E      |
| DPTR:              | Data Pointer (2 bytes)  |                   |          |          |         |                   |         |             |         |             |                |
| DPH                | Data Pointer High       | 83H               |          |          |         |                   |         |             |         |             | 00H            |
| DPL                | Data Pointer Low        | 82H               |          |          |         |                   |         |             |         |             | 00H            |
|                    |                         |                   | AF       | AE       | AD      | AC                | AB      | AA          | A9      | A8          |                |
| IE*                | Interrupt Enable        | A8H               | ĒĀ       | -        | ET2     | ES                | ET1     | EX1         | ET0     | EX0         | 0x000000       |
|                    |                         |                   | BF       | BE       | BD      | BC                | BB      | BA          | B9      | B8          | 1              |
| IP*                | Interrupt Priority      | B8H               | -        | -        | PT2     | PS                | PT1     | PX1         | PT0     | PX0         | xx000000E      |
| IPH#               | Interrupt Priority High | B7H               | -        | _        | PT2H    | PSH               | PT1H    | PX1H        | PT0H    | PX0H        | xx000000E      |
|                    |                         |                   | 87       | 86       | 85      | 84                | 83      | 82          | 81      | 80          | 1              |
| P0*                | Port 0                  | 80H               | AD7      | AD6      | AD5     | AD4               | AD3     | AD2         | AD1     | AD0         | FFH            |
|                    |                         |                   | 97       | 96       | 95      | 94                | 93      | 92          | 91      | 90          | 1              |
| P1*                | Port 1                  | 90H               | -        | -        | -       | -                 | -       | -           | T2EX    | T2          | FFH            |
|                    |                         |                   | A7       | A6       | A5      | A4                | A3      | A2          | A1      | A0          | 1              |
| P2*                | Port 2                  | A0H               | AD15     | AD14     | AD13    | AD12              | AD11    | AD10        | AD9     | AD8         | FFH            |
|                    |                         |                   | B7       | B6       | B5      | B4                | B3      | B2          | B1      | B0          | 1              |
| P3*                | Port 3                  | B0H               | RD       | WR       | T1      | T0                | INT1    | <b>INTO</b> | TxD     | RxD         | FFH            |
| PCON# <sup>1</sup> | Power Control           | 87H               | SMOD1    | SMOD0    | _       | POF               | GF1     | GF0         | PD      | IDL         | 00xx00001      |
|                    |                         | 0/11              | D7       | D6       | <br>D5  | D4                | D3      | D2          | D1      | D0          |                |
| PSW*               | Program Status Word     | DOH               | CY       | AC       | F0      | RS1               | RS0     | OV          | -       | P           | 000000x01      |
| RACAP2H#           | Timer 2 Capture High    | CBH               | 01       | ////     | 10      |                   | 1100    | 0,          |         |             | 00H            |
| RACAP2L#           | Timer 2 Capture Low     | CAH               |          |          |         |                   |         |             |         |             | 00H            |
| SADDR#             | Slave Address           | A9H               |          |          |         |                   |         |             |         |             | 00H            |
| SADEN#             | Slave Address Mask      | B9H               |          |          |         |                   |         |             |         |             | 00H            |
| SBUF               | Serial Data Buffer      | 99H               |          |          |         |                   |         |             |         |             | XXXXXXXXB      |
|                    |                         |                   | 9F       | 9E       | 9D      | 9C                | 9B      | 9A          | 99      | 98          |                |
| SCON*              | Serial Control          | 98H               | SM0/FE   | SM1      | SM2     | REN               | TB8     | RB8         | TI      | RI          | 00H            |
| SP                 | Stack Pointer           | 81H               |          |          |         |                   |         |             |         |             | 07H            |
|                    |                         |                   | 8F       | 8E       | 8D      | 8C                | 8B      | 8A          | 89      | 88          |                |
| TCON*              | Timer Control           | 88H               | TF1      | TR1      | TF0     | TR0               | IE1     | IT1         | IE0     | IT0         | 00H            |
|                    |                         |                   | CF       | CE       | CD      | CC                | СВ      | CA          | C9      | C8          | 1              |
| T2CON*             | Timer 2 Control         | C8H               | TF2      | EXF2     | RCLK    | TCLK              | EXEN2   | TR2         | C/T2    | CP/RL2      | 00H            |
| T2MOD#             | Timer 2 Mode Control    | C9H               | _        | _        | _       | _                 | -       | _           | T2OE    | DCEN        | xxxxxx00E      |
| TH0                | Timer High 0            | 8CH               |          |          |         |                   |         |             |         |             | 00H            |
| TH1                | Timer High 1            | 8DH               |          |          |         |                   |         |             |         |             | 00H            |
| TH2#               | Timer High 2            | CDH               |          |          |         |                   |         |             |         |             | 00H            |
| TL0                | Timer Low 0             | 8AH               |          |          |         |                   |         |             |         |             | 00H            |
| TL1                | Timer Low 1             | 8BH               |          |          |         |                   |         |             |         |             | 00H            |
| TL2#               | Timer Low 2             | ССН               |          |          |         |                   |         |             |         |             | 00H            |
| TMOD               | Timer Mode              | 89H               | GATE     | C/T      | M1      | M0                | GATE    | C/T         | M1      | M0          | 00H            |

#### NOTE:

Unused register bits that are not defined should not be set by the user's program. If violated, the device could function incorrectly. \* SFRs are bit addressable.

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

- Reserved bits.

1. Reset value depends on reset source.

2. LPEP – Low Power EPROM operation (OTP only)

### P80C3xX2; P80C5xX2; P87C5xX2

P87C5xX2

P80C3xX2; P80C5xX2;

#### 80C51 8-bit microcontroller family 4K/8K/16K/32K ROM/OTP, low voltage (2.7 to 5.5 V), low power, high speed (30/33 MHz)

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

|        | ddress =<br>t Address |           |                                                                                                                                                                                                                                                                                                                                                |                               |              |                                 |              | Г            | Reset Value   | = 00⊓                                                      |
|--------|-----------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------------|---------------------------------|--------------|--------------|---------------|------------------------------------------------------------|
|        |                       | 7         | 6                                                                                                                                                                                                                                                                                                                                              | 5                             | 4            | 3                               | 2            | 1            | 0             |                                                            |
|        |                       | TF2       | EXF2                                                                                                                                                                                                                                                                                                                                           | RCLK                          | TCLK         | EXEN2                           | TR2          | C/T2         | CP/RL2        |                                                            |
| Symbol | Positi                | ion Na    | me and Sig                                                                                                                                                                                                                                                                                                                                     | nificance                     |              |                                 |              |              |               |                                                            |
| TF2    | T2CO                  |           | ner 2 overflo<br>en either R0                                                                                                                                                                                                                                                                                                                  |                               |              | overflow and                    | l must be c  | leared by so | oftware. TF2  | will not be set                                            |
| EXF2   | T2CO                  | EX        | Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX and $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   | T2CO                  |           | 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   | T2CO                  |           |                                                                                                                                                                                                                                                                                                                                                |                               |              | the serial po<br>imer 1 overfle |              |              |               | or its transmit cloo<br>ck.                                |
| EXEN2  | T2CO                  | tra       | Timer 2 external enable flag. When set, allows a capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not being used to clock the serial port. EXEN2 = 0 causes Timer 2 to ignore events at T2EX.                                                                                                             |                               |              |                                 |              |              |               |                                                            |
| TR2    | T2CO                  | N.2 Sta   | art/stop cont                                                                                                                                                                                                                                                                                                                                  | ol for Time                   | 2. A logic 1 | starts the tir                  | mer.         |              |               |                                                            |
| C/T2   | T2CO                  | N.1 Tin   | Timer or counter select. (Timer 2)<br>0 = Internal timer (OSC/12 in 12-clock mode or OSC/6 in 6-clock mode)<br>1 = External event counter (falling edge triggered).                                                                                                                                                                            |                               |              |                                 |              |              |               |                                                            |
| CP/RE2 | T2CO                  | cle<br>EX | ared, auto-r                                                                                                                                                                                                                                                                                                                                   | eloads will o<br>nen either F | occur either | with Timer 2                    | overflows of | or negative  | transitions a | EXEN2 = 1. Whe<br>T2EX when<br>ced to auto-reloa<br>SU016. |

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

### P80C3xX2; P80C5xX2; P87C5xX2



Figure 7. Timer 2 in Capture Mode

| T2MOD                                                                                                                                                                                                                                                                                                                                                                                                                | Address    | = 0C9H  |     |                                |               |               |       |      | Reset Va | lue = XXXX XX00E |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------|-----|--------------------------------|---------------|---------------|-------|------|----------|------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                      | Not Bit Ad | dressal | ble |                                |               |               |       |      |          |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                      |            | 7       | 6   | 5                              | 4             | 3             | 2     | 1    | 0        |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                      |            | _       | _   | _                              | _             | _             | _     | T2OE | DCEN     |                  |
| Symbol                                                                                                                                                                                                                                                                                                                                                                                                               | Positior   | 1       |     | <b>unction</b><br>lot implemer | nted. reserve | ed for future | use.* |      |          |                  |
| T2OE                                                                                                                                                                                                                                                                                                                                                                                                                 | T2MOD.     | 1       |     | imer 2 Outp                    |               |               |       |      |          |                  |
| DCEN    T2MOD.0    Down Count Enable bit. When set, this allows Timer 2 to be configured as an up/down counter.      *    User software should not write 1s to reserved bits. These bits may be used in future 8051 family products to invoke new features. 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 indeterminate. |            |         |     |                                |               |               |       |      |          |                  |

Figure 8. Timer 2 Mode (T2MOD) Control Register

#### FULL-DUPLEX ENHANCED UART

#### Standard UART operation

The serial port is full duplex, meaning it can transmit and receive simultaneously. It is also receive-buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the register. (However, if the first byte still hasn't been read by the time reception of the second byte is complete, one of the bytes will be lost.) The serial port receive and transmit registers are both accessed at Special Function Register SBUF. Writing to SBUF loads the transmit register, and reading SBUF accesses a physically separate receive register.

The serial port can operate in 4 modes:

- Mode 0: Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received (LSB first). The baud rate is fixed at 1/12 the oscillator frequency in 12-clock mode or 1/6 the oscillator frequency in 6-clock mode.
- Mode 1: 10 bits are transmitted (through TxD) or received (through RxD): a start bit (0), 8 data bits (LSB first), and a stop bit (1). On receive, the stop bit goes into RB8 in Special Function Register SCON. The baud rate is variable.
- Mode 2: 11 bits are transmitted (through TxD) or received (through RxD): start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On Transmit, the 9th data bit (TB8 in SCON) can be assigned the value of 0 or 1. Or, for example, the parity bit (P, in the PSW) could be moved into TB8. On receive, the 9th data bit goes into RB8 in Special Function Register SCON, while the stop bit is ignored. The baud rate is programmable to either 1/32 or 1/64 the oscillator frequency in 12-clock mode or 1/16 or 1/32 the oscillator frequency in 6-clock mode.
- Mode 3: 11 bits are transmitted (through TxD) or received (through RxD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). In fact, Mode 3 is the same as Mode 2 in all respects except baud rate. The baud rate in Mode 3 is variable.

In all four modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming start bit if REN = 1.

#### **Multiprocessor Communications**

Modes 2 and 3 have a special provision for multiprocessor communications. In these modes, 9 data bits are received. The 9th one goes into RB8. Then comes a stop bit. The port can be programmed such that when the stop bit is received, the serial port interrupt will be activated only if RB8 = 1. This feature is enabled by setting bit SM2 in SCON. A way to use this feature in multiprocessor systems is as follows:

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is 1 in an address byte and 0 in a data byte. With SM2 = 1, no slave will be interrupted by a data byte. An address byte, however, will interrupt all slaves, so that each slave can examine the received byte and see if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that will be coming.

### P80C3xX2; P80C5xX2; P87C5xX2

The slaves that weren't being addressed leave their SM2s set and go on about their business, ignoring the coming data bytes.

SM2 has no effect in Mode 0, and in Mode 1 can be used to check the validity of the stop bit. In a Mode 1 reception, if SM2 = 1, the receive interrupt will not be activated unless a valid stop bit is received.

#### Serial Port Control Register

The serial port control and status register is the Special Function Register SCON, shown in Figure 12. This register contains not only the mode selection bits, but also the 9th data bit for transmit and receive (TB8 and RB8), and the serial port interrupt bits (TI and RI).

#### **Baud Rates**

The baud rate in Mode 0 is fixed: Mode 0 Baud Rate = Oscillator Frequency / 12 (12-clock mode) or / 6 (6-clock mode). The baud rate in Mode 2 depends on the value of bit SMOD in Special Function Register PCON. If SMOD = 0 (which is the value on reset), and the port pins in 12-clock mode, the baud rate is 1/64 the oscillator frequency. If SMOD = 1, the baud rate is 1/32 the oscillator frequency. In 6-clock mode, the baud rate is 1/32 or 1/16 the oscillator frequency, respectively.

Mode 2 Baud Rate =

 $\frac{2^{\text{SMOD}}}{n} \times (\text{Oscillator Frequency})$ 

Where:

n = 64 in 12-clock mode, 32 in 6-clock mode

The baud rates in Modes 1 and 3 are determined by the Timer 1 or Timer 2 overflow rate.

#### Using Timer 1 to Generate Baud Rates

When Timer 1 is used as the baud rate generator (T2CON.RCLK = 0, T2CON.TCLK = 0), the baud rates in Modes 1 and 3 are determined by the Timer 1 overflow rate and the value of SMOD as follows:

Mode 1, 3 Baud Rate =

$$\frac{2^{\text{SMOD}}}{n} \times$$
 (Timer 1 Overflow Rate)

Where:

n = 32 in 12-clock mode, 16 in 6-clock mode

The Timer 1 interrupt should be disabled in this application. The Timer itself can be configured for either "timer" or "counter" operation, and in any of its 3 running modes. In the most typical applications, it is configured for "timer" operation, in the auto-reload mode (high nibble of TMOD = 0010B). In that case the baud rate is given by the formula:

Mode 1, 3 Baud Rate =

$$\frac{2^{\text{SMOD}}}{n} \times \frac{\text{Oscillator Frequency}}{12 \times [256-(\text{TH1})]}$$

Where:

n = 32 in 12-clock mode, 16 in 6-clock mode

One can achieve very low baud rates with Timer 1 by leaving the Timer 1 interrupt enabled, and configuring the Timer to run as a 16-bit timer (high nibble of TMOD = 0001B), and using the Timer 1 interrupt to do a 16-bit software reload. Figure 13 lists various commonly used baud rates and how they can be obtained from Timer 1.

| S     | CON    | Addres                                                                                                                                           | ss = 98H                                  |           |                      |           |          |                       |                      |          |          | Reset Value = 00H                                                       |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------|----------------------|-----------|----------|-----------------------|----------------------|----------|----------|-------------------------------------------------------------------------|
|       |        | Bit Addressable                                                                                                                                  |                                           |           | 6                    | 5         | 4        | 3                     | 2                    | 1        | 0        | _                                                                       |
|       |        |                                                                                                                                                  |                                           | SM0       | SM1                  | SM2       | REN      | TB8                   | RB8                  | ΤI       | RI       |                                                                         |
| Where | e SM0, | SM1 spe                                                                                                                                          | cify the serial po                        | ort mode  | e, as foll           | ows:      |          |                       |                      |          |          |                                                                         |
| SM0   | SM1    | Mode                                                                                                                                             | Description                               | E         | Baud Ra              | ate       |          |                       |                      |          |          |                                                                         |
| 0     | 0      | 0                                                                                                                                                | shift register                            |           | f <sub>OSC</sub> /12 | 2 (12-clo | ock moc  | le) or f <sub>O</sub> | <sub>SC</sub> /6 (6- | clock m  | node)    |                                                                         |
| 0     | 1      | 1                                                                                                                                                | 8-bit UART variable                       |           |                      |           |          |                       |                      |          |          |                                                                         |
| 1     | 0      | 0 2 9-bit UART f <sub>OSC</sub> /64 or f <sub>OSC</sub> /32 (12-clock mode) or f <sub>OSC</sub> /32 or f <sub>OSC</sub> /16 (6-clock mode)       |                                           |           |                      |           |          |                       |                      |          |          |                                                                         |
| 1     | 1      | 3                                                                                                                                                | 9-bit UART                                | variable  |                      |           |          |                       |                      |          |          |                                                                         |
| SM2   | acti   | vated if th                                                                                                                                      |                                           | data bit  | (RB8) is             |           |          |                       |                      |          | ,        | M2 is set to 1, then RI will not be tivated if a valid stop bit was not |
| REN   | Ena    | ables seri                                                                                                                                       | al reception. Se                          | t by soft | ware to              | enable    | receptio | on. Clea              | r by soft            | tware to | disable  | e reception.                                                            |
| TB8   | The    | e 9th data                                                                                                                                       | bit that will be t                        | ransmitt  | ed in M              | odes 2    | and 3. S | Set or cl             | ear by s             | oftware  | as desi  | ired.                                                                   |
| RB8   |        | In Modes 2 and 3, is the 9th data bit that was received. In Mode 1, it SM2=0, RB8 is the stop bit that was received. In Mode 0, RB8 is not used. |                                           |           |                      |           |          |                       |                      |          |          |                                                                         |
| ті    |        |                                                                                                                                                  | errupt flag. Set b<br>ny serial transmi   |           |                      |           |          |                       | e in Mo              | de 0, or | at the b | beginning of the stop bit in the other                                  |
| RI    |        |                                                                                                                                                  | rrupt flag. Set by<br>ny serial reception |           |                      |           |          |                       |                      |          | halfway  | / through the stop bit time in the other                                |

SU01626

| Baud Rate     |               |              | t.         | CHOD | Timer 1 |      |              |  |  |
|---------------|---------------|--------------|------------|------|---------|------|--------------|--|--|
| Mode          | 12-clock mode | 6-clock mode | fosc       | SMOD | С/Т     | Mode | Reload Value |  |  |
| Mode 0 Max    | 1.67 MHz      | 3.34 MHz     | 20 MHz     | Х    | Х       | Х    | Х            |  |  |
| Mode 2 Max    | 625 k         | 1250 k       | 20 MHz     | 1    | X       | Х    | Х            |  |  |
| Mode 1, 3 Max | 104.2 k       | 208.4 k      | 20 MHz     | 1    | 0       | 2    | FFH          |  |  |
| Mode 1, 3     | 19.2 k        | 38.4 k       | 11.059 MHz | 1    | 0       | 2    | FDH          |  |  |
|               | 9.6 k         | 19.2 k       | 11.059 MHz | 0    | 0       | 2    | FDH          |  |  |
|               | 4.8 k         | 9.6 k        | 11.059 MHz | 0    | 0       | 2    | FAH          |  |  |
|               | 2.4 k         | 4.8 k        | 11.059 MHz | 0    | 0       | 2    | F4H          |  |  |
|               | 1.2 k         | 2.4 k        | 11.059 MHz | 0    | 0       | 2    | E8H          |  |  |
|               | 137.5         | 275          | 11.986 MHz | 0    | 0       | 2    | 1DH          |  |  |
|               | 110           | 220          | 6 MHz      | 0    | 0       | 2    | 72H          |  |  |
|               | 110           | 220          | 12 MHz     | 0    | 0       | 1    | FEEBH        |  |  |

#### Figure 12. Serial Port Control (SCON) Register

Figure 13. Timer 1 Generated Commonly Used Baud Rates

#### More About Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed a 1/12 the oscillator frequency (12-clock mode) or 1/6 the oscillator frequency (6-clock mode).

Figure 14 shows a simplified functional diagram of the serial port in Mode 0, and associated timing.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal at S6P2 also loads a 1 into the 9th position of the transmit shift register and tells the TX Control block to commence a transmission. The internal timing is such that one full machine cycle will elapse between "write to SBUF" and activation of SEND.

SEND enables the output of the shift register to the alternate output function line of P3.0 and also enable SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK is low during S3, S4, and S5 of every machine cycle, and high during S6, S1, and S2. At

S6P2 of every machine cycle in which SEND is active, the contents of the transmit shift are shifted to the right one position.

As data bits shift out to the right, zeros come in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position, is just to the left of the MSB, and all positions to the left of that contain zeros. This condition flags the TX Control block to do one last shift and then deactivate SEND and set T1. Both of these actions occur at S1P1 of the 10th machine cycle after "write to SBUF."

Reception is initiated by the condition REN = 1 and R1 = 0. At S6P2 of the next machine cycle, the RX Control unit writes the bits 1111110 to the receive shift register, and in the next clock phase activates RECEIVE.

RECEIVE enable SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK makes transitions at S3P1 and S6P1 of every machine cycle. At S6P2 of every machine cycle in which RECEIVE is active, the contents of the receive shift register are

### P80C3xX2; P80C5xX2; P87C5xX2

### P80C3xX2; P80C5xX2; P87C5xX2



Figure 15. Serial Port Mode 1

### P80C3xX2; P80C5xX2; P87C5xX2

#### Enhanced UART operation

In addition to the standard operation modes, the UART can perform framing error detect by looking for missing stop bits, and automatic address recognition. The UART also fully supports multiprocessor communication.

When used for framing error detect the UART looks for missing stop bits in the communication. A missing bit will set the FE bit in the SCON register. The FE bit shares the SCON.7 bit with SM0 and the function of SCON.7 is determined by PCON.6 (SMOD0) (see Figure 18). If SMOD0 is set then SCON.7 functions as FE. SCON.7 functions as SM0 when SMOD0 is cleared. When used as FE SCON.7 can only be cleared by software. Refer to Figure 19.

#### Automatic Address Recognition

Automatic Address Recognition is a feature which allows the UART to recognize certain addresses in the serial bit stream by using hardware to make the comparisons. This feature saves a great deal of software overhead by eliminating the need for the software to examine every serial address which passes by the serial port. This feature is enabled by setting the SM2 bit in SCON. In the 9 bit UART modes, mode 2 and mode 3, the Receive Interrupt flag (RI) will be automatically set when the received byte contains either the "Given" address or the "Broadcast" address. The 9 bit mode requires that the 9th information bit is a 1 to indicate that the received information is an address and not data. Automatic address recognition is shown in Figure 20.

The 8 bit mode is called Mode 1. In this mode the RI flag will be set if SM2 is enabled and the information received has a valid stop bit following the 8 address bits and the information is either a Given or Broadcast address.

Mode 0 is the Shift Register mode and SM2 is ignored.

Using the Automatic Address Recognition feature allows a master to selectively communicate with one or more slaves by invoking the Given slave address or addresses. All of the slaves may be contacted by using the Broadcast address. Two special Function Registers are used to define the slave's address, SADDR, and the address mask, SADEN. SADEN is used to define which bits in the SADDR are to be used and which bits are "don't care". The SADEN mask can be logically ANDed with the SADDR to create the "Given" address which the master will use for addressing each of the slaves. Use of the Given address allows multiple slaves to be recognized while excluding others. The following examples will help to show the versatility of this scheme:

| Slave 0 | SADDR | = | 1100 000        | 0   |
|---------|-------|---|-----------------|-----|
|         | SADEN | = | <u>1111 110</u> | 1   |
|         | Given | = | 1100 00>        | (0) |

| Slave 1 | SADDR | = | 1100 0000        |
|---------|-------|---|------------------|
|         | SADEN | = | <u>1111 1110</u> |
|         | Given | = | 1100 000X        |

In the above example SADDR is the same and the SADEN data is used to differentiate between the two slaves. Slave 0 requires a 0 in bit 0 and it ignores bit 1. Slave 1 requires a 0 in bit 1 and bit 0 is ignored. A unique address for Slave 0 would be 1100 0010 since slave 1 requires a 0 in bit 1. A unique address for slave 1 would be 1100 0001 since a 1 in bit 0 will exclude slave 0. Both slaves can be selected at the same time by an address which has bit 0 = 0 (for slave 0) and bit 1 = 0 (for slave 1). Thus, both could be addressed with 1100 0000.

In a more complex system the following could be used to select slaves 1 and 2 while excluding slave 0:

| Slave 0 | SADDR | = | 1100 0000        |
|---------|-------|---|------------------|
|         | SADEN | = | <u>1111 1001</u> |
|         | Given | = | 1100 0XX0        |
| Slave 1 | SADDR | = | 1110 0000        |
|         | SADEN | = | <u>1111 1010</u> |
|         | Given | = | 1110 0X0X        |
| Slave 2 | SADDR | = | 1110 0000        |
|         | SADEN | = | <u>1111 1100</u> |
|         | Given | = | 1110 00XX        |

In the above example the differentiation among the 3 slaves is in the lower 3 address bits. Slave 0 requires that bit 0 = 0 and it can be uniquely addressed by 1110 0110. Slave 1 requires that bit 1 = 0 and it can be uniquely addressed by 1110 and 0101. Slave 2 requires that bit 2 = 0 and its unique address is 1110 0011. To select Slaves 0 and 1 and exclude Slave 2 use address 1110 0100, since it is necessary to make bit 2 = 1 to exclude slave 2.

The Broadcast Address for each slave is created by taking the logical OR of SADDR and SADEN. Zeros in this result are trended as don't-cares. In most cases, interpreting the don't-cares as ones, the broadcast address will be FF hexadecimal.

Upon reset SADDR (SFR address 0A9H) and SADEN (SFR address 0B9H) are leaded with 0s. This produces a given address of all "don't cares" as well as a Broadcast address of all "don't cares". This effectively disables the Automatic Addressing mode and allows the microcontroller to use standard 80C51 type UART drivers which do not make use of this feature.

## P80C3xX2; P80C5xX2; P87C5xX2

|        |       | 7       | 6                     | 5                       | 4                               | 3                               | 2                           | 1                             | 0                           |                                                                                                   |
|--------|-------|---------|-----------------------|-------------------------|---------------------------------|---------------------------------|-----------------------------|-------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------|
|        | ſ     | SM0/FE  | SM1                   | SM2                     | REN                             | TB8                             | RB8                         | TI                            | RI                          | ]                                                                                                 |
|        | (     | SMOD0 = | 0/1)*                 |                         |                                 |                                 |                             |                               |                             | -                                                                                                 |
| Symbol | Posit | ion     | Functior              | n                       |                                 |                                 |                             |                               |                             |                                                                                                   |
| FE     | SCO   | N.7     | cleared b             |                         | imes but sho                    |                                 |                             |                               |                             | ected. The FE bit is not<br>ust be set to enable                                                  |
| SM0    | SCO   | N.7     | Serial Po             | rt Mode E               | it 0, (SMOD                     | 0 must = 0 to                   | access bit                  | SM0)                          |                             |                                                                                                   |
| SM1    | SCO   | N.6     | Serial Po             | rt Mode E               | Sit 1                           |                                 |                             |                               |                             |                                                                                                   |
|        |       |         | SM0                   | SM1                     | Mode                            | Description                     | Bau                         | d Rate**                      |                             |                                                                                                   |
|        |       |         | 0                     | 0                       | 0                               | shift register                  | fosc                        | /12 (12-clk ı                 | mode) or f <sub>O</sub>     | <sub>SC</sub> /6 (6-clk mode)                                                                     |
|        |       |         | 0                     | 1                       | 1                               | 8-bit UART                      | varia                       |                               |                             |                                                                                                   |
|        |       |         | 1                     | 0                       | 2                               | 9-bit UART                      | fosc                        | /32 (12-cloc                  |                             | 16 (6-clock mode) or                                                                              |
|        |       |         | 1                     | 1                       | 3                               | 9-bit UART                      | varia                       | ble                           |                             |                                                                                                   |
| SM2    | SCO   | N.5     | unless th<br>Broadcas | e receive<br>at Address | d 9th data bit<br>s. In Mode 1, | (RB8) is 1, ir<br>if SM2 = 1 th | idicating a<br>en RI will r | n address, a<br>not be activa | and the rece<br>ated unless | 1 then RI will not be set<br>eived byte is a Given or<br>a valid stop bit was<br>SM2 should be 0. |
| REN    | SCO   | N.4     | Enables               | serial rece             | eption. Set by                  | / software to                   | enable rec                  | eption. Clea                  | ar by softwa                | re to disable reception.                                                                          |
| TB8    | SCO   | N.3     | The 9th o             | lata bit the            | at will be tran                 | smitted in Mo                   | des 2 and                   | 3. Set or cl                  | ear by softw                | vare as desired.                                                                                  |
| RB8    | SCO   | N.2     | was rece              |                         |                                 | bit that was re                 | eceived. In                 | Mode 1, if                    | SM2 = 0, R                  | B8 is the stop bit that                                                                           |
| ТІ     | SCO   | N.1     |                       |                         |                                 | ardware at th<br>in any serial  |                             |                               |                             | 0, or at the beginning of software.                                                               |
| RI     | SCO   | N.0     |                       | me in the               |                                 |                                 |                             |                               |                             | ), or halfway through the<br>st be cleared by                                                     |
| DTES:  |       |         |                       |                         |                                 | , in any sena                   | reception                   | (except set                   | 5 GM2). Ma                  | St Se cleared by                                                                                  |

Figure 18. SCON: Serial Port Control Register

### P80C3xX2; P80C5xX2; P87C5xX2

#### **Interrupt Priority Structure**



Figure 21. Interrupt Sources

#### Interrupts

The devices described in this data sheet provide six interrupt sources. These are shown in Figure 21. The External Interrupts INTO and INT1 can each be either level-activated or transition-activated, depending on bits ITO and IT1 in Register TCON. The flags that actually generate these interrupts are bits IE0 and IE1 in TCON. When an external interrupt is generated, the flag that generated it is cleared by the hardware when the service routine is vectored to only if the interrupt was transition-activated. If the interrupt was level-activated, then the external requesting source is what controls the request flag, rather than the on-chip hardware.

The Timer 0 and Timer 1 Interrupts are generated by TF0 and TF1, which are set by a rollover in their respective Timer/Counter registers (except see Timer 0 in Mode 3). When a timer interrupt is generated, the flag that generated it is cleared by the on-chip hardware when the service routine is vectored to.

The Serial Port Interrupt is generated by the logical OR of RI and TI. Neither of these flags is cleared by hardware when the service routine is vectored to. In fact, the service routine will normally have to determine whether it was RI or TI that generated the interrupt, and the bit will have to be cleared in software.

All of the bits that generate interrupts can be set or cleared by software, with the same result as though it had been set or cleared by hardware. That is, interrupts can be generated or pending interrupts can be canceled in software.

Each of these interrupt sources can be individually enabled or disabled by setting or clearing a bit in Special Function Register IE (Figure 22). IE also contains a global disable bit,  $\overline{EA}$ , which disables all interrupts at once.

#### **Priority Level Structure**

Each interrupt source can also be individually programmed to one of four priority levels by setting or clearing bits in Special Function Registers IP (Figure 23) and IPH (Figure 24). A lower-priority interrupt can itself be interrupted by a higher-priority interrupt, but not by another interrupt of the same level. A high-priority level 3 interrupt can't be interrupted by any other interrupt source.

If two request of different priority levels are received simultaneously, the request of higher priority level is serviced. If requests of the same priority level are received simultaneously, an internal polling sequence determines which request is serviced. Thus within each priority level there is a second priority structure determined by the polling sequence as follows:

#### Source

#### Priority Within Level (highest)

1. IE0 (External Int 0)

- 2. TF0 (Timer 0)
- 3. IE1 (External Int 1)
- 4. TF1 (Timer 1)
- 5. RI+TI (UART)
  6. TF2, EXF2 (Timer 2)

(lowest)

Note that the "priority within level" structure is only used to resolve simultaneous requests of the same priority level.

The IP and IPH registers contain a number of unimplemented bits. User software should not write 1s to these positions, since they may be used in other 80C51 Family products.

#### How Interrupts Are Handled

The interrupt flags are sampled at S5P2 of every machine cycle. The samples are polled during the following machine cycle. If one of the flags was in a set condition at S5P2 of the preceding cycle, the polling cycle will find it and the interrupt system will generate an LCALL to the appropriate service routine, provided this hardware-generated LCALL is not blocked by any of the following conditions:

- 1. An interrupt of equal or higher priority level is already in progress.
- 2. The current (polling) cycle is not the final cycle in the execution of the instruction in progress.
- 3. The instruction in progress is RETI or any write to the IE or IP registers.

Any of these three conditions will block the generation of the LCALL to the interrupt service routine. Condition 2 ensures that the instruction in progress will be completed before vectoring to any service routine. Condition 3 ensures that if the instruction in progress is RETI or any access to IE or IP, then at least one more instruction will be executed before any interrupt is vectored to.

The polling cycle is repeated with each machine cycle, and the values polled are the values that were present at S5P2 of the previous machine cycle. Note that if an interrupt flag is active but not being responded to for one of the above conditions, if the flag is not still active when the blocking condition is removed, the denied interrupt will not be serviced. In other words, the fact that the interrupt flag was once active but not serviced is not remembered. Every polling cycle is new.

P87C5xX2

P80C3xX2; P80C5xX2;

#### 80C51 8-bit microcontroller family 4K/8K/16K/32K ROM/OTP, low voltage (2.7 to 5.5 V), low power, high speed (30/33 MHz)

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 |
|----------------------|------------------|--------------|---------------------------------------|----------------|
| External interrupt 0 | 1                | IE0          | N (L) <sup>1</sup> Y (T) <sup>2</sup> | 03H            |
| Timer 0              | 2                | TF0          | Y                                     | 0BH            |
| External interrupt 1 | 3                | IE1          | N (L) Y (T)                           | 13H            |
| Timer 1              | 4                | TF1          | Y                                     | 1BH            |
| UART                 | 5                | RI, TI       | Ν                                     | 23H            |
| Timer 2              | 6                | TF2, EXF2    | N                                     | 2BH            |

NOTES:

1. L = Level activated

2. T = Transition activated

#### Reduced EMI

All port pins have slew rate controlled outputs. This is to limit noise generated by quickly switching output signals. The slew rate is factory set to approximately 10 ns rise and fall times.

#### Reduced EMI Mode

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

#### AUXR (8EH)



#### **Dual DPTR**

The dual DPTR structure (see Figure 26) enables a way to 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: xxx000x0B

#### AUXR1 (A2H)

| LPEP WUPD 0 - DPS | 7 | 6 | 5 | 4    | 3    | 2 | 1 | 0   |
|-------------------|---|---|---|------|------|---|---|-----|
|                   | - | - | - | LPEP | WUPD | 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.

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 WUPD or LPEP bits.



Figure 26.

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

### P80C3xX2; P80C5xX2; P87C5xX2

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

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

NOTES:

 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 FREG |     |      |
|---------------------|--------|----------------------|----------------|-------------------------|------------|-----|------|
| SYMBOL              | FIGURE | PARAMETER            | OPERATING MODE | POWER SUPPLY<br>VOLTAGE | MIN        | MAX | UNIT |
| 1/t <sub>CLCL</sub> | 31     | Oscillator frequency | 6-clock        | 5 V ± 10%               | 0          | 30  | MHz  |
|                     |        |                      | 6-clock        | 2.7 V to 5.5 V          | 0          | 16  | MHz  |
|                     |        |                      | 12-clock       | $5 V \pm 10\%$          | 0          | 33  | MHz  |
|                     |        |                      | 12-clock       | 2.7 V to 5.5 V          | 0          | 16  | MHz  |

Product data

#### **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
- $\mathsf{C}-\,\mathsf{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
- $\label{eq:tauples} \begin{array}{l} \mbox{Examples: } t_{AVLL} = \mbox{Time for address valid to ALE low.} \\ t_{LLPL} = \mbox{Time for ALE low to } \overline{\mbox{PSEN}} \mbox{ low.} \end{array}$



Figure 27. External Program Memory Read Cycle



Figure 28. External Data Memory Read Cycle

### P80C3xX2; P80C5xX2; P87C5xX2

V<sub>CC</sub>

lcc

#### 80C51 8-bit microcontroller family 4K/8K/16K/32K ROM/OTP, low voltage (2.7 to 5.5 V), low power, high speed (30/33 MHz)

### P80C3xX2; P80C5xX2; P87C5xX2

Vcc

P0

ĒΑ







RST

XTAL2

All other pins are disconnected







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

Product data

**PROGRAMMING AND VERIFICATION CHARACTERISTICS** 

T<sub>amb</sub> = 21 °C to +27 °C, V<sub>CC</sub> = 5 V±10%, V<sub>SS</sub> = 0 V (See Figure 43)

| 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 40. FOR VERIFICATION CONDITIONS SEE FIGURE 42.

\*\* SEE TABLE 9.

Figure 43. Programming and Verification

Product data

| ADDRESS        | CONTENT | BIT(S) | COMMENT            |
|----------------|---------|--------|--------------------|
| 0000H to 1FFFH | DATA    | 7:0    | User ROM Data      |
| 2000H to 203FH | KEY     | 7:0    | ROM Encryption Key |
| 2040H          | SEC     | 0      | ROM Security Bit 1 |
| 2040H          | SEC     | 1      | ROM Security Bit 2 |

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

1. External MOVC is disabled, and

2.  $\overline{\text{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 |  |

P80C3xX2; P80C5xX2; P87C5xX2

#### **REVISION HISTORY**

| Rev | Date     | Description                                                            |
|-----|----------|------------------------------------------------------------------------|
| _6  | 20030124 | Product data (9397 750 10995); ECN 853-2337 29260 of 06 December 2002  |
|     |          | Modifications:                                                         |
|     |          | Added TSSOP38 package details                                          |
| _5  | 20020912 | Product data (9397 750 10361); ECN 853-2337 28906 of 12 September 2002 |
| _4  | 20020612 | Product data (9397 750 09969); ECN 853-2337 28427 of 12 June 2002      |
| _3  | 20020422 | Product data (9397 750 09779); ECN 853-2337 28059 of 22 April 2002     |
| _2  | 20020219 | Preliminary data (9397 750 09467)                                      |
| _1  | 20010924 | Preliminary data (9397 750 08895); initial release                     |