# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | 80C51                                                                   |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 40/20MHz                                                                |
| 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) | 4.5V ~ 5.5V                                                             |
| Data Converters            | -                                                                       |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 44-QFP                                                                  |
| Supplier Device Package    | 44-VQFP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/ts80c31x2-mce |
|                            |                                                                         |

Email: info@E-XFL.COM

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



## 5. Pin Configuration



\*NIC: No Internal Connection



| Table 2. | Pin | Description | for | 40/44 | pin | packages |
|----------|-----|-------------|-----|-------|-----|----------|
|----------|-----|-------------|-----|-------|-----|----------|

|                 | PIN NUMBER |              |              |       | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|-----------------|------------|--------------|--------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MNEMONIC        | DIL        | LCC          | VQFP 1.4     | TYPE  | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| V <sub>SS</sub> | 20         | 22           | 16           | I     | Ground: 0V reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| Vss1            |            | 1            | 39           | Ι     | Optional Ground: Contact the Sales Office for ground connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| V <sub>CC</sub> | 40         | 44           | 38           | Ι     | <b>Power Supply:</b> This is the power supply voltage for normal, idle and power-<br>down operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| P0.0-P0.7       | 39-32      | 43-36        | 37-30        | I/O   | <b>Port 0</b> : Port 0 is an open-drain, bidirectional I/O port. Port 0 pins that have 1s written to them float and can be used as high impedance inputs. Port 0 pins must be polarized to Vcc or Vss in order to prevent any parasitic current consumption. Port 0 is also the multiplexed low-order address and data bus during access to external program and data memory. In this application, it uses strong internal pull-up 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. 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.                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| P2.0-P2.7       | 21-28      | 24-31        | 18-25        | I/O   | <b>Port 2</b> : Port 2 is an 8-bit bidirectional I/O port with internal pull-ups. 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 pulled low will source current because of the internal pull-ups. 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 emitting 1s. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 emits the contents of the P2 SFR. |  |  |  |
| 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. 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 pulled low will source current because of the internal pull-ups. Port 3 also serves the special features of the 80C51 family, as listed below.                                                                                                                                                                                                                                                                                     |  |  |  |
|                 | 10         | 11           | 5            | I     | RXD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|                 | 11         | 13           | 7            | 0     | TXD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                 | 12         | 14           | 8            | I     | <b>INTO</b> (P3.2): External interrupt 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | 13         | 15           | 9            | I     | <b>INT1</b> (P3.3): External interrupt 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | 14         | 16           | 10           | I     | T0 (P3.4): Timer 0 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                 | 15         | 17           | 11           | I     | T1 (P3.5): Timer 1 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                 | 16         | 18           | 12           | 0     | WR (P3.6): External data memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                 | 17         | 19           | 13           | 0     | <b>RD</b> (P3.7): External data memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| Reset           | 9          | 10           | 4            | Ι     | <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_{SS}$ permits a power-on reset using only an external capacitor to $V_{CC}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| ALE             | 30         | 33           | 27           | (I) O | 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 (1/3 in X2 mode) 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.                                                                                                                                                                                                                                                                                                                   |  |  |  |
| PSEN            | 29         | 32           | 26           | 0     | <b>Program Store ENable:</b> The read strobe to external program memory. When executing code from the external program memory, <b>PSEN</b> is activated twice each machine cycle, except that two <b>PSEN</b> activations are skipped during each access to external data memory. <b>PSEN</b> is not activated during fetches from internal program memory.                                                                                                                                                                                                                                                                                                                 |  |  |  |
| ĒĀ              | 31         | 35           | 29           | Ι     | <b>External Access Enable:</b> $\overline{EA}$ must be externally held low to enable the device to fetch code from external program memory locations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| XTAL1           | 19         | 21           | 15           | I     | <b>Crystal 1:</b> 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |



## 6. TS80C31X2 Enhanced Features

In comparison to the original 80C31, the TS80C31X2 implements some new features, which are:

- The X2 option.
- The Dual Data Pointer.
- The 4 level interrupt priority system.
- The power-off flag.
- The ONCE mode.
- Enhanced UART

## 6.1 X2 Feature

The TS80C31X2 core needs only 6 clock periods per machine cycle. This feature called "X2" provides the following advantages:

- Divide frequency crystals by 2 (cheaper crystals) while keeping same CPU power.
- Save power consumption while keeping same CPU power (oscillator power saving).
- Save power consumption by dividing dynamically operating frequency by 2 in operating and idle modes.
- Increase CPU power by 2 while keeping same crystal frequency.

In order to keep the original C51 compatibility, a divider by 2 is inserted between the XTAL1 signal and the main clock input of the core (phase generator). This divider may be disabled by software.

### 6.1.1 Description

The clock for the whole circuit and peripheral is first divided by two before being used by the CPU core and peripherals. This allows any cyclic ratio to be accepted on XTAL1 input. In X2 mode, as this divider is bypassed, the signals on XTAL1 must have a cyclic ratio between 40 to 60%. Figure 1. shows the clock generation block diagram. X2 bit is validated on XTAL1+2 rising edge to avoid glitches when switching from X2 to STD mode. Figure 2. shows the mode switching waveforms.







### Table 3. CKCON Register

#### CKCON - Clock Control Register (8Fh)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
|---|---|---|---|---|---|---|----|
| - | - | - | - | - | - | - | X2 |

| Bit<br>Number | Bit<br>Mnemonic | Description                                                                                                                                                                                                     |
|---------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 6             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 5             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 4             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 3             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 2             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 1             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                 |
| 0             | X2              | <b>CPU and peripheral clock bit</b><br>Clear to select 12 clock periods per machine cycle (STD mode, $F_{OSC}=F_{XTAL}/2$ ).<br>Set to select 6 clock periods per machine cycle (X2 mode, $F_{OSC}=F_{XTAL}$ ). |

Reset Value = XXXX XXX0b Not bit addressable

For further details on the X2 feature, please refer to ANM072 available on the web (http://www.atmel-wm.com)



#### 6.3.5 Reset Addresses

On reset, the SADDR and SADEN registers are initialized to 00h, i.e. the given and broadcast addresses are XXXX (all don't-care bits). This ensures that the serial port will reply to any address, and so, that it is backwards compatible with the 80C51 microcontrollers that do not support automatic address recognition.

#### SADEN - Slave Address Mask Register (B9h)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |

Reset Value = 0000 0000b Not bit addressable

#### SADDR - Slave Address Register (A9h)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |

Reset Value = 0000 0000b Not bit addressable



## Table 5. SCON Register

#### SCON - Serial Control Register (98h)

| 7             | 6               | 5                                                 |                                                                                                                               | 4                                                              | 3                                                                            | 2                                                                 | 1                                                                | 0                  |  |  |  |  |  |
|---------------|-----------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------------------------|--------------------|--|--|--|--|--|
| FE/SM0        | SM1             | SM                                                | 2                                                                                                                             | REN                                                            | TB8                                                                          | RB8                                                               | TI                                                               | RI                 |  |  |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic |                                                   | Description                                                                                                                   |                                                                |                                                                              |                                                                   |                                                                  |                    |  |  |  |  |  |
| 7             | FE              | Set by ha                                         | reset the err<br>rdware whe                                                                                                   | or state, not cle<br>en an invalid st                          | eared by a valid sto<br>op bit is detected.<br>ss to the FE bit              | op bit.                                                           |                                                                  |                    |  |  |  |  |  |
|               | SM0             | Refer to                                          | rial port Mode bit 0<br>Refer to SM1 for serial port mode selection.<br>SMOD0 must be cleared to enable access to the SM0 bit |                                                                |                                                                              |                                                                   |                                                                  |                    |  |  |  |  |  |
|               |                 | Serial port M                                     | fode bit 1<br>SM1                                                                                                             | Mada                                                           | Decorinti                                                                    | on Baud Rat                                                       |                                                                  |                    |  |  |  |  |  |
| 6             | SM1             | 0<br>0<br>1<br>1                                  | 0<br>1<br>0<br>1                                                                                                              | <u>Mode</u><br>0<br>1<br>2<br>3                                | Descripti<br>Shift Reg<br>8-bit UA<br>9-bit UA<br>9-bit UA                   | ister F <sub>XTAL</sub> /<br>RT Variabl<br>RT F <sub>XTAL</sub> / | –<br>12 (/6 in X2 mode)<br>e<br>64 or F <sub>XTAL</sub> /32 (/32 |                    |  |  |  |  |  |
| 5             | SM2             | Clear to o<br>Set to ena                          | disable mult                                                                                                                  | tiprocessor con<br>ocessor comm                                | cessor Communic<br>nmunication featur<br>unication feature in                | re.                                                               | d eventually mode                                                | 1. This bit should |  |  |  |  |  |
| 4             | REN             |                                                   |                                                                                                                               | al reception.                                                  |                                                                              |                                                                   |                                                                  |                    |  |  |  |  |  |
| 3             | TB8             | Clear to t                                        | ransmit a lo                                                                                                                  | <b>h bit to trans</b><br>ogic 0 in the 9t<br>ic 1 in the 9th l | <b>mit in modes 2 an</b><br>h bit.<br>pit.                                   | d 3.                                                              |                                                                  |                    |  |  |  |  |  |
| 2             | RB8             | Cleared b<br>Set by ha                            | y hardware<br>rdware if 9                                                                                                     | if 9th bit receith bit receith                                 | modes 2 and 3<br>ived is a logic 0.<br>is a logic 1.<br>received stop bit. I | n mode 0 RB8 is 1                                                 | not used.                                                        |                    |  |  |  |  |  |
| 1             | TI              | Transmit Int<br>Clear to a<br>Set by ha<br>modes. | acknowledg                                                                                                                    | e interrupt.                                                   | th bit time in mode                                                          | e 0 or at the begin                                               | ning of the stop bit                                             | in the other       |  |  |  |  |  |
| 0             | RI              |                                                   | acknowledg                                                                                                                    |                                                                | th bit time in mode                                                          | e 0, see Figure 5.                                                | and Figure 6. in the                                             | e other modes.     |  |  |  |  |  |

Reset Value = 0000 0000b Bit addressable



#### IP - Interrupt Priority Register (B8h)

| 7             | 6               | 5                                       | 4                                                                                   | 3   | 2   | 1   | 0   |  |  |  |  |
|---------------|-----------------|-----------------------------------------|-------------------------------------------------------------------------------------|-----|-----|-----|-----|--|--|--|--|
| -             | -               | -                                       | PS                                                                                  | PT1 | PX1 | РТО | PX0 |  |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic |                                         | Description                                                                         |     |     |     |     |  |  |  |  |
| 7             | -               | Reserved<br>The value read t            | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.     |     |     |     |     |  |  |  |  |
| 6             | -               | Reserved<br>The value read t            | eserved<br>The value read from this bit is indeterminate. Do not set this bit.      |     |     |     |     |  |  |  |  |
| 5             | -               | Reserved<br>The value read t            | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.     |     |     |     |     |  |  |  |  |
| 4             | PS              | Serial port Priority<br>Refer to PSH fo |                                                                                     |     |     |     |     |  |  |  |  |
| 3             | PT1             | Timer 1 overflow in<br>Refer to PT1H f  | nterrupt Priority I<br>for priority level.                                          | bit |     |     |     |  |  |  |  |
| 2             | PX1             | External interrupt<br>Refer to PX1H     | 1 Priority bit<br>for priority level.                                               |     |     |     |     |  |  |  |  |
| 1             | PT0             |                                         | <b>Timer 0 overflow interrupt Priority bit</b><br>Refer to PT0H for priority level. |     |     |     |     |  |  |  |  |
| 0             | PX0             |                                         | External interrupt 0 Priority bit<br>Refer to PX0H for priority level.              |     |     |     |     |  |  |  |  |

Reset Value = XXX0 0000b Bit addressable



#### Table 10. IPH Register

#### IPH - Interrupt Priority High Register (B7h)

| 7 | 6 | 5 | 4   | 3    | 2    | 1    | 0    |
|---|---|---|-----|------|------|------|------|
| - | - | - | PSH | PT1H | PX1H | РТОН | РХОН |

| Bit<br>Number | Bit<br>Mnemonic |                                                                        |                                                                                 | Description                                                    |      |  |  |  |  |  |
|---------------|-----------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------|------|--|--|--|--|--|
| 7             | -               | Reserved<br>The value read f                                           | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                                                |      |  |  |  |  |  |
| 6             | -               | Reserved<br>The value read f                                           | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                                                |      |  |  |  |  |  |
| 5             | -               | Reserved<br>The value read f                                           | rom this bit is inde                                                            | terminate. Do not set this                                     | bit. |  |  |  |  |  |
| 4             | PSH             | Serial port Priority<br><u>PSH</u><br>0<br>1<br>1<br>1                 | High bit           PS           0           1           0           1           | <u>Priority Level</u><br>Lowest<br>Highest                     |      |  |  |  |  |  |
| 3             | PT1H            | Timer 1 overflow in           PT1H           0           1           1 | <b>iterrupt Priority I</b><br><u>PT1</u><br>0<br>1<br>0<br>1                    | <b>Jigh bit</b><br><u>Priority Level</u><br>Lowest<br>Highest  |      |  |  |  |  |  |
| 2             | PX1H            | <b>External interrupt</b><br><u>PX1H</u><br>0<br>0<br>1<br>1           | 1 Priority High bi<br><u>PX1</u><br>0<br>1<br>0<br>1<br>1                       | t<br><u>Priority Level</u><br>Lowest<br>Highest                |      |  |  |  |  |  |
| 1             | РТОН            | Timer 0 overflow in <u>PT0H</u> 0           1           1              | tterrupt Priority I<br><u>PTO</u><br>0<br>1<br>0<br>1<br>1                      | <b>Fligh bit</b><br><u>Priority Level</u><br>Lowest<br>Highest |      |  |  |  |  |  |
| 0             | РХОН            | External interrupt<br><u>PX0H</u><br>0<br>1<br>1<br>1                  | 0 Priority High bi<br><u>PX0</u><br>0<br>1<br>0<br>1                            | t<br><u>Priority Level</u><br>Lowest<br>Highest                |      |  |  |  |  |  |

Reset Value = XXX0 0000b Not bit addressable



### 6.5 Idle mode

An instruction that sets PCON.0 causes that to be the last instruction executed before going into the Idle mode. In the Idle mode, the internal clock signal is gated off to the CPU, but not to the interrupt, Timer, and Serial Port functions. The CPU status is preserved in its entirely : the Stack Pointer, Program Counter, Program Status Word, Accumulator and all other registers maintain their data during Idle. The port pins hold the logical states they had at the time Idle was activated. ALE and PSEN hold at logic high levels.

There are two ways to terminate the Idle. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware, terminating the Idle mode. The interrupt will be serviced, and following RETI the next instruction to be executed will be the one following the instruction that put the device into idle.

The flag bits GF0 and GF1 can be used to give and indication if an interrupt occured during normal operation or during an Idle. For example, an instruction that activates Idle can also set one or both flag bits. When Idle is terminated by an interrupt, the interrupt service routine can examine the flag bits.

The over way of terminating the Idle mode is with a hardware reset. Since the clock oscillator is still running, the hardware reset needs to be held active for only two machine cycles (24 oscillator periods) to complete the reset.

### 6.6 Power-Down Mode

To save maximum power, a power-down mode can be invoked by software (Refer to Table 6., PCON register).

In power-down mode, the oscillator is stopped and the instruction that invoked power-down mode is the last instruction executed. The internal RAM and SFRs retain their value until the power-down mode is terminated.  $V_{CC}$  can be lowered to save further power. Either a hardware reset or an external interrupt can cause an exit from power-down. To properly terminate power-down, the reset or external interrupt should not be executed before  $V_{CC}$  is restored to its normal operating level and must be held active long enough for the oscillator to restart and stabilize.

Only external interrupts  $\overline{INT0}$  and  $\overline{INT1}$  are useful to exit from power-down. For that, interrupt must be enabled and configured as level or edge sensitive interrupt input.

Holding the pin low restarts the oscillator but bringing the pin high completes the exit as detailed in Figure 8. When both interrupts are enabled, the oscillator restarts as soon as one of the two inputs is held low and power down exit will be completed when the first input will be released. In this case the higher priority interrupt service routine is executed.

Once the interrupt is serviced, the next instruction to be executed after RETI will be the one following the instruction that put TS80C31X2 into power-down mode.



#### Figure 8. Power-Down Exit Waveform

Exit from power-down by reset redefines all the SFRs, exit from power-down by external interrupt does no affect the SFRs.

Exit from power-down by either reset or external interrupt does not affect the internal RAM content. NOTE: If idle mode is activated with power-down mode (IDL and PD bits set), the exit sequence is unchanged, when execution is vectored to interrupt, PD and IDL bits are cleared and idle mode is not entered.



| Mode       | Program<br>Memory | ALE | PSEN | PORT0    | PORT1     | PORT2     | PORT3     |
|------------|-------------------|-----|------|----------|-----------|-----------|-----------|
| Idle       | External          | 1   | 1    | Floating | Port Data | Address   | Port Data |
| Power Down | External          | 0   | 0    | Floating | Port Data | Port Data | Port Data |

Table 11. The state of ports during idle and power-down modes



## 6.8 Power-Off Flag

The power-off flag allows the user to distinguish between a "cold start" reset and a "warm start" reset.

A cold start reset is the one induced by  $V_{CC}$  switch-on. A warm start reset occurs while  $V_{CC}$  is still applied to the device and could be generated for example by an exit from power-down.

The power-off flag (POF) is located in PCON register (See Table 13.). POF is set by hardware when  $V_{CC}$  rises from 0 to its nominal voltage. The POF can be set or cleared by software allowing the user to determine the type of reset.

The POF value is only relevant with a Vcc range from 4.5V to 5.5V. For lower Vcc value, reading POF bit will return indeterminate value.

#### Table 13. PCON Register

#### PCON - Power Control Register (87h)

| 7             | 6               | 5                                                     | 4                                                                                                                | 3                  | 2                   | 1                  | 0   |  |  |  |  |  |  |
|---------------|-----------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------|---------------------|--------------------|-----|--|--|--|--|--|--|
| SMOD1         | SMOD            |                                                       | POF                                                                                                              | GF1                | GF0                 | PD                 | IDL |  |  |  |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic |                                                       | Description                                                                                                      |                    |                     |                    |     |  |  |  |  |  |  |
| 7             | SMOD1           | Serial port Mode bi<br>Set to select dou              | Serial port Mode bit 1<br>Set to select double baud rate in mode 1, 2 or 3.                                      |                    |                     |                    |     |  |  |  |  |  |  |
| 6             | SMOD0           | Clear to select S                                     | Serial port Mode bit 0<br>Clear to select SM0 bit in SCON register.<br>Set to to select FE bit in SCON register. |                    |                     |                    |     |  |  |  |  |  |  |
| 5             | -               | <b>Reserved</b><br>The value read f                   | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                  |                    |                     |                    |     |  |  |  |  |  |  |
| 4             | POF             |                                                       | ze next reset type.<br>when V <sub>CC</sub> rises fr                                                             | om 0 to its nomina | l voltage. Can also | be set by software | e.  |  |  |  |  |  |  |
| 3             | GF1             |                                                       | <b>ag</b><br>for general purpose<br>eneral purpose usa                                                           |                    |                     |                    |     |  |  |  |  |  |  |
| 2             | GF0             |                                                       | <b>ag</b><br>for general purpose<br>eneral purpose usa                                                           |                    |                     |                    |     |  |  |  |  |  |  |
| 1             | PD              | Cleared by hardy                                      | Power-Down mode bit<br>Cleared by hardware when reset occurs.<br>Set to enter power-down mode.                   |                    |                     |                    |     |  |  |  |  |  |  |
| 0             | IDL             | Idle mode bit<br>Clear by hardwa<br>Set to enter idle | re when interrupt of mode.                                                                                       | or reset occurs.   |                     |                    |     |  |  |  |  |  |  |

Reset Value = 00X1 0000b Not bit addressable



## 7.3 DC Parameters for Standard Voltage

 $\begin{array}{l} TA = 0^{\circ}C \mbox{ to } +70^{\circ}C; \mbox{ } V_{SS} = 0 \mbox{ } V; \mbox{ } V_{CC} = 5 \mbox{ } V \pm 10\%; \mbox{ } F = 0 \mbox{ to } 40 \mbox{ } MHz. \\ TA = -40^{\circ}C \mbox{ to } +85^{\circ}C; \mbox{ } V_{SS} = 0 \mbox{ } V; \mbox{ } V_{CC} = 5 \mbox{ } V \pm 10\%; \mbox{ } F = 0 \mbox{ to } 40 \mbox{ } MHz. \\ \end{array}$ 

| Table 14. | DC | <b>Parameters</b> | in | Standard | Voltage |
|-----------|----|-------------------|----|----------|---------|
|-----------|----|-------------------|----|----------|---------|

| Symbol                            | Parameter                                                    | Min                                                                     | Тур               | Max                                               | Unit        | Test Conditions                                                                                                                     |
|-----------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------|-------------------|---------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub>                   | Input Low Voltage                                            | -0.5                                                                    |                   | 0.2 V <sub>CC</sub> - 0.1                         | v           |                                                                                                                                     |
| V <sub>IH</sub>                   | Input High Voltage except XTAL1, RST                         | 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 <sup>(6)</sup>             |                                                                         |                   | 0.3<br>0.45<br>1.0                                | V<br>V<br>V | $I_{OL} = 100 \ \mu A^{(4)}$ $I_{OL} = 1.6 \ m A^{(4)}$ $I_{OL} = 3.5 \ m A^{(4)}$                                                  |
| V <sub>OL1</sub>                  | Output Low Voltage, port 0 <sup>(6)</sup>                    |                                                                         |                   | 0.3<br>0.45<br>1.0                                | V<br>V<br>V | $I_{OL} = 200 \ \mu A^{(4)}$ $I_{OL} = 3.2 \ m A^{(4)}$ $I_{OL} = 7.0 \ m A^{(4)}$                                                  |
| V <sub>OL2</sub>                  | Output Low Voltage, ALE, PSEN                                |                                                                         |                   | 0.3<br>0.45<br>1.0                                | V<br>V<br>V | $I_{OL} = 100 \ \mu A^{(4)}$ $I_{OL} = 1.6 \ m A^{(4)}$ $I_{OL} = 3.5 \ m A^{(4)}$                                                  |
| V <sub>OH</sub>                   | Output High Voltage, ports 1, 2, 3                           | $V_{CC} - 0.3$<br>$V_{CC} - 0.7$<br>$V_{CC} - 1.5$                      |                   |                                                   | V<br>V<br>V | $\begin{split} I_{OH} &= -10 \; \mu A \\ I_{OH} &= -30 \; \mu A \\ I_{OH} &= -60 \; \mu A \\ V_{CC} &= 5 \; V \pm 10\% \end{split}$ |
| V <sub>OH1</sub>                  | Output High Voltage, port 0                                  | V <sub>CC</sub> - 0.3<br>V <sub>CC</sub> - 0.7<br>V <sub>CC</sub> - 1.5 |                   |                                                   | V<br>V<br>V | $I_{OH} = -200 \ \mu A$<br>$I_{OH} = -3.2 \ m A$<br>$I_{OH} = -7.0 \ m A$<br>$V_{CC} = 5 \ V \pm 10\%$                              |
| V <sub>OH2</sub>                  | Output High Voltage, ALE, PSEN                               | V <sub>CC</sub> - 0.3<br>V <sub>CC</sub> - 0.7<br>V <sub>CC</sub> - 1.5 |                   |                                                   | V<br>V<br>V | $I_{OH} = -100 \ \mu A$ $I_{OH} = -1.6 \ m A$ $I_{OH} = -3.5 \ m A$ $V_{CC} = 5 \ V \pm 10\%$                                       |
| R <sub>RST</sub>                  | RST Pulldown Resistor                                        | 50                                                                      | 90 <sup>(5)</sup> | 200                                               | kΩ          |                                                                                                                                     |
| I <sub>IL</sub>                   | Logical 0 Input Current ports 1, 2 and 3                     |                                                                         |                   | -50                                               | μΑ          | Vin = 0.45 V                                                                                                                        |
| I <sub>LI</sub>                   | Input Leakage Current                                        |                                                                         |                   | ±10                                               | μΑ          | 0.45 V < Vin < V <sub>CC</sub>                                                                                                      |
| I <sub>TL</sub>                   | Logical 1 to 0 Transition Current, ports 1, 2, 3             |                                                                         |                   | -650                                              | μΑ          | Vin = 2.0 V                                                                                                                         |
| C <sub>IO</sub>                   | Capacitance of I/O Buffer                                    |                                                                         |                   | 10                                                | pF          | Fc = 1 MHz<br>$TA = 25^{\circ}C$                                                                                                    |
| I <sub>PD</sub>                   | Power Down Current                                           |                                                                         | 20 <sup>(5)</sup> | 50                                                | μΑ          | $2.0 \text{ V} < \text{V}_{\text{CC}} < 5.5 \text{ V}^{(3)}$                                                                        |
| I <sub>CC</sub><br>under<br>RESET | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                                                                         |                   | 1 + 0.4 Freq<br>(MHz)<br>@12MHz 5.8<br>@16MHz 7.4 | mA          | $V_{CC} = 5.5 V^{(1)}$                                                                                                              |



| Symbol                       | Parameter                                                    | Min | Тур | Max                                                 | Unit | Test Conditions              |
|------------------------------|--------------------------------------------------------------|-----|-----|-----------------------------------------------------|------|------------------------------|
| I <sub>CC</sub><br>operating | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |     |     | 3 + 0.6 Freq<br>(MHz)<br>@12MHz 10.2<br>@16MHz 12.6 | mA   | $V_{\rm CC} = 5.5 \ V^{(8)}$ |
| I <sub>CC</sub><br>idle      | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |     |     | 0.25+0.3Freq<br>(MHz)<br>@12MHz 3.9<br>@16MHz 5.1   | mA   | $V_{CC} = 5.5 V^{(2)}$       |

## 7.4 DC Parameters for Low Voltage

TA = 0°C to +70°C; V<sub>SS</sub> = 0 V; V<sub>CC</sub> = 2.7 V to 5.5 V  $\pm$  10%; F = 0 to 30 MHz. TA = -40°C to +85°C; V<sub>SS</sub> = 0 V; V<sub>CC</sub> = 2.7 V to 5.5 V  $\pm$  10%; F = 0 to 30 MHz.

Table 15. DC Parameters for Low Voltage

| Symbol                            | Parameter                                                    | Min                 | Тур                                    | Max                                               | Unit | Test Conditions                                                                                      |
|-----------------------------------|--------------------------------------------------------------|---------------------|----------------------------------------|---------------------------------------------------|------|------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub>                   | Input Low Voltage                                            | -0.5                |                                        | 0.2 V <sub>CC</sub> - 0.1                         | V    |                                                                                                      |
| V <sub>IH</sub>                   | Input High Voltage except XTAL1, RST                         | $0.2 V_{CC} + 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 <sup>(6)</sup>             |                     |                                        | 0.45                                              | v    | $I_{OL} = 0.8 \text{ mA}^{(4)}$                                                                      |
| V <sub>OL1</sub>                  | Output Low Voltage, port 0, ALE, PSEN <sup>(6)</sup>         |                     |                                        | 0.45                                              | v    | $I_{OL} = 1.6 \text{ mA}^{(4)}$                                                                      |
| V <sub>OH</sub>                   | Output High Voltage, ports 1, 2, 3                           | 0.9 V <sub>CC</sub> |                                        |                                                   | V    | $I_{OH} = -10 \ \mu A$                                                                               |
| V <sub>OH1</sub>                  | Output High Voltage, port 0, ALE, PSEN                       | 0.9 V <sub>CC</sub> |                                        |                                                   | V    | $I_{OH} = -40 \ \mu A$                                                                               |
| I <sub>IL</sub>                   | Logical 0 Input Current ports 1, 2 and 3                     |                     |                                        | -50                                               | μΑ   | Vin = 0.45 V                                                                                         |
| $I_{LI}$                          | Input Leakage Current                                        |                     |                                        | ±10                                               | μΑ   | 0.45 V < Vin < V <sub>CC</sub>                                                                       |
| I <sub>TL</sub>                   | Logical 1 to 0 Transition Current, ports 1, 2, 3             |                     |                                        | -650                                              | μΑ   | Vin = 2.0 V                                                                                          |
| R <sub>RST</sub>                  | RST Pulldown Resistor                                        | 50                  | 90 <sup>(5)</sup>                      | 200                                               | kΩ   |                                                                                                      |
| CIO                               | Capacitance of I/O Buffer                                    |                     |                                        | 10                                                | pF   | $Fc = 1 MHz$ $TA = 25^{\circ}C$                                                                      |
| I <sub>PD</sub>                   | Power Down Current                                           |                     | 20 <sup>(5)</sup><br>10 <sup>(5)</sup> | 50<br>30                                          | μΑ   | $V_{CC} = 2.0 \text{ V to } 5.5 \text{ V}^{(3)}$<br>$V_{CC} = 2.0 \text{ V to } 3.3 \text{ V}^{(3)}$ |
| I <sub>CC</sub><br>under<br>RESET | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                     |                                        | 1 + 0.2 Freq<br>(MHz)<br>@12MHz 3.4<br>@16MHz 4.2 | mA   | $V_{CC} = 3.3 V^{(1)}$                                                                               |
| I <sub>CC</sub><br>operating      | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                     |                                        | 1 + 0.3 Freq<br>(MHz)<br>@12MHz 4.6<br>@16MHz 5.8 | mA   | $V_{CC} = 3.3 V^{(8)}$                                                                               |









Figure 11.  $I_{CC}$  Test Condition, Idle Mode



Figure 12. I<sub>CC</sub> Test Condition, Power-Down Mode



Figure 13. Clock Signal Waveform for  $I_{\mbox{\scriptsize CC}}$  Tests in Active and Idle Modes



| Symbol            | Туре | Standard<br>Clock | X2 Clock  | -M | -V | -L | Units |
|-------------------|------|-------------------|-----------|----|----|----|-------|
| T <sub>LHLL</sub> | Min  | 2 T - x           | T - x     | 10 | 8  | 15 | ns    |
| T <sub>AVLL</sub> | Min  | T - x             | 0.5 T - x | 15 | 13 | 20 | ns    |
| T <sub>LLAX</sub> | Min  | T - x             | 0.5 T - x | 15 | 13 | 20 | ns    |
| T <sub>LLIV</sub> | Max  | 4 T - x           | 2 T - x   | 30 | 22 | 35 | ns    |
| T <sub>LLPL</sub> | Min  | T - x             | 0.5 T - x | 10 | 8  | 15 | ns    |
| T <sub>PLPH</sub> | Min  | 3 T - x           | 1.5 T - x | 20 | 15 | 25 | ns    |
| T <sub>PLIV</sub> | Max  | 3 T - x           | 1.5 T - x | 40 | 25 | 45 | ns    |
| T <sub>PXIX</sub> | Min  | x                 | х         | 0  | 0  | 0  | ns    |
| T <sub>PXIZ</sub> | Max  | T - x             | 0.5 T - x | 7  | 5  | 15 | ns    |
| T <sub>AVIV</sub> | Max  | 5 T - x           | 2.5 T - x | 40 | 30 | 45 | ns    |
| T <sub>PLAZ</sub> | Max  | x                 | х         | 10 | 10 | 10 | ns    |

## 7.5.3 External Program Memory Read Cycle



Figure 14. External Program Memory Read Cycle



| Speed             |     | M<br>MHz | X2 1<br>30 M | V<br>node<br>MHz<br>z equiv. | standa | V<br>rd mode<br>MHz | X2 1<br>20 N | -L<br>X2 mode<br>20 MHz<br>40 MHz equiv. |     | X2 mode standard mode<br>20 MHz 30 MHz |    | Units |
|-------------------|-----|----------|--------------|------------------------------|--------|---------------------|--------------|------------------------------------------|-----|----------------------------------------|----|-------|
| Symbol            | Min | Max      | Min          | Max                          | Min    | Max                 | Min          | Max                                      | Min | Max                                    |    |       |
| T <sub>RLRH</sub> | 130 |          | 85           |                              | 135    |                     | 125          |                                          | 175 |                                        | ns |       |
| T <sub>WLWH</sub> | 130 |          | 85           |                              | 135    |                     | 125          |                                          | 175 |                                        | ns |       |
| T <sub>RLDV</sub> |     | 100      |              | 60                           |        | 102                 |              | 95                                       |     | 137                                    | ns |       |
| T <sub>RHDX</sub> | 0   |          | 0            |                              | 0      |                     | 0            |                                          | 0   |                                        | ns |       |
| T <sub>RHDZ</sub> |     | 30       |              | 18                           |        | 35                  |              | 25                                       |     | 42                                     | ns |       |
| T <sub>LLDV</sub> |     | 160      |              | 98                           |        | 165                 |              | 155                                      |     | 222                                    | ns |       |
| T <sub>AVDV</sub> |     | 165      |              | 100                          |        | 175                 |              | 160                                      |     | 235                                    | ns |       |
| T <sub>LLWL</sub> | 50  | 100      | 30           | 70                           | 55     | 95                  | 45           | 105                                      | 70  | 130                                    | ns |       |
| T <sub>AVWL</sub> | 75  |          | 47           |                              | 80     |                     | 70           |                                          | 103 |                                        | ns |       |
| T <sub>QVWX</sub> | 10  |          | 7            |                              | 15     |                     | 5            |                                          | 13  |                                        | ns |       |
| T <sub>QVWH</sub> | 160 |          | 107          |                              | 165    |                     | 155          |                                          | 213 |                                        | ns |       |
| T <sub>WHQX</sub> | 15  |          | 9            |                              | 17     |                     | 10           |                                          | 18  |                                        | ns |       |
| T <sub>RLAZ</sub> |     | 0        |              | 0                            |        | 0                   |              | 0                                        |     | 0                                      | ns |       |
| T <sub>WHLH</sub> | 10  | 40       | 7            | 27                           | 15     | 35                  | 5            | 45                                       | 13  | 53                                     | ns |       |

Table 22. AC Parameters for a Fix Clock



| Symbol            | Туре | Standard<br>Clock | X2 Clock  | -M | -V | -L | Units |
|-------------------|------|-------------------|-----------|----|----|----|-------|
| T <sub>RLRH</sub> | Min  | 6 T - x           | 3 T - x   | 20 | 15 | 25 | ns    |
| T <sub>WLWH</sub> | Min  | 6 T - x           | 3 T - x   | 20 | 15 | 25 | ns    |
| T <sub>RLDV</sub> | Max  | 5 T - x           | 2.5 T - x | 25 | 23 | 30 | ns    |
| T <sub>RHDX</sub> | Min  | x                 | х         | 0  | 0  | 0  | ns    |
| T <sub>RHDZ</sub> | Max  | 2 T - x           | T - x     | 20 | 15 | 25 | ns    |
| T <sub>LLDV</sub> | Max  | 8 T - x           | 4T -x     | 40 | 35 | 45 | ns    |
| T <sub>AVDV</sub> | Max  | 9 T - x           | 4.5 T - x | 60 | 50 | 65 | ns    |
| T <sub>LLWL</sub> | Min  | 3 T - x           | 1.5 T - x | 25 | 20 | 30 | ns    |
| T <sub>LLWL</sub> | Max  | 3 T + x           | 1.5 T + x | 25 | 20 | 30 | ns    |
| T <sub>AVWL</sub> | Min  | 4 T - x           | 2 T - x   | 25 | 20 | 30 | ns    |
| T <sub>QVWX</sub> | Min  | T - x             | 0.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>QVWH</sub> | Min  | 7 T - x           | 3.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>WHQX</sub> | Min  | T - x             | 0.5 T - x | 10 | 8  | 15 | ns    |
| T <sub>RLAZ</sub> | Max  | x                 | х         | 0  | 0  | 0  | ns    |
| T <sub>WHLH</sub> | Min  | T - x             | 0.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>WHLH</sub> | Max  | T + x             | 0.5 T + x | 15 | 10 | 20 | ns    |

 Table 23. AC Parameters for a Variable Clock: derating formula

## 7.5.5 External Data Memory Write Cycle



Figure 15. External Data Memory Write Cycle





### 7.5.6 External Data Memory Read Cycle



Figure 16. External Data Memory Read Cycle

### 7.5.7 Serial Port Timing - Shift Register Mode

#### Table 24. Symbol Description

| Symbol            | Parameter                                |
|-------------------|------------------------------------------|
| T <sub>XLXL</sub> | Serial port clock cycle time             |
| T <sub>QVHX</sub> | Output data set-up to clock rising edge  |
| T <sub>XHQX</sub> | Output data hold after clock rising edge |
| T <sub>XHDX</sub> | Input data hold after clock rising edge  |
| T <sub>XHDV</sub> | Clock rising edge to input data valid    |

### Table 25. AC Parameters for a Fix Clock

| Speed             | -M<br>40 MHz |     | -V<br>X2 mode<br>30 MHz<br>60 MHz equiv. |     | -V<br>standard mode<br>40 MHz |     | -L<br>X2 mode<br>20 MHz<br>40 MHz equiv. |     | -L<br>standard mode<br>30 MHz |     | Units |
|-------------------|--------------|-----|------------------------------------------|-----|-------------------------------|-----|------------------------------------------|-----|-------------------------------|-----|-------|
| Symbol            | Min          | Max | Min                                      | Max | Min                           | Max | Min                                      | Max | Min                           | Max |       |
| T <sub>XLXL</sub> | 300          |     | 200                                      |     | 300                           |     | 300                                      |     | 400                           |     | ns    |
| T <sub>QVHX</sub> | 200          |     | 117                                      |     | 200                           |     | 200                                      |     | 283                           |     | ns    |
| T <sub>XHQX</sub> | 30           |     | 13                                       |     | 30                            |     | 30                                       |     | 47                            |     | ns    |
| T <sub>XHDX</sub> | 0            |     | 0                                        |     | 0                             |     | 0                                        |     | 0                             |     | ns    |
| T <sub>XHDV</sub> |              | 117 |                                          | 34  |                               | 117 |                                          | 117 |                               | 200 | ns    |



| Symbol            | Туре | Standard<br>Clock | X2 Clock | -М  | -V  | -L  | Units |
|-------------------|------|-------------------|----------|-----|-----|-----|-------|
| T <sub>XLXL</sub> | Min  | 12 T              | 6 T      |     |     |     | ns    |
| T <sub>QVHX</sub> | Min  | 10 T - x          | 5 T - x  | 50  | 50  | 50  | ns    |
| T <sub>XHQX</sub> | Min  | 2 T - x           | T - x    | 20  | 20  | 20  | ns    |
| T <sub>XHDX</sub> | Min  | х                 | х        | 0   | 0   | 0   | ns    |
| T <sub>XHDV</sub> | Max  | 10 T - x          | 5 T- x   | 133 | 133 | 133 | ns    |

 Table 26. AC Parameters for a Variable Clock: derating formula

## 7.5.8 Shift Register Timing Waveforms



Figure 17. Shift Register Timing Waveforms



## 8. Ordering Information



Table 28. Maximum Clock Frequency

| Code                                   | -M | -V        | -L        | Unit |
|----------------------------------------|----|-----------|-----------|------|
| Standard Mode, oscillator frequency    | 40 | 40        | 30        | MHz  |
| Standard Mode, internal frequency      | 40 | 40        | 30        |      |
| X2 Mode, oscillator frequency          | 20 | 30        | 20        | MHz  |
| X2 Mode, internal equivalent frequency | 40 | <b>60</b> | <b>40</b> |      |