



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 - Microcontrollers</u>"

| Details                    |                                                                        |
|----------------------------|------------------------------------------------------------------------|
| Product Status             | Obsolete                                                               |
| Core Processor             | 8051                                                                   |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 16MHz                                                                  |
| Connectivity               | UART/USART                                                             |
| Peripherals                | POR                                                                    |
| Number of I/O              | 32                                                                     |
| Program Memory Size        | •                                                                      |
| Program Memory Type        | ROMIess                                                                |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 128 x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                            |
| Data Converters            | -                                                                      |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 85°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/p80c31sfaa-512 |

Email: info@E-XFL.COM

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

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32

# 80C51/87C51 AND 80C31 ORDERING INFORMATION

| ROMIess     | TEMPERATURE RANGE °C<br>AND PACKAGE      | VOLTAGE<br>RANGE | FREQ.<br>(MHz) | DRAWING<br>NUMBER |
|-------------|------------------------------------------|------------------|----------------|-------------------|
| P80C31SBPN  | 0 to +70, Plastic Dual In-line Package   | 2.7 V to 5.5 V   | 0 to 16        | SOT129-1          |
| P80C31SBAA  | 0 to +70, Plastic Leaded Chip Carrier    | 2.7 V to 5.5 V   | 0 to 16        | SOT187-2          |
| P80C31SBBB  | 0 to +70, Plastic Quad Flat Pack         | 2.7 V to 5.5 V   | 0 to 16        | SOT307-2          |
| P80C31SFPN  | -40 to +85, Plastic Dual In-line Package | 2.7 V to 5.5 V   | 0 to 16        | SOT129-1          |
| P80C31SFA A | -40 to +85, Plastic Leaded Chip Carrier  | 2.7 V to 5.5 V   | 0 to 16        | SOT187-2          |
| P80C31SFBB  | –40 to +85, Plastic Quad Flat Pack       | 2.7 V to 5.5 V   | 0 to 16        | SOT307-2          |

# PART NUMBER DERIVATION

| DEVICE NUMBER | OPERATING FREQUENCY, MAX (S) | TEMPERATURE RANGE (B)                | PACKAGE (AA) |
|---------------|------------------------------|--------------------------------------|--------------|
| P80C31        | S = 16 MHz                   | B = 0° to +70°C                      | AA = PLCC    |
| P80C32        | U = 33 MHz                   | $F = -40^{\circ}C$ to $+85^{\circ}C$ | BB = PQFP    |
|               |                              |                                      | PN = PDIP    |

# **80C32 ORDERING INFORMATION**

| ROMIess     | TEMPERATURE RANGE °C<br>AND PACKAGE                | FREQ<br>MHz | DRAWING<br>NUMBER |
|-------------|----------------------------------------------------|-------------|-------------------|
| P80C32SBP N | 0 to +70, Plastic Dual In-line Package             | 16          | SOT129-1          |
| P80C32SBA A | 0 to +70, Plastic Leaded Chip Carrier              | 16          | SOT187-2          |
| P80C32SBB B | 0 to +70, Plastic Quad Flat Pack                   | 16          | SOT307-2          |
| P80C32SFP N | -40 to +85, Plastic Dual In-line Package           | 16          | SOT129-1          |
| P80C32SFA A | -40 to +85, Plastic Leaded Chip Carrier            | 16          | SOT187-2          |
| P80C32SFB B | -40 to +85, Plastic Quad Flat Pack                 | 16          | SOT307-2          |
| P80C32UBA A | 0 to +70, Plastic Leaded Chip Carrier              | 33          | SOT187-2          |
| P80C32UBP N | 0 to +70, Plastic Dual In-line Package             | 33          | SOT129-1          |
| P80C32UBB B | 0 to +70, Plastic Quad Flat Pack                   | 33          | SOT307-2          |
| P80C32UFA A | -40 to +85, Plastic Leaded Chip Carrier            | 33          | SOT187-2          |
| P80C32UFP N | -40 to +85, Plastic Dual In-line Package 33 SOT129 |             |                   |
| P80C32UFB B | -40 to +85, Plastic Quad Flat Pack                 | 33          | SOT307-2          |

80C31/80C32

## **PIN DESCRIPTIONS**

|                    | PIN NUMBER |              |               |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|------------|--------------|---------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MNEMONIC           | DIP        | LCC          | QFP           | TYPE | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| V <sub>SS</sub>    | 20         | 22           | 16            | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V <sub>CC</sub>    | 40         | 44           | 38            | I    | Power Supply: This is the power supply voltage for normal, idle, and power-down operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P0.0-0.7           | 39–32      | 43–36        | 37–30         | I/O  | <b>Port 0:</b> Port 0 is an open-drain, bidirectional I/O port with Schmitt trigger inputs. Port 0 pins that have 1s written to them float and can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external program and data memory. In this application, it uses strong internal pull-ups when emitting 1s.                                                                                                                                                                                                                                                                                                                                                                                                        |
| P1.0-P1.7          | 1–8        | 2–9          | 40–44,<br>1–3 | I/O  | <b>Port 1:</b> Port 1 is an 8-bit bidirectional I/O port with internal pull-ups and Schmitt trigger inputs. Port 1 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 1 pins that are externally pulled low will source current because of the internal pull-ups. (See DC Electrical Characteristics: I <sub>IL</sub> ). Alternate functions for Port 1 include:                                                                                                                                                                                                                                                                                                                                                    |
|                    | 1          | 2            | 40            | I/O  | T2 (P1.0): Timer/Counter 2 external count input/clockout (see Programmable Clock-Out)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | 2          | 3            | 41            | I    | T2EX (P1.1): Timer/Counter 2 Reload/Capture/Direction control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P2.0-P2.7          | 21–28      | 24–31        | 18–25         | I/O  | Port 2: Port 2 is an 8-bit bidirectional I/O port with internal pull-ups and Schmitt trigger inputs. Port 2 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 2 pins that are externally being pulled low will source current because of the internal pull-ups. (See DC Electrical Characteristics: I <sub>IL</sub> ). Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR). In this application, it uses strong internal pull-ups when emitting 1s. During accesses to external data memory that use 8-bit addresses (MOV @Ri), port 2 emits the contents of the P2 special function register. |
| P3.0-P3.7          | 10–17      | 11,<br>13–19 | 5,<br>7–13    | I/O  | <b>Port 3:</b> Port 3 is an 8-bit bidirectional I/O port with internal pull-ups and Schmitt trigger inputs. Port 3 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, port 3 pins that are externally being pulled low will source current because of the pull-ups. (See DC Electrical Characteristics: I <sub>IL</sub> ). Port 3 also serves the special features of the 80C51 family, as listed below:                                                                                                                                                                                                                                                                                                                 |
|                    | 10         | 11           | 5             | - 1  | RxD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | 11         | 13           | 7             | 0    | TxD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | 12         | 14           | 8             | I    | INTO (P3.2): External interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | 13         | 15           | 9             | !    | INT1 (P3.3): External interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | 14         | 16           | 10            |      | T0 (P3.4): Timer 0 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | 15<br>16   | 17<br>18     | 11<br>12      | 0    | T1 (P3.5): Timer 1 external input  WR (P3.6): External data memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | 17         | 19           | 13            | 0    | RD (P3.7): External data memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RST                | 9          | 10           | 4             | I    | <b>Reset:</b> A high on this pin for two machine cycles while the oscillator is running, resets the device. An internal diffused resistor to V <sub>SS</sub> permits a power-on reset using only an external capacitor to V <sub>CC</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ALE                | 30         | 33           | 27            | 0    | Address Latch Enable: Output pulse for latching the low byte of the address during an access to external memory. In normal operation, ALE is emitted at a constant rate of 1/6 the oscillator frequency, and can be used for external timing or clocking. Note that one ALE pulse is skipped during each access to external data memory. ALE can be disabled by setting SFR auxiliary.0. With this bit set, ALE will be active only during a MOVX instruction.                                                                                                                                                                                                                                                                                                                         |
| PSEN               | 29         | 32           | 26            | 0    | Program Store Enable: The read strobe to external program memory. When the 80C31/32 is executing code from the external program memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory. PSEN is not activated during fetches from internal program memory.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| EA/V <sub>PP</sub> | 31         | 35           | 29            | I    | External Access Enable/Programming Supply Voltage: EA must be externally held low to enable the device to fetch code from external program memory locations 0000H to 0FFFH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 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.



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



Figure 2. Timer 2 in Capture Mode

80C31/80C32



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 6. Timer 2 in Baud Rate Generator Mode

80C31/80C32

#### **Baud Rate Generator Mode**

Bits TCLK and/or RCLK in T2CON (Table 3) allow the serial port transmit and receive baud rates to be derived from either Timer 1 or Timer 2. When TCLK= 0, Timer 1 is used as the serial port transmit baud rate generator. When TCLK= 1, Timer 2 is used as the serial port transmit baud rate generator. RCLK has the same effect for the serial port receive baud rate. With these two bits, the serial port can have different receive and transmit baud rates – one generated by Timer 1, the other by Timer 2.

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

The baud rates in modes 1 and 3 are determined by Timer 2's overflow rate given below:

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

The timer can be configured for either "timer" or "counter" operation. In many applications, it is configured for "timer" operation (C/T2\*=0). Timer operation is different for Timer 2 when it is being used as a baud rate generator.

Usually, as a timer it would increment every machine cycle (i.e., 1/12 the oscillator frequency). As a baud rate generator, it increments every state time (i.e., 1/2 the oscillator frequency). Thus the baud rate formula is as follows:

Modes 1 and 3 Baud Rates =

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

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

The Timer 2 as a baud rate generator mode shown in Figure 6, is valid only if RCLK and/or TCLK = 1 in T2CON register. Note that a rollover in TH2 does not set TF2, and will not generate an interrupt. Thus, the Timer 2 interrupt does not have to be disabled when Timer 2 is in the baud rate generator mode. Also if the EXEN2 (T2 external enable flag) is set, a 1-to-0 transition in T2EX (Timer/counter 2 trigger input) will set EXF2 (T2 external flag) but will not cause a reload from (RCAP2H, RCAP2L) to (TH2,TL2). Therefore when Timer 2 is in use as a baud rate generator, T2EX can be used as an additional external interrupt, if needed.

When Timer 2 is in the baud rate generator mode, one should not try to read or write TH2 and TL2. As a baud rate generator, Timer 2 is incremented every state time (osc/2) or asynchronously from pin T2;

under these conditions, a read or write of TH2 or TL2 may not be accurate. The RCAP2 registers may be read, but should not be written to, because a write might overlap a reload and cause write and/or reload errors. The timer should be turned off (clear TR2) before accessing the Timer 2 or RCAP2 registers.

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

Table 4. Timer 2 Generated Commonly Used Baud Rates

| Baud Rate | Oce From | Timer 2 |        |  |  |
|-----------|----------|---------|--------|--|--|
| Baud Rate | Osc Freq | RCAP2H  | RCAP2L |  |  |
| 375 K     | 12 MHz   | FF      | FF     |  |  |
| 9.6 K     | 12 MHz   | FF      | D9     |  |  |
| 2.8 K     | 12 MHz   | FF      | B2     |  |  |
| 2.4 K     | 12 MHz   | FF      | 64     |  |  |
| 1.2 K     | 12 MHz   | FE      | C8     |  |  |
| 300       | 12 MHz   | FB      | 1E     |  |  |
| 110       | 12 MHz   | F2      | AF     |  |  |
| 300       | 6 MHz    | FD      | 8F     |  |  |
| 110       | 6 MHz    | F9      | 57     |  |  |

## **Summary Of Baud Rate Equations**

Timer 2 is in baud rate generating mode. If Timer 2 is being clocked through pin T2(P1.0) the baud rate is:

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

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

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

Where fosc= Oscillator Frequency

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

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

# Timer/Counter 2 Set-up

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

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32

Table 5. Timer 2 as a Timer

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

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

| MODE        | TMOD                      |                           |  |  |
|-------------|---------------------------|---------------------------|--|--|
| MODE        | INTERNAL CONTROL (Note 1) | EXTERNAL CONTROL (Note 2) |  |  |
| 16-bit      | 02H                       | 0AH                       |  |  |
| Auto-Reload | 03H                       | 0BH                       |  |  |

#### NOTES:

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

#### **Enhanced UART**

The UART operates in all of the usual modes that are described in the first section of *Data Handbook IC20, 80C51-Based 8-Bit Microcontrollers*. In addition the UART can perform framing error detect by looking for missing stop bits, and automatic address recognition. The 80C31/32 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 7). 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 8.

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

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 b 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 0000        |
|---------|-------|---|------------------|
|         | SADEN | = | <u>1111 1101</u> |
|         | Given | = | 1100 00X0        |
| Slave 1 | SADDR | = | 1100 0000        |
|         | SADEN | = | 1111 1110        |
|         | 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 | = | 1111 1001        |
|         | 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

80C31/80C32

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.

|                       | S                                                                                                                                                                                                                                                                                                                                                                                                             | CON Addr                                                                                                                                                                                                          | ess = 98H            |                    |             |                                     |                      |            | 1           | Reset Value = 0000 0000B                |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------|-------------|-------------------------------------|----------------------|------------|-------------|-----------------------------------------|
|                       | Bit Addressable                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                   |                      |                    |             |                                     |                      |            |             |                                         |
|                       |                                                                                                                                                                                                                                                                                                                                                                                                               | SM0/FE                                                                                                                                                                                                            | SM1                  | SM2                | REN         | TB8                                 | RB8                  | TI         | RI          |                                         |
|                       | Bit:                                                                                                                                                                                                                                                                                                                                                                                                          | 7<br>SMOD0 = 0                                                                                                                                                                                                    | 6<br>/1)*            | 5                  | 4           | 3                                   | 2                    | 1          | 0           |                                         |
| Symbol                | Func                                                                                                                                                                                                                                                                                                                                                                                                          | tion                                                                                                                                                                                                              |                      |                    |             |                                     |                      |            |             |                                         |
| FE                    |                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                   |                      |                    |             | hen an inva                         |                      |            |             | it is not cleared by valid<br>e FE bit. |
| SM0                   | Seria                                                                                                                                                                                                                                                                                                                                                                                                         | Port Mode                                                                                                                                                                                                         | Bit 0, (SM           | DD0 must           | = 0 to acce | ess bit SM0)                        |                      |            |             |                                         |
| SM1                   | Serial                                                                                                                                                                                                                                                                                                                                                                                                        | Port Mode<br>SM1                                                                                                                                                                                                  | Bit 1<br><b>Mode</b> | Descr              | iption      | Baud Rate                           | **                   |            |             |                                         |
|                       | 0                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                 | 0                    | shift re           | egister     | f <sub>OSC</sub> /12                |                      |            |             |                                         |
|                       | 0                                                                                                                                                                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                 | 1                    | 8-bit L            |             | variable                            |                      |            |             |                                         |
|                       | 1<br>1                                                                                                                                                                                                                                                                                                                                                                                                        | 0<br>1                                                                                                                                                                                                            | 2<br>3               | 9-bit L<br>9-bit L |             | f <sub>OSC</sub> /64 or<br>variable | f <sub>OSC</sub> /32 |            |             |                                         |
| SM2                   | Enables the Automatic Address Recognition feature in Modes 2 or 3. If SM2 = 1 then RI will not be set unless the received 9th data bit (RB8) is 1, indicating an address, and the received byte is a Given or Broadcast Address. In Mode 1, if SM2 = 1 then RI will not be activated unless a valid stop bit was received, and the received byte is a Given or Broadcast Address. In Mode 0, SM2 should be 0. |                                                                                                                                                                                                                   |                      |                    |             |                                     |                      |            |             |                                         |
| REN                   | Enab                                                                                                                                                                                                                                                                                                                                                                                                          | es serial re                                                                                                                                                                                                      | ception. Se          | t by softwa        | are to enab | le reception                        | Clear by s           | oftware to | disable red | ception.                                |
| TB8                   | The 9                                                                                                                                                                                                                                                                                                                                                                                                         | th data bit t                                                                                                                                                                                                     | hat will be          | transmitted        | l in Modes  | 2 and 3. Se                         | or clear by          | software a | as desired. |                                         |
| RB8                   | In modes 2 and 3, the 9th data bit that was received. In Mode 1, if SM2 = 0, RB8 is the stop bit that was received. In Mode 0, RB8 is not used.                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                   |                      |                    |             |                                     |                      |            |             |                                         |
| ТІ                    | Transmit interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or at the beginning of the stop bit in the other modes, in any serial transmission. Must be cleared by software.                                                                                                                                                                                                           |                                                                                                                                                                                                                   |                      |                    |             |                                     |                      |            |             |                                         |
| RI                    |                                                                                                                                                                                                                                                                                                                                                                                                               | Receive interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or halfway through the stop bit time in the other modes, in any serial reception (except see SM2). Must be cleared by software. |                      |                    |             |                                     |                      |            |             |                                         |
| TE:<br>IOD0 is locate | ed at PCON                                                                                                                                                                                                                                                                                                                                                                                                    | 6.                                                                                                                                                                                                                |                      |                    |             |                                     |                      |            |             | SU00043                                 |

Figure 7. SCON: Serial Port Control Register



Figure 8. UART Framing Error Detection



Figure 9. UART Multiprocessor Communication, Automatic Address Recognition

80C31/80C32

## **Interrupt Priority Structure**

The 80C31 and 80C32 have a 6-source four-level interrupt structure. They are the IE, IP and IPH. (See Figures 10, 11, and 12.) The IPH (Interrupt Priority High) register that makes the four-level interrupt structure possible. The IPH is located at SFR address B7H. The structure of the IPH register and a description of its bits is shown in Figure 12.

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

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

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 7. Interrupt Table

| SOURCE | POLLING PRIORITY | REQUEST BITS | HARDWARE CLEAR?                       | VECTOR ADDRESS |
|--------|------------------|--------------|---------------------------------------|----------------|
| X0     | 1                | IE0          | N (L) <sup>1</sup> Y (T) <sup>2</sup> | 03H            |
| T0     | 2                | TP0          | Υ                                     | 0BH            |
| X1     | 3                | IE1          | N (L) Y (T)                           | 13H            |
| T1     | 4                | TF1          | Υ                                     | 1BH            |
| SP     | 5                | RI, TI       | N                                     | 23H            |
| T2     | 6                | TF2, EXF2    | N                                     | 2BH            |

#### NOTES:

- 1. L = Level activated
- 2. T = Transition activated

|      |           | 7      | 6                          | 5                        | 4           | 3                    | 2   | 1   | 0         |
|------|-----------|--------|----------------------------|--------------------------|-------------|----------------------|-----|-----|-----------|
|      | IE (0A8H) | EA     | _                          | ET2                      | ES          | ET1                  | EX1 | ET0 | EX0       |
|      |           |        | Bit = 1 ena<br>Bit = 0 dis | ables the i<br>ables it. | nterrupt.   |                      |     |     |           |
| BIT  | SYMBOL    | FUNC   | TION                       |                          |             |                      |     |     |           |
| IE.7 | EA        |        |                            |                          |             | rupts are earing its |     |     | each inte |
| IE.6 | _         | Not im | plemente                   | d. Reserv                | ed for futu | re use.              |     |     |           |
| IE.5 | ET2       | Timer  | 2 interrup                 | t enable b               | it.         |                      |     |     |           |
| IE.4 | ES        | Serial | Port inter                 | upt enabl                | e bit.      |                      |     |     |           |
| IE.3 | ET1       | Timer  | 1 interrup                 | t enable b               | it.         |                      |     |     |           |
| IE.2 | EX1       | Extern | al interru                 | t 1 enable               | e bit.      |                      |     |     |           |
| IE.1 | ET0       | Timer  | 0 interrup                 | t enable b               | it.         |                      |     |     |           |
| IE.0 | EX0       | Extern | al interru                 | t 0 enable               | e bit.      |                      |     |     |           |

Figure 10. IE Registers

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32



Figure 11. IP Registers



Figure 12. IPH Registers

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32

#### **Reduced EMI Mode**

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

#### **Reduced EMI Mode**

# AUXR (8EH)



# **Dual DPTR**

The dual DPTR structure (see Figure 13) 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)



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

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32

# **ABSOLUTE MAXIMUM RATINGS**1, 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 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:

- 1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any conditions other than those described in the AC and DC Electrical Characteristics section of this specification is not implied.
- 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$ °C to +70°C or -40°C to +85°C

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

80C31/80C32

#### DC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0^{\circ}C$  to +70°C or -40°C to +85°C,  $V_{CC} = 2.7$  V to 5.5 V,  $V_{SS} = 0$  V (16 MHz devices)

|                  |                                                                                                                                               | TEST                                                                                                                    |                          | Τ                    |                          |                      |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------|--------------------------|----------------------|--|
| SYMBOL           | PARAMETER                                                                                                                                     | CONDITIONS                                                                                                              | MIN                      | TYP <sup>1</sup> MAX |                          | UNIT                 |  |
|                  | Land land to the second                                                                                                                       | 4.0 V < V <sub>CC</sub> < 5.5 V                                                                                         | -0.5                     |                      | 0.2 V <sub>CC</sub> -0.1 | V                    |  |
| $V_{IL}$         | Input low voltage                                                                                                                             | 2.7 V <v<sub>CC&lt; 4.0 V</v<sub>                                                                                       | -0.5                     |                      | 0.7                      | V                    |  |
| V <sub>IH</sub>  | Input high voltage (ports 0, 1, 2, 3, EA)                                                                                                     |                                                                                                                         | 0.2 V <sub>CC</sub> +0.9 |                      | V <sub>CC</sub> +0.5     | V                    |  |
| V <sub>IH1</sub> | Input high voltage, XTAL1, RST                                                                                                                |                                                                                                                         | 0.7 V <sub>CC</sub>      |                      | V <sub>CC</sub> +0.5     | V                    |  |
| V <sub>OL</sub>  | Output low voltage, ports 1, 2, 8                                                                                                             | $V_{CC} = 2.7 \text{ V}$ $I_{OL} = 1.6 \text{ mA}^2$                                                                    |                          |                      | 0.4                      | ٧                    |  |
| V <sub>OL1</sub> | Output low voltage, port 0, ALE, PSEN8, 7                                                                                                     | $V_{CC} = 2.7 \text{ V}$ $I_{OL} = 3.2 \text{ mA}^2$                                                                    |                          |                      | 0.4                      | ٧                    |  |
|                  | Outside in the control of 0.03                                                                                                                | V <sub>CC</sub> = 2.7 V<br>I <sub>OH</sub> = -20 μA                                                                     | V <sub>CC</sub> - 0.7    |                      |                          | V                    |  |
| V <sub>OH</sub>  | Output high voltage, ports 1, 2, 3 <sup>3</sup>                                                                                               | V <sub>CC</sub> = 4.5 V<br>I <sub>OH</sub> = -30 μA                                                                     | V <sub>CC</sub> - 0.7    |                      |                          | V                    |  |
| V <sub>OH1</sub> | Output high voltage (port 0 in external bus mode), ALE <sup>9</sup> , PSEN <sup>3</sup>                                                       | $V_{CC} = 2.7 \text{ V}$ $I_{OH} = -3.2 \text{ mA}$                                                                     | V <sub>CC</sub> - 0.7    |                      |                          | V                    |  |
| I <sub>IL</sub>  | Logical 0 input current, ports 1, 2, 3                                                                                                        | V <sub>IN</sub> = 0.4 V                                                                                                 | -1                       |                      | -50                      | μΑ                   |  |
| I <sub>TL</sub>  | Logical 1-to-0 transition current, ports 1, 2, 3 <sup>6</sup>                                                                                 | V <sub>IN</sub> = 2.0 V<br>See note 4                                                                                   |                          |                      | -650                     | μА                   |  |
| ILI              | Input leakage current, port 0                                                                                                                 | $0.45 < V_{IN} < V_{CC} - 0.3$                                                                                          |                          |                      | ±10                      | μΑ                   |  |
| Icc              | Power supply current (see Figure 21): Active mode @ 16 MHz Idle mode @ 16 MHz Power-down mode or clock stopped (see Figure 25 for conditions) | See note 5 $T_{amb} = 0^{\circ}\text{C to } 70^{\circ}\text{C}$ $T_{amb} = -40^{\circ}\text{C to } +85^{\circ}\text{C}$ |                          | 3                    | 50<br>75                 | μΑ<br>μΑ<br>μΑ<br>μΑ |  |
| R <sub>RST</sub> | Internal reset pull-down resistor                                                                                                             |                                                                                                                         | 40                       |                      | 225                      | kΩ                   |  |
| C <sub>IO</sub>  | Pin capacitance <sup>10</sup> (except EA)                                                                                                     |                                                                                                                         |                          |                      | 15                       | pF                   |  |

## NOTES:

- 1. Typical ratings are not guaranteed. The values listed are at room temperature, 5 V.
- Capacitive loading on ports 0 and 2 may cause spurious noise to be superimposed on the Vols of ALE and ports 1 and 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100 pF), the noise pulse on the ALE pin may exceed 0.8 V. In such cases, it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input. IoL can exceed these conditions provided that no single output sinks more than 5 mA and no more than two outputs exceed the test conditions
- 3. Capacitive loading on ports 0 and 2 may cause the  $V_{OH}$  on ALE and  $\overline{PSEN}$  to momentarily fall below the  $V_{CC}$ -0.7 specification when the address bits are stabilizing.
- Pins of ports 1, 2 and 3 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when V<sub>IN</sub> is approximately 2 V.
- See Figures 22 through 25 for I<sub>CC</sub> test conditions.

 $I_{CC} = 0.9 \times FREQ. + 1.1 \text{ mA}$ 

- Idle mode:  $I_{CC} = 0.18 \times FREQ. +1.01$  mA; See Figure 21. 6. This value applies to  $T_{amb} = 0^{\circ}C$  to  $+70^{\circ}C$ . For  $T_{amb} = -40^{\circ}C$  to  $+85^{\circ}C$ ,  $I_{TL} = -750$   $\mu$ A.
- Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.
- 8. Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows: Maximum I<sub>OL</sub> per port pin: 15 mA (\*NOTE: This is 85°C specification.)

Maximum I<sub>OL</sub> per 8-bit port: 26 mA Maximum total I<sub>OL</sub> for all outputs: 71 mA

If  $I_{OL}$  exceeds the test condition,  $V_{OL}$  may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions.

- 9. ALE is tested to V<sub>OH1</sub>, except when ALE is off then V<sub>OH</sub> is the voltage specification.
- 10. Pin capacitance is characterized but not tested. Pin capacitance is less than 25 pF.

2000 Aug 07

80C31/80C32

#### DC ELECTRICAL CHARACTERISTICS

 $T_{amb} = 0$ °C to +70°C or -40°C to +85°C, 33 MHz devices; 5 V ±10%;  $V_{SS} = 0$  V

| 0)/440-01        | 24244555                                                                                | TEST                                                                                                |                          |                  |                          |          |  |
|------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------|------------------|--------------------------|----------|--|
| SYMBOL           | PARAMETER                                                                               | CONDITIONS                                                                                          | MIN                      | TYP <sup>1</sup> | MAX                      | UNIT     |  |
| V <sub>IL</sub>  | Input low voltage                                                                       | 4.5 V < V <sub>CC</sub> < 5.5 V                                                                     | -0.5                     |                  | 0.2 V <sub>CC</sub> -0.1 | V        |  |
| V <sub>IH</sub>  | Input high voltage (ports 0, 1, 2, 3, EA)                                               |                                                                                                     | 0.2 V <sub>CC</sub> +0.9 |                  | V <sub>CC</sub> +0.5     | V        |  |
| V <sub>IH1</sub> | Input high voltage, XTAL1, RST                                                          |                                                                                                     | 0.7 V <sub>CC</sub>      |                  | V <sub>CC</sub> +0.5     | V        |  |
| V <sub>OL</sub>  | Output low voltage, ports 1, 2, 3 8                                                     | $V_{CC} = 4.5 \text{ V}$ $I_{OL} = 1.6 \text{mA}^2$                                                 |                          |                  | 0.4                      | V        |  |
| V <sub>OL1</sub> | Output low voltage, port 0, ALE, PSEN 7, 8                                              | $V_{CC} = 4.5 \text{ V}$ $I_{OL} = 3.2 \text{mA}^2$                                                 |                          |                  | 0.4                      | V        |  |
| V <sub>OH</sub>  | Output high voltage, ports 1, 2, 3 <sup>3</sup>                                         | $V_{CC} = 4.5 \text{ V}$ $I_{OH} = -30\mu\text{A}$                                                  | V <sub>CC</sub> - 0.7    |                  |                          | V        |  |
| V <sub>OH1</sub> | Output high voltage (port 0 in external bus mode), ALE <sup>9</sup> , PSEN <sup>3</sup> | $V_{CC} = 4.5 \text{ V}$ $I_{OH} = -3.2 \text{mA}$                                                  | V <sub>CC</sub> - 0.7    |                  |                          | V        |  |
| I <sub>IL</sub>  | Logical 0 input current, ports 1, 2, 3                                                  | V <sub>IN</sub> = 0.4 V                                                                             | -1                       |                  | -50                      | μΑ       |  |
| I <sub>TL</sub>  | Logical 1-to-0 transition current, ports 1, 2, 3 <sup>6</sup>                           | V <sub>IN</sub> = 2.0 V<br>See note 4                                                               |                          |                  | -650                     | μА       |  |
| ILI              | Input leakage current, port 0                                                           | $0.45 < V_{IN} < V_{CC} - 0.3$                                                                      |                          |                  | ±10                      | μΑ       |  |
| I <sub>CC</sub>  | Power supply current (see Figure 21): Active mode (see Note 5) Idle mode (see Note 5)   | See note 5                                                                                          |                          |                  | 50                       |          |  |
|                  | Power-down mode or clock stopped (see Fig-<br>ure 25 for conditions)                    | $T_{amb} = 0^{\circ}C \text{ to } 70^{\circ}C$<br>$T_{amb} = -40^{\circ}C \text{ to } +85^{\circ}C$ |                          | 3                | 50<br>75                 | μA<br>μA |  |
| R <sub>RST</sub> | Internal reset pull-down resistor                                                       |                                                                                                     | 40                       |                  | 225                      | kΩ       |  |
| C <sub>IO</sub>  | Pin capacitance <sup>10</sup> (except EA)                                               |                                                                                                     |                          |                  | 15                       | pF       |  |

### NOTES:

- 1. Typical ratings are not guaranteed. The values listed are at room temperature, 5 V.
- Capacitive loading on ports 0 and 2 may cause spurious noise to be superimposed on the VOLs of ALE and ports 1 and 3. The noise is due to external bus capacitance discharging into the port 0 and port 2 pins when these pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100 pF), the noise pulse on the ALE pin may exceed 0.8 V. In such cases, it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input. IOL can exceed these conditions provided that no single output sinks more than 5mA and no more than two outputs exceed the test conditions.
- 3. Capacitive loading on ports 0 and 2 may cause the  $V_{OH}$  on ALE and PSEN to momentarily fall below the  $V_{CC}$ -0.7 specification when the address bits are stabilizing.
- Pins of ports 1, 2 and 3 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when  $V_{\mbox{\scriptsize IN}}$  is approximately 2 V.
- 5. See Figures 22 through 25 for I<sub>CC</sub> test conditions.

- Active mode:  $I_{CC(MAX)} = 0.9 \times FREQ. + 1.1 \text{ mA}$ Idle mode:  $I_{CC(MAX)} = 0.18 \times FREQ. + 1.0 \text{ mA}$ ; See Figure 21. 6. This value applies to  $I_{amb} = 0^{\circ}C$  to  $+70^{\circ}C$ . For  $I_{amb} = -40^{\circ}C$  to  $+85^{\circ}C$ ,  $I_{TL} = -750 \mu A$ .
- Load capacitance for port 0, ALE, and  $\overline{PSEN} = 100 \text{ pF}$ , load capacitance for all other outputs = 80 pF.
- 8. Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows: Maximum IOL per port pin: 15 mA (\*NOTE: This is 85°C specification.)

Maximum I<sub>OL</sub> per 8-bit port: 26 mA

Maximum total I<sub>OL</sub> for all outputs: 71 mA

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

- ALE is tested to  $V_{OH1}$ , except when ALE is off then  $V_{OH}$  is the voltage specification.
- 10. Pin capacitance is characterized but not tested. Pin capacitance is less than 25 pF. Pin capacitance of ceramic package is less than 15 pF (except EA is 25 pF).

22 2000 Aug 07

80C31/80C32

## **AC ELECTRICAL CHARACTERISTICS**

 $T_{amb} = 0$ °C to +70°C or -40°C to +85°C,  $V_{CC} = +2.7$  V to +5.5 V,  $V_{SS} = 0$  V<sup>1, 2, 3</sup>

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

- Parameters are valid over operating temperature range unless otherwise specified.
   Load capacitance for port 0, ALE, and PSEN = 100 pF, load capacitance for all other outputs = 80 pF.
- 3. Interfacing the 80C31 and 80C32 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 0 Hz. When an external clock source is used, the RST pin should be held high for a minimum of 20 µs for power-on or wakeup from power down.

2000 Aug 07 23

80C31/80C32

## **AC ELECTRICAL CHARACTERISTICS**

 $T_{amb}$  = 0°C to +70°C or -40°C to +85°C,  $V_{CC}$  = 5 V ±10%,  $V_{SS}$  = 0 V<sup>1, 2, 3</sup>

|                                |        |                                                                                  |                                                 | E CLOCK <sup>4</sup>                 |                                                  |       |      |
|--------------------------------|--------|----------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------------|--------------------------------------------------|-------|------|
|                                |        |                                                                                  |                                                 | to f <sub>max</sub>                  | _                                                | CLOCK | ┨    |
| SYMBOL                         | FIGURE | PARAMETER                                                                        | MIN                                             | MAX                                  | MIN                                              | MAX   | UNIT |
| t <sub>LHLL</sub>              | 14     | ALE pulse width                                                                  | 2t <sub>CLCL</sub> -40                          |                                      | 21                                               |       | ns   |
| t <sub>AVLL</sub>              | 14     | Address valid to ALE low                                                         | t <sub>CLCL</sub> -25                           |                                      | 5                                                |       | ns   |
| t <sub>LLAX</sub>              | 14     | Address hold after ALE low                                                       | t <sub>CLCL</sub> -25                           |                                      |                                                  |       | ns   |
| $t_{LLIV}$                     | 14     | ALE low to valid instruction in                                                  |                                                 | 4t <sub>CLCL</sub> -65               |                                                  | 55    | ns   |
| t <sub>LLPL</sub>              | 14     | ALE low to PSEN low                                                              | t <sub>CLCL</sub> -25                           |                                      | 5                                                |       | ns   |
| t <sub>PLPH</sub>              | 14     | PSEN pulse width                                                                 | 3t <sub>CLCL</sub> -45                          |                                      | 45                                               |       | ns   |
| t <sub>PLIV</sub>              | 14     | PSEN low to valid instruction in                                                 |                                                 | 3t <sub>CLCL</sub> -60               |                                                  | 30    | ns   |
| t <sub>PXIX</sub>              | 14     | Input instruction hold after PSEN                                                | 0                                               |                                      | 0                                                |       | ns   |
| t <sub>PXIZ</sub>              | 14     | Input instruction float after PSEN                                               |                                                 | t <sub>CLCL</sub> -25                |                                                  | 5     | ns   |
| t <sub>AVIV</sub>              | 14     | Address to valid instruction in                                                  |                                                 | 5t <sub>CLCL</sub> -80               |                                                  | 70    | ns   |
| t <sub>PLAZ</sub>              | 14     | PSEN low to address float                                                        |                                                 | 10                                   |                                                  | 10    | ns   |
| Data Memoi                     | ry     |                                                                                  | •                                               |                                      | •                                                |       |      |
| t <sub>RLRH</sub>              | 15, 16 | RD pulse width                                                                   | 6t <sub>CLCL</sub> -100                         |                                      | 82                                               |       | ns   |
| t <sub>WLWH</sub>              | 15, 16 | WR pulse width                                                                   | 6t <sub>CLCL</sub> -100                         |                                      | 82                                               |       | ns   |
| t <sub>RLDV</sub>              | 15, 16 | RD low to valid data in                                                          |                                                 | 5t <sub>CLCL</sub> -90               |                                                  | 60    | ns   |
| t <sub>RHDX</sub>              | 15, 16 | Data hold after RD                                                               | 0                                               |                                      | 0                                                |       | ns   |
| t <sub>RHDZ</sub>              | 15, 16 | Data float after RD                                                              |                                                 | 2t <sub>CLCL</sub> -28               |                                                  | 32    | ns   |
| t <sub>LLDV</sub>              | 15, 16 | ALE low to valid data in                                                         |                                                 | 8t <sub>CLCL</sub> -150              |                                                  | 90    | ns   |
| t <sub>AVDV</sub>              | 15, 16 | Address to valid data in                                                         |                                                 | 9t <sub>CLCL</sub> -165              |                                                  | 105   | ns   |
| t <sub>LLWL</sub>              | 15, 16 | ALE low to RD or WR low                                                          | 3t <sub>CLCL</sub> -50                          | 3t <sub>CLCL</sub> +50               | 40                                               | 140   | ns   |
| t <sub>AVWL</sub>              | 15, 16 | Address valid to WR low or RD low                                                | 4t <sub>CLCL</sub> -75                          | OLOL                                 | 45                                               |       | ns   |
| t <sub>QVWX</sub>              | 15, 16 | Data valid to WR transition                                                      | t <sub>CLCL</sub> -30                           |                                      | 0                                                |       | ns   |
| twhQX                          | 15, 16 | Data hold after WR                                                               | t <sub>CLCL</sub> -25                           |                                      | 5                                                |       | ns   |
| t <sub>QVWH</sub>              | 16     | Data valid to WR high                                                            | 7t <sub>CLCL</sub> -130                         |                                      | 80                                               |       | ns   |
| t <sub>RLAZ</sub>              | 15, 16 | RD low to address float                                                          | T CLCL TO                                       | 0                                    |                                                  | 0     | ns   |
| twhlh                          | 15, 16 | RD or WR high to ALE high                                                        | t <sub>CLCL</sub> -25                           | t <sub>CLCL</sub> +25                | 5                                                | 55    | ns   |
| External Clo                   |        | THE OF THE HIGH                                                                  | CLCL 20                                         | ICLCL 120                            |                                                  |       | 1.0  |
|                                | 18     | High time                                                                        | 0.38t <sub>CLCL</sub>                           | t <sub>CLCL</sub> -t <sub>CLCX</sub> |                                                  | l     | ns   |
| t <sub>CHCX</sub>              | 18     | Low time                                                                         | 0.38t <sub>CLCL</sub>                           | i e                                  |                                                  |       | ns   |
| toLCX                          | 18     | Rise time                                                                        | 0.00tGLGL                                       | tclcl-tchcx<br>5                     | <del>                                     </del> |       | ns   |
| touch                          | 18     | Fall time                                                                        | +                                               | 5                                    | <del>                                     </del> |       | ns   |
| t <sub>CHCL</sub> Shift Regist |        | i an ariic                                                                       |                                                 | <u> </u>                             |                                                  |       | 113  |
|                                | 17     | Serial port clock cycle time                                                     | 12to. o.                                        |                                      | 360                                              | ĺ     | ns   |
| tangu                          | 17     | Output data setup to clock rising edge                                           | 12t <sub>CLCL</sub><br>10t <sub>CLCL</sub> -133 |                                      | 167                                              |       | +    |
| t <sub>QVXH</sub>              | 17     | Output data setup to clock rising edge  Output data hold after clock rising edge | _                                               |                                      | 107                                              |       | ns   |
| t <sub>XHQX</sub>              |        |                                                                                  | 2t <sub>CLCL</sub> -80                          |                                      |                                                  |       | ns   |
| t <sub>XHDX</sub>              | 17     | Input data hold after clock rising edge                                          | 0                                               | 404 400                              | 0                                                | 407   | ns   |
| t <sub>XHDV</sub>              | 17     | Clock rising edge to input data valid                                            |                                                 | 10t <sub>CLCL</sub> -133             |                                                  | 167   | ns   |

### NOTES:

- 1. Parameters are valid over operating temperature range unless otherwise specified.
- 2. Load capacitance for port 0, ALE, and  $\overline{PSEN} = 100 \, pF$ , load capacitance for all other outputs = 80 pF.
- 3. Interfacing the 80C31 and 80C32 to devices with float times up to 45ns is permitted. This limited bus contention will not cause damage to Port 0 drivers.
- 4. Variable clock is specified for oscillator frequencies greater than 16 MHz to 33 MHz. For frequencies equal or less than 16 MHz, see 16 MHz "AC Electrical Characteristics", page 23.
- 5. Parts are guaranteed to operate down to 0 Hz. When an external clock source is used, the RST pin should be held high for a minimum of 20 μs for power-on or wakeup from power down.



Figure 16. External Data Memory Write Cycle



Figure 17. Shift Register Mode Timing



Figure 18. External Clock Drive

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32



Figure 19. AC Testing Input/Output



Figure 20. Float Waveform



 $\label{eq:continuous} \mbox{Figure 21. I}_{\mbox{CC}} \mbox{ vs. FREQ} \\ \mbox{Valid only within frequency specifications of the device under test}$ 

80C51 8-bit microcontroller family 128/256 byte RAM ROMless low voltage (2.7V–5.5V), low power, high speed (33 MHz)

80C31/80C32

#### Data sheet status

| Data sheet status         | Product status | Definition [1]                                                                                                                                                                                                                                             |
|---------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Objective specification   | Development    | This data sheet contains the design target or goal specifications for product development. Specification may change in any manner without notice.                                                                                                          |
| Preliminary specification | Qualification  | This data sheet contains preliminary data, and supplementary data will be published at a later date. Philips Semiconductors reserves the right to make changes at any time without notice in order to improve design and supply the best possible product. |
| Product specification     | Production     | This data sheet contains final specifications. Philips Semiconductors reserves the right to make changes at any time without notice in order to improve design and supply the best possible product.                                                       |

<sup>[1]</sup> Please consult the most recently issued datasheet before initiating or completing a design.

#### **Definitions**

**Short-form specification** — The data in a short-form specification is extracted from a full data sheet with the same type number and title. For detailed information see the relevant data sheet or data handbook.

Limiting values definition — Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability.

**Application information** — Applications that are described herein for any of these products are for illustrative purposes only. Philips Semiconductors make no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

#### **Disclaimers**

**Life support** — These products are not designed for use in life support appliances, devices or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips Semiconductors customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips Semiconductors for any damages resulting from such application.

Right to make changes — Philips Semiconductors reserves the right to make changes, without notice, in the products, including circuits, standard cells, and/or software, described or contained herein in order to improve design and/or performance. Philips Semiconductors assumes no responsibility or liability for the use of any of these products, conveys no license or title under any patent, copyright, or mask work right to these products, and makes no representations or warranties that these products are free from patent, copyright, or mask work right infringement, unless otherwise specified.

Philips Semiconductors 811 East Arques Avenue P.O. Box 3409 Sunnyvale, California 94088–3409 Telephone 800-234-7381 © Copyright Philips Electronics North America Corporation 2000 All rights reserved. Printed in U.S.A.

Date of release: 08-00

Document order number: 9397 750 07403

Let's make things better.

Philips Semiconductors



