



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | 8051                                                                     |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 18MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, UART/USART                                             |
| Peripherals                | Brown-out Detect/Reset, LED, POR, PWM, WDT                               |
| Number of I/O              | 18                                                                       |
| Program Memory Size        | 8KB (8K x 8)                                                             |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 256 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2.4V ~ 3.6V                                                              |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 20-TSSOP (0.173", 4.40mm Width)                                          |
| Supplier Device Package    | 20-TSSOP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89lpc922fdh-529 |

Email: info@E-XFL.COM

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

## 2.2 Additional features

- 15 I/O pins minimum. Up to 18 I/O pins while using on-chip oscillator and reset options.
- 20-pin TSSOP and DIP packages.
- A high performance 80C51 CPU provides instruction cycle times of 111 ns to 222 ns for all instructions except multiply and divide when executing at 18 MHz. This is six times the performance of the standard 80C51 running at the same clock frequency. A lower clock frequency for the same performance results in power savings and reduced EMI.
- In-Application Programming of the Flash code memory. This allows changing the code in a running application.
- Serial Flash programming allows simple in-circuit production coding. Flash security bits prevent reading of sensitive application programs.
- Watchdog timer with separate on-chip oscillator, requiring no external components. The watchdog prescaler is selectable from eight values.
- Low voltage reset (Brownout detect) allows a graceful system shutdown when power fails. May optionally be configured as an interrupt.
- Idle and two different Power-down reduced power modes. Improved wake-up from Power-down mode (a low interrupt input starts execution). Typical Power-down current is 1 µA (total Power-down with voltage comparators disabled).
- Active-LOW reset. On-chip power-on reset allows operation without external reset components. A reset counter and reset glitch suppression circuitry prevent spurious and incomplete resets. A software reset function is also available.
- Oscillator Fail Detect. The watchdog timer has a separate fully on-chip oscillator allowing it to perform an oscillator fail detect function.
- Programmable port output configuration options:
  - quasi-bidirectional,
  - open drain,
  - push-pull,
  - input-only.
- Port 'input pattern match' detect. Port 0 may generate an interrupt when the value of the pins match or do not match a programmable pattern.
- LED drive capability (20 mA) on all port pins. A maximum limit is specified for the entire chip (160 mA for the P89LPC9221; 80 mA for the P89LPC920/921/922).
- Controlled slew rate port outputs to reduce EMI. Outputs have approximately 10 ns minimum ramp times.
- Only power and ground connections are required to operate the P89LPC920/921/922/9221 when internal reset option is selected.
- Four interrupt priority levels.
- Eight keypad interrupt inputs, plus two additional external interrupt inputs.
- Second data pointer.
- Schmitt trigger port inputs.
- Emulation support.

8-bit microcontrollers with two-clock 80C51 core

## 5. Pinning information



## 5.1 Pinning

## 5.2 Pin description

| Table 3:   | Pin descri |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol     | Pin        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.0 to P0 | ).7        | I/O  | <b>Port 0:</b> Port 0 is an 8-bit I/O port with a user-configurable output type. During reset<br>Port 0 latches are configured in the input only mode with the internal pull-up disabled.<br>The operation of Port 0 pins as inputs and outputs depends upon the port configuration<br>selected. Each port pin is configured independently. Refer to Section 8.12.1 "Port<br>configurations" and Table 8 "DC electrical characteristics" for details. |
|            |            |      | The Keypad Interrupt feature operates with Port 0 pins.                                                                                                                                                                                                                                                                                                                                                                                               |
|            |            |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                               |
|            |            |      | Port 0 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                    |
|            | 1          | I/O  | <b>P0.0</b> — Port 0 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |            | 0    | CMP2 — Comparator 2 output.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |            | I    | KBI0 — Keyboard input 0.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 20         | I/O  | <b>P0.1</b> — Port 0 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |            | I    | <b>CIN2B</b> — Comparator 2 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            | I    | KBI1 — Keyboard input 1.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 19         | I/O  | <b>P0.2</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |            | I    | <b>CIN2A</b> — Comparator 2 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            | I    | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 18         | I/O  | P0.3 — Port 0 bit 3. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | I    | <b>CIN1B</b> — Comparator 1 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            | Ι    | KBI3 — Keyboard input 3.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 17         | I/O  | P0.4 — Port 0 bit 4. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | I    | CIN1A — Comparator 1 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | I    | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 16         | I/O  | P0.5 — Port 0 bit 5. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | I    | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | Ι    | KBI5 — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 14         | I/O  | P0.6 — Port 0 bit 6. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | 0    | CMP1 — Comparator 1 output.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |            | I    | KBI6 — Keyboard input 6.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|            | 13         | I/O  | P0.7 — Port 0 bit 7. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                |
|            |            | I/O  | T1 — Timer/counter 1 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            | 1    | KBI7 — Keyboard input 7.                                                                                                                                                                                                                                                                                                                                                                                                                              |

## 8-bit microcontrollers with two-clock 80C51 core

|             | uea |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-----|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol      | Pin | Туре                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1.0 to P1. | 7   | I/O, I <sup>[1]</sup> | <b>Port 1:</b> Port 1 is an 8-bit I/O port with a user-configurable output type, except for three pins as noted below. During reset Port 1 latches are configured in the input only mode with the internal pull-up disabled. The operation of the configurable Port 1 pins as inputs and outputs depends upon the port configuration selected. Each of the configurable port pins are programmed independently. Refer to Section 8.12.1 "Port configurations" and Table 8 "DC electrical characteristics" for details. P1.2 - P1.3 are open drain when used as outputs. P1.5 is input only.                                                                                                                                                                                                                         |
|             |     |                       | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|             |     |                       | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             | 12  | I/O                   | <b>P1.0</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|             |     | 0                     | <b>TXD</b> — Transmitter output for the serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             | 11  | I/O                   | <b>P1.1</b> — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|             |     | I                     | <b>RXD</b> — Receiver input for the serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             | 10  | I/O                   | P1.2 — Port 1 bit 2 (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             |     | I/O                   | <b>T0</b> — Timer/counter 0 external count input or overflow output (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             |     | I/O                   | <b>SCL</b> — I <sup>2</sup> C serial clock input/output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|             | 9   | I/O                   | P1.3 — Port 1 bit 3 (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             |     | I                     | INTO — External interrupt 0 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |     | I/O                   | <b>SDA</b> — I <sup>2</sup> C serial data input/output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|             | 8   | I/O                   | P1.4 — Port 1 bit 4. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             |     | I                     | INT1 — External interrupt 1 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             | 4   | I                     | P1.5 — Port 1 bit 5 (input only).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|             |     | I                     | <b>RST</b> — External Reset input (if selected via FLASH configuration). A LOW on this pin resets the microcontroller, causing I/O ports and peripherals to take on their default states, and the processor begins execution at address 0. When using an oscillator frequency above 12 MHz, the reset input function of P1.5 must be enabled. An external circuit is required to hold the device in reset at power-up until V <sub>DD</sub> has reached its specified level. When system power is removed V <sub>DD</sub> will fall below the minimum specified operating voltage. When using an oscillator frequency above 12 MHz, in some applications, an external brownout detect circuit may be required to hold the device in reset when V <sub>DD</sub> falls below the minimum specified operating voltage. |
|             | 3   | I/O                   | P1.6 — Port 1 bit 6. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | 2   | I/O                   | P1.7 — Port 1 bit 7. High current source (P89LPC9221).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## Table 3: Pin description...continued

## 8. Functional description

**Remark:** Please refer to the *P89LPC920/921/922/9221 User's Manual* for a more detailed functional description.

## 8.1 Enhanced CPU

The P89LPC920/921/922/9221 uses an enhanced 80C51 CPU which runs at 6 times the speed of standard 80C51 devices. A machine cycle consists of two CPU clock cycles, and most instructions execute in one or two machine cycles.

## 8.2 Clocks

### 8.2.1 Clock definitions

The P89LPC920/921/922/9221 device has several internal clocks as defined below:

**OSCCLK** — Input to the DIVM clock divider. OSCCLK is selected from one of four clock sources (see Figure 5) and can also be optionally divided to a slower frequency (see Section 8.7 "CPU Clock (CCLK) modification: DIVM register").

**Note:** fosc is defined as the OSCCLK frequency.

**CCLK** — CPU clock; output of the clock divider. There are two CCLK cycles per machine cycle, and most instructions are executed in one to two machine cycles (two or four CCLK cycles).

RCCLK — The internal 7.373 MHz RC oscillator output.

**PCLK** — Clock for the various peripheral devices and is CCLK/2

### 8.2.2 CPU clock (OSCCLK)

The P89LPC920/921/922/9221 provides several user-selectable oscillator options in generating the CPU clock. This allows optimization for a range of needs from high precision to lowest possible cost. These options are configured when the FLASH is programmed and include an on-chip watchdog oscillator, an on-chip RC oscillator, an oscillator using an external crystal, or an external clock source. The crystal oscillator can be optimized for low, medium, or high frequency crystals covering a range from 20 kHz to 12 MHz.

### 8.2.3 Low speed oscillator option

This option supports an external crystal in the range of 20 kHz to 100 kHz. Ceramic resonators are also supported in this configuration.

### 8.2.4 Medium speed oscillator option

This option supports an external crystal in the range of 100 kHz to 4 MHz. Ceramic resonators are also supported in this configuration.

### 8.2.5 High speed oscillator option

This option supports an external crystal in the range of 4 MHz to 18 MHz. Ceramic resonators are also supported in this configuration. When using an oscillator frequency above 12 MHz, the reset input function of P1.5 must be enabled. An external circuit is required to hold the device in reset at power-up until V<sub>DD</sub> has reached its specified level. When system power is removed V<sub>DD</sub> will fall below

8-bit microcontrollers with two-clock 80C51 core



## 8.6 CPU Clock (CCLK) wake-up delay

The P89LPC920/921/922/9221 has an internal wake-up timer that delays the clock until it stabilizes depending to the clock source used. If the clock source is any of the three crystal selections (low, medium and high frequencies) the delay is 992 OSCCLK cycles plus 60 to 100  $\mu$ s. If the clock source is either the internal RC oscillator, watchdog oscillator, or external clock, the delay is 224 OSCCLK cycles plus 60 to 100  $\mu$ s.

## 8.7 CPU Clock (CCLK) modification: DIVM register

The OSCCLK frequency can be divided down up to 510 times by configuring a dividing register, DIVM, to generate CCLK. This feature makes it possible to temporarily run the CPU at a lower rate, reducing power consumption. By dividing the clock, the CPU can retain the ability to respond to events that would not exit Idle mode by executing its normal program at a lower rate. This can also allow bypassing the oscillator start-up time in cases where Power-down mode would otherwise be used. The value of DIVM may be changed by the program at any time without interrupting code execution.

## 8.8 Low power select

The P89LPC920/921/922/9221 is designed to run at 18 MHz (CCLK) maximum. However, if CCLK is 8 MHz or slower, the CLKLP SFR bit (AUXR1.7) can be set to '1' to lower the power consumption further. On any reset, CLKLP is '0' allowing highest performance access. This bit can then be set in software if CCLK is running at 8 MHz or slower.

## 8.9 Memory organization

The various P89LPC920/921/922/9221 memory spaces are as follows:

• DATA

128 bytes of internal data memory space (00h:7Fh) accessed via direct or indirect addressing, using instruction other than MOVX and MOVC. All or part of the Stack may be in this area.

• IDATA

Indirect Data. 256 bytes of internal data memory space (00h:FFh) accessed via indirect addressing using instructions other than MOVX and MOVC. All or part of the Stack may be in this area. This area includes the DATA area and the 128 bytes immediately above it.

SFR

Special Function Registers. Selected CPU registers and peripheral control and status registers, accessible only via direct addressing.

• CODE

64 kB of Code memory space, accessed as part of program execution and via the MOVC instruction. The P89LPC920/921/922/9221 has 2 kB/4 kB/8 kB of on-chip Code memory.

P1.2 (SCL/T0) and P1.3 (SDA/INT0) may only be configured to be either input-only or open-drain.

## 8.12.2 Quasi-bidirectional output configuration

Quasi-bidirectional output type can be used as both an input and output without the need to reconfigure the port. This is possible because when the port outputs a logic HIGH, it is weakly driven, allowing an external device to pull the pin LOW. When the pin is driven LOW, it is driven strongly and able to sink a fairly large current. These features are somewhat similar to an open-drain output except that there are three pull-up transistors in the quasi-bidirectional output that serve different purposes.

The P89LPC920/921/922/9221 is a 3 V device, but the pins are 5 V-tolerant. In quasi-bidirectional mode, if a user applies 5 V on the pin, there will be a current flowing from the pin to  $V_{DD}$ , causing extra power consumption. Therefore, applying 5 V in quasi-bidirectional mode is discouraged.

A quasi-bidirectional port pin has a Schmitt-triggered input that also has a glitch suppression circuit.

## 8.12.3 Open-drain output configuration

The open-drain output configuration turns off all pull-ups and only drives the pull-down transistor of the port driver when the port latch contains a logic '0'. To be used as a logic output, a port configured in this manner must have an external pull-up, typically a resistor tied to  $V_{DD}$ .

An open-drain port pin has a Schmitt-triggered input that also has a glitch suppression circuit.

### 8.12.4 Input-only configuration

The input-only port configuration has no output drivers. It is a Schmitt-triggered input that also has a glitch suppression circuit.

### 8.12.5 Push-pull output configuration

The push-pull output configuration has the same pull-down structure as both the open-drain and the quasi-bidirectional output modes, but provides a continuous strong pull-up when the port latch contains a logic '1'. The push-pull mode may be used when more source current is needed from a port output. A push-pull port pin has a Schmitt-triggered input that also has a glitch suppression circuit. The P89LPC9221 device has high source current on eight pins in push-pull mode. See Table 8 "DC electrical characteristics".

## 8.12.6 Port 0 analog functions

The P89LPC920/921/922/9221 incorporates two Analog Comparators. In order to give the best analog function performance and to minimize power consumption, pins that are being used for analog functions must have the digital outputs and digital inputs disabled.

Digital outputs are disabled by putting the port output into the Input-Only (high impedance) mode as described in Section 8.12.4.

Digital inputs on Port 0 may be disabled through the use of the PT0AD register, bits 1:5. On any reset, PT0AD1:5 defaults to '0's to enable digital functions.

## 8.12.7 Additional port features

After power-up, all pins are in Input-Only mode. Please note that this is different from the LPC76x series of devices.

- After power-up, all I/O pins except P1.5, may be configured by software.
- Pin P1.5 is input only. Pins P1.2 and P1.3 and are configurable for either input-only or open-drain.

Every output on the P89LPC920/921/922/9221 has been designed to sink typical LED drive current. However, there is a maximum total output current for all ports which must not be exceeded. Please refer to Table 8 "DC electrical characteristics" for detailed specifications.

All ports pins that can function as an output have slew rate controlled outputs to limit noise generated by quickly switching output signals. The slew rate is factory-set to approximately 10 ns rise and fall times.

## 8.13 Power monitoring functions

The P89LPC920/921/922/9221 incorporates power monitoring functions designed to prevent incorrect operation during initial power-up and power loss or reduction during operation. This is accomplished with two hardware functions: Power-on Detect and Brownout detect.

#### 8.13.1 Brownout detection

The Brownout detect function determines if the power supply voltage drops below a certain level. The default operation is for a Brownout detection to cause a processor reset, however it may alternatively be configured to generate an interrupt.

Brownout detection may be enabled or disabled in software.

If Brownout detection is enabled, the brownout condition occurs when  $V_{DD}$  falls below the brownout trip voltage,  $V_{BO}$  (see Table 8 "DC electrical characteristics"), and is negated when  $V_{DD}$  rises above  $V_{BO}$ . If the P89LPC920/921/922/9221 device is to operate with a power supply that can be below 2.7 V, BOE should be left in the unprogrammed state so that the device can operate at 2.4 V, otherwise continuous brownout reset may prevent the device from operating.

For correct activation of Brownout detect, the V<sub>DD</sub> rise and fall times must be observed. Please see Table 8 "DC electrical characteristics" for specifications.

### 8.13.2 Power-on detection

The Power-on Detect has a function similar to the Brownout detect, but is designed to work as power comes up initially, before the power supply voltage reaches a level where Brownout detect can work. The POF flag in the RSTSRC register is set to indicate an initial power-up condition. The POF flag will remain set until cleared by software.

## 8.14 Power reduction modes

The P89LPC920/921/922/9221 supports three different power reduction modes. These modes are Idle mode, Power-down mode, and total Power-down mode.

## 8.16.3 Mode 2

Mode 2 configures the Timer register as an 8-bit Counter with automatic reload. Mode 2 operation is the same for Timer 0 and Timer 1.

#### 8.16.4 Mode 3

When Timer 1 is in Mode 3 it is stopped. Timer 0 in Mode 3 forms two separate 8-bit counters and is provided for applications that require an extra 8-bit timer. When Timer 1 is in Mode 3 it can still be used by the serial port as a baud rate generator.

### 8.16.5 Mode 6

In this mode, the corresponding timer can be changed to a PWM with a full period of 256 timer clocks.

### 8.16.6 Timer overflow toggle output

Timers 0 and 1 can be configured to automatically toggle a port output whenever a timer overflow occurs. The same device pins that are used for the T0 and T1 count inputs are also used for the timer toggle outputs. The port outputs will be a logic 1 prior to the first timer overflow when this mode is turned on.

## 8.17 Real-Time clock/system timer

The P89LPC920/921/922/9221 has a simple Real-Time clock that allows a user to continue running an accurate timer while the rest of the device is powered-down. The Real-Time clock can be a wake-up or an interrupt source. The Real-Time clock is a 23-bit down counter comprised of a 7-bit prescaler and a 16-bit loadable down counter. When it reaches all '0's, the counter will be reloaded again and the RTCF flag will be set. The clock source for this counter can be either the CPU clock (CCLK) or the XTAL oscillator, provided that the XTAL oscillator is not being used as the CPU clock. If the XTAL oscillator is used as the CPU clock, then the RTC will use CCLK as its clock source. Only power-on reset will reset the Real-Time clock and its associated SFRs to the default state.

## 8.18 UART

The P89LPC920/921/922/9221 has an enhanced UART that is compatible with the conventional 80C51 UART except that Timer 2 overflow cannot be used as a baud rate source. The P89LPC920/921/922/9221 does include an independent Baud Rate Generator. The baud rate can be selected from the oscillator (divided by a constant), Timer 1 overflow, or the independent Baud Rate Generator. In addition to the baud rate generation, enhancements over the standard 80C51 UART include Framing Error detection, automatic address recognition, selectable double buffering and several interrupt options.The UART can be operated in 4 modes: shift register, 8-bit UART, 9-bit UART, and CPU clock/32 or CPU clock/16.

#### 8.18.1 Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted or received, LSB first. The baud rate is fixed at  $1/_{16}$  of the CPU clock frequency.

8-bit microcontrollers with two-clock 80C51 core



8-bit microcontrollers with two-clock 80C51 core

## 8.22 Watchdog timer

The Watchdog timer causes a system reset when it underflows as a result of a failure to feed the timer prior to the timer reaching its terminal count. It consists of a programmable 12-bit prescaler, and an 8-bit down counter. The down counter is decremented by a tap taken from the prescaler. The clock source for the prescaler is either the PCLK or the nominal 400 kHz Watchdog oscillator. The Watchdog timer can only be reset by a power-on reset. When the watchdog feature is disabled, it can be used as an interval timer and may generate an interrupt. Figure 11 shows the Watchdog timer in watchdog mode. Feeding the watchdog requires a two-byte sequence. If PCLK is selected as the watchdog clock and the CPU is powered-down, the watchdog is disabled. The Watchdog timer has a time-out period that ranges from a few  $\mu$ s to a few seconds. Please refer to the *P89LPC920/921/922/9221* User's Manual for more details.



Fig 11. Watchdog timer in watchdog mode (WDTE = '1').

## 8.23 Additional features

### 8.23.1 Software reset

The SRST bit in AUXR1 gives software the opportunity to reset the processor completely, as if an external reset or watchdog reset had occurred. Care should be taken when writing to AUXR1 to avoid accidental software resets.

### 8.23.2 Dual data pointers

The dual Data Pointers (DPTR) provides two different Data Pointers to specify the address used with certain instructions. The DPS bit in the AUXR1 register selects one of the two Data Pointers. Bit 2 of AUXR1 is permanently wired as a logic '0' so that the DPS bit may be toggled (thereby switching Data Pointers) simply by incrementing the AUXR1 register, without the possibility of inadvertently altering other bits in the register.

## 8.24 Flash program memory

## 8.24.1 General description

The P89LPC920/921/922/9221 Flash memory provides in-circuit electrical erasure and programming. The Flash can be read, erased, or written as bytes. The Sector and Page Erase functions can erase any Flash sector (1 kB) or page (64 bytes). The Chip Erase operation will erase the entire program memory. In-System Programming and standard parallel programming are both available. On-chip erase and write timing generation contribute to a user-friendly programming interface. The P89LPC920/921/922/9221 Flash reliably stores memory contents even after 10,000 erase and program cycles. The cell is designed to optimize the erase and programming mechanisms. The P89LPC920/921/922/9221 uses V<sub>DD</sub> as the supply voltage to perform the Program/Erase algorithms.

### 8.24.2 Features

- Parallel programming with industry-standard commercial programmers.
- In-Circuit serial Programming (ICP) with industry-standard commercial programmers.
- IAP-Lite allows individual and multiple bytes of code memory to be used for data storage and programmed under control of the end application.
- Internal fixed boot ROM, containing low-level In-Application Programming (IAP) routines that can be called from the end application (in addition to IAP-Lite).
- Default serial loader providing In-System Programming (ISP) via the serial port, located in upper end of user program memory.
- Boot vector allows user-provided Flash loader code to reside anywhere in the Flash memory space, providing flexibility to the user.
- Programming and erase over the full operating voltage range.
- Read/Programming/Erase using ISP/IAP/IAP-Lite.
- Any flash program or erase operation in 2 ms.
- Programmable security for the code in the Flash for each sector.
- >100,000 typical erase/program cycles for each byte.
- 10 year minimum data retention.

### 8.24.3 ISP and IAP capabilities of the P89LPC920/921/922/9221

**Flash organization:** The P89LPC920/921/922/9221 program memory consists of two/four/eight 1 kB sectors. Each sector can be further divided into 64-byte pages. In addition to sector erase, page erase, and byte erase, a 64-byte page register is included which allows from 1 to 64 bytes of a given page to be programmed at the same time, substantially reducing overall programming time. An In-Application Programming (IAP) interface is provided to allow the end user's application to erase and reprogram the user code memory. In addition, erasing and reprogramming of user-programmable bytes including UCFG1, the Boot Status Bit and the Boot Vector are supported. As shipped from the factory, the upper 512 bytes of user code space contains a serial In-System Programming (ISP) routine allowing for the device to be programmed in circuit through the serial port.

#### 8-bit microcontrollers with two-clock 80C51 core

**Flash programming and erasing:** There are three methods of erasing or programming of the Flash memory that may be used. First, the Flash may be programmed or erased in the end-user application by calling low-level routines through a common entry point. Second, the on-chip ISP boot loader may be invoked. This ISP boot loader will, in turn, call low-level routines through the same common entry point that can be used by the end-user application. Third, the Flash may be programmed or erased using the parallel method by using a commercially available EPROM programmer which supports this device. This device does not provide for direct verification of code memory contents. Instead this device provides a 32-bit CRC result on either a sector or the entire 2 kB/4 kB/8 kB of user code space.

**Boot ROM:** When the microcontroller programs its own Flash memory, all of the low-level details are handled by code that is contained in a Boot ROM that is separate from the Flash memory. A user program simply calls the common entry point in the Boot ROM with appropriate parameters to accomplish the desired operation. The Boot ROM include operations such as erase sector, erase page, program page, CRC, program security bit, etc. The Boot ROM occupies the program memory space at the top of the address space from FF00H to FEFFH, thereby not conflicting with the user program memory space.

Power-on reset code execution: The P89LPC920/921/922/9221 contains two special Flash elements: the Boot Vector and the Boot Status Bit. Following reset, the P89LPC920/921/922/9221 examines the contents of the Boot Status Bit. If the Boot Status Bit is set to zero, power-up execution starts at location 0000H, which is the normal start address of the user's application code. When the Boot Status Bit is set to a one, the contents of the Boot Vector is used as the high byte of the execution address and the low byte is set to 00H. The factory default setting is 1FH for the P89LPC9221 and P89LPC922, and corresponds to the address 1F00H for the default ISP boot loader. The factory default setting is 0FH for the P89LPC921 and corresponds to the address 0F00H for the default ISP boot loader. The factory default setting for the LPC920 is 07H and corresponds to the address 0700H. This boot loader is pre-programmed at the factory into this address space and can be erased by the user. Users who wish to use this loader should take precautions to avoid erasing the 1 kB sector from 1C00H to 1FFFH in the P89LPC922/9221 or the 1 kB sector from 0C00H to 0FFFH in the P89LPC921, or the 1 kB sector from 0400H to 07FFH in the P89LPC920. Instead, the page erase function can be used to erase the eight 64-byte pages which comprise the lower 512 bytes of the sector. A custom boot loader can be written with the Boot Vector set to the custom boot loader, if desired.

Hardware activation of the boot loader: The boot loader can also be executed by forcing the device into ISP mode during a power-on sequence (see the *P89LPC920/921/922/9221 User's Manual* for specific information). This has the same effect as having a non-zero Boot Status Bit. This allows an application to be built that will normally execute user code but can be manually forced into ISP operation. If the factory default setting for the Boot Vector is changed, it will no longer point to the factory pre-programmed ISP boot loader code. If this happens, the only way it is possible to change the contents of the Boot Vector is through the parallel programming method, provided that the end user application does not contain a customized loader that provides for erasing and reprogramming of the Boot Vector

## 8-bit microcontrollers with two-clock 80C51 core

#### Table 8: DC electrical characteristics...continued

 $V_{DD}$  = 2.4 V to 3.6 V unless otherwise specified.

 $T_{amb} = -40 \circ C$  to +85  $\circ C$  for industrial, unless otherwise specified.

|                      |                                                     | •                               |      |                    |      |        |
|----------------------|-----------------------------------------------------|---------------------------------|------|--------------------|------|--------|
| Symbol               | Parameter                                           | Conditions                      | Min  | Typ <sup>[1]</sup> | Max  | Unit   |
| V <sub>BO</sub>      | brownout trip voltage with<br>BOV = '0', BOPD = '1' | 2.4 V < V <sub>DD</sub> < 3.6 V | 2.40 | -                  | 2.70 | V      |
| $V_{REF}$            | bandgap reference voltage                           |                                 | 1.11 | 1.23               | 1.34 | V      |
| TC <sub>(VREF)</sub> | bandgap temperature coefficient                     |                                 | -    | 10                 | 20   | ppm/°C |
| TC <sub>(VREF)</sub> | bandgap temperature coefficient                     |                                 | -    | 10                 | 20   |        |

[1] Typical ratings are not guaranteed. The values listed are at room temperature, 3 V.

[2] The I<sub>DD(oper)</sub>, I<sub>DD(idle)</sub>, and I<sub>DD(PD)</sub> specifications are measured using an external clock with the following functions disabled: comparators, brownout detect, and Watchdog timer.

[3] See Table 7 "Limiting values<sup>[1]</sup>" on page 35 for steady state (non-transient) limits on  $I_{OL}$  or  $I_{OH}$ . If  $I_{OL}/I_{OH}$  exceeds the test condition,  $V_{OL}/V_{OH}$  may exceed the related specification.

- [4] Pin capacitance is characterized but not tested.
- [5] Measured with port in quasi-bidirectional mode.
- [6] Measured with port in high-impedance mode.

[7] Ports in quasi-bidirectional mode with weak pull-up (applies to all port pins with pull-ups). Does not apply to open-drain pins.

[8] Port pins source a transition current when used in quasi-bidirectional mode and externally driven from '1' to '0'. This current is highest when V<sub>IN</sub> is approximately 2 V.

8-bit microcontrollers with two-clock 80C51 core

## **11. Dynamic characteristics**

## Table 9:AC characteristics

 $V_{DD}$  = 2.4 V to 3.6 V unless otherwise specified.

 $T_{amb} = -40 \degree C$  to +85  $\degree C$  for industrial, unless otherwise specified.<sup>[1]</sup>

| Symbol             | Parameter                                                       | Conditions                                    | Variable             | f <sub>osc</sub> = 12 MHz             |       | Unit  |     |
|--------------------|-----------------------------------------------------------------|-----------------------------------------------|----------------------|---------------------------------------|-------|-------|-----|
|                    |                                                                 |                                               | Min                  | Max                                   | Min   | Max   |     |
| f <sub>RCOSC</sub> | internal RC oscillator frequency<br>(nominal f = 7.3728 MHz)    | trimmed to ±1%<br>at T <sub>amb</sub> = 25 °C | 7.189                | 7.557                                 | 7.189 | 7.557 | MHz |
| f <sub>WDOSC</sub> | internal Watchdog oscillator<br>frequency (nominal f = 400 kHz) |                                               | 320                  | 520                                   | 320   | 520   | kHz |
| f <sub>osc</sub>   | oscillator frequency                                            |                                               | 0                    | 12                                    | -     | -     | MHz |
| t <sub>CLCL</sub>  | clock cycle                                                     | see Figure 13                                 | 83                   | -                                     | -     | -     | ns  |
| f <sub>CLKP</sub>  | CLKLP active frequency                                          |                                               | 0                    | 8                                     | -     | -     | MHz |
| Glitch filt        | er                                                              |                                               |                      |                                       |       |       |     |
|                    | glitch rejection, P1.5/RST pin                                  |                                               | -                    | 50                                    | -     | 50    | ns  |
|                    | signal acceptance, P1.5/RST pin                                 |                                               | 125                  | -                                     | 125   | -     | ns  |
|                    | glitch rejection, any pin except P1.5/RST                       |                                               | -                    | 15                                    | -     | 15    | ns  |
|                    | signal acceptance, any pin except P1.5/RST                      |                                               | 50                   | -                                     | 50    | -     | ns  |
| External           | clock                                                           |                                               |                      |                                       |       |       |     |
| t <sub>CHCX</sub>  | HIGH time                                                       | see Figure 13                                 | 33                   | $t_{CLCL} - t_{CLCX}$                 | 33    | -     | ns  |
| t <sub>CLCX</sub>  | LOW time                                                        | see Figure 13                                 | 33                   | t <sub>CLCL</sub> – t <sub>CHCX</sub> | 33    | -     | ns  |
| t <sub>CLCH</sub>  | rise time                                                       | see Figure 13                                 | -                    | 8                                     | -     | 8     | ns  |
| t <sub>CHCL</sub>  | fall time                                                       | see Figure 13                                 | -                    | 8                                     | -     | 8     | ns  |
| Shift regi         | ster (UART mode 0)                                              |                                               |                      |                                       |       |       |     |
| t <sub>XLXL</sub>  | serial port clock cycle time                                    |                                               | 16 t <sub>CLCL</sub> | -                                     | 1333  | -     | ns  |
| t <sub>QVXH</sub>  | output data set-up to clock rising edge                         |                                               | 13 t <sub>CLCL</sub> | -                                     | 1083  | -     | ns  |
| t <sub>XHQX</sub>  | output data hold after clock rising edge                        |                                               | -                    | t <sub>CLCL</sub> + 20                | -     | 103   | ns  |
| t <sub>XHDX</sub>  | input data hold after clock rising edge                         |                                               | -                    | 0                                     | -     | 0     | ns  |
| t <sub>DVXH</sub>  | input data valid to clock rising edge                           |                                               | 150                  | -                                     | 150   | -     | ns  |

[1] Parameters are valid over operating temperature range unless otherwise specified. Parts are tested to 2 MHz, but are guaranteed to operate down to 0 Hz.

8-bit microcontrollers with two-clock 80C51 core



#### Fig 12. Shift register mode timing.



### Table 11: AC characteristics, ISP entry mode

 $V_{DD}$  = 2.4 V to 3.6 V, unless otherwise specified.

 $T_{amb} = -40 \circ C$  to +85  $\circ C$  for industrial, unless otherwise specified.

| Symbol          | Parameter                                                 | Conditions | Min | Тур | Max | Unit |
|-----------------|-----------------------------------------------------------|------------|-----|-----|-----|------|
| t <sub>VR</sub> | $\overline{\text{RST}}$ delay from V <sub>DD</sub> active |            | 50  | -   | -   | μs   |
| t <sub>RH</sub> | RST HIGH time                                             |            | 1   | -   | 32  | μs   |
| t <sub>RL</sub> | RST LOW time                                              |            | 1   | -   | -   | μs   |



### 8-bit microcontrollers with two-clock 80C51 core

## 13. Package outline



### Fig 15. TSSOP20 (SOT360-1).

8-bit microcontrollers with two-clock 80C51 core



#### DIP20: plastic dual in-line package; 20 leads (300 mil)

## Fig 16. DIP20 (SOT146-1).

8-bit microcontrollers with two-clock 80C51 core

## Contents

| 1              | General description                          | . 1 | 8.1         |
|----------------|----------------------------------------------|-----|-------------|
| 2              | Features                                     | . 1 | 8.1         |
| 2.1            | Principal features                           | . 1 | 8.1         |
| 2.2            | Additional features                          |     | 8.1         |
| 3              | Ordering information                         | . 3 | 8.1         |
| 3.1            | Ordering options                             |     | 8.1         |
| 4              | Block diagram                                |     | 8.1         |
| -              | -                                            |     | 8.1         |
| 5              | Pinning information                          |     | 8.1<br>8.1  |
| 5.1            | Pinning                                      |     | o. 1<br>8.1 |
| 5.2            | Pin description                              |     | 8.1         |
| 6              | Logic symbol                                 |     | 8.1         |
| 7              | Special function registers                   | . 9 | 0.1         |
| 8              | Functional description                       | 14  | 8.1         |
| 8.1            | Enhanced CPU                                 | 14  |             |
| 8.2            | Clocks                                       | 14  | 8.1         |
| 8.2.1          | Clock definitions                            |     | 8.2         |
| 8.2.2          | CPU clock (OSCCLK)                           |     | 8.2         |
| 8.2.3          | Low speed oscillator option                  | 14  | 8.2         |
| 8.2.4          | Medium speed oscillator option               | 14  | 8.2         |
| 8.2.5          | High speed oscillator option                 | 14  | 8.2         |
| 8.2.6          | Clock output                                 | 15  | 8.2         |
| 8.3            | On-chip RC oscillator option                 |     | 8.2         |
| 8.4            | Watchdog oscillator option                   |     | 8.2         |
| 8.5            | External clock input option                  |     | 8.2         |
| 8.6            | CPU Clock (CCLK) wake-up delay               |     | 8.2         |
| 8.7            | CPU Clock (CCLK) modification: DIVM register |     | 8.2         |
| 8.8            | Low power select                             | 17  | 8.2         |
| 8.9            | Memory organization                          |     | 8.2         |
| 8.10           | Data RAM arrangement                         |     |             |
| 8.11           | Interrupts                                   | 18  | 8.2         |
| 8.11.1         | External interrupt inputs                    |     | 8.2         |
| 8.12           | I/O ports                                    |     | 9           |
| 8.12.1         | Port configurations                          | 19  | 10          |
| 8.12.2         | Quasi-bidirectional output configuration     |     | 11          |
| 8.12.3         | Open-drain output configuration.             |     |             |
| 8.12.4         | Input-only configuration                     |     | 12          |
| 8.12.5         | Push-pull output configuration               |     | 13          |
| 8.12.6         | Port 0 analog functions                      |     | 14          |
| 8.12.7<br>8.13 | Additional port features                     |     | 15          |
| 8.13.1         | Brownout detection                           |     | 16          |
| 8.13.1         | Power-on detection                           |     | 17          |
| 8.14           | Power reduction modes                        |     |             |
| 8.14.1         | Idle mode                                    | 22  | 18          |
| 8.14.1         | Power-down mode                              |     |             |
| 8.14.3         | Total Power-down mode                        |     |             |
| 8.15           | Reset                                        |     |             |
| 8.15.1         | Reset vector                                 |     |             |
| 8.16           | Timers/counters 0 and 1                      |     |             |
| 8.16.1         | Mode 0                                       |     |             |
| 8.16.2         | Mode 1                                       |     |             |
| 8.16.3         | Mode 2                                       |     |             |
| 8.16.4         | Mode 3                                       |     |             |
| 2              |                                              | - · |             |

## © Koninklijke Philips Electronics N.V. 2004. Printed in the U.S.A.

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner.

The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.

Date of release: 15 December 2004

| 8.16.5           | Mode 6                                                              |
|------------------|---------------------------------------------------------------------|
| 8.16.6           | Timer overflow toggle output                                        |
| 8.17             | Real-Time clock/system timer                                        |
| 8.18             | UART 24                                                             |
| 8.18.1           | Mode 0                                                              |
| 8.18.2           | Mode 1                                                              |
| 8.18.3           | Mode 2                                                              |
| 8.18.4           | Mode 3                                                              |
| 8.18.5           | Baud rate generator and selection                                   |
| 8.18.6           | Framing error                                                       |
| 8.18.7           | Break detect                                                        |
| 8.18.8           | Double buffering                                                    |
| 8.18.9           | Transmit interrupts with double buffering                           |
|                  | enabled (Modes 1, 2 and 3)                                          |
| 8.18.10          | The 9 <sup>th</sup> bit (bit 8) in double buffering (Modes 1, 2 and |
|                  | 3)                                                                  |
| 8.19             | I <sup>2</sup> C-bus serial interface                               |
| 8.20             | Analog comparators                                                  |
| 8.20.1           | Internal reference voltage                                          |
| 8.20.2           | Comparator interrupt                                                |
| 8.20.3           | Comparators and power reduction modes                               |
| 8.21             | Keypad interrupt (KBI)                                              |
| 8.22             | Watchdog timer                                                      |
| 8.23             | Additional features                                                 |
| 8.23.1           | Software reset                                                      |
| 8.23.2           | Dual data pointers                                                  |
| 8.24<br>8.24.1   | Flash program memory                                                |
| 8.24.1<br>8.24.2 | General description                                                 |
| 8.24.2<br>8.24.3 | Features                                                            |
| 0.24.3           | the P89LPC920/921/922/9221                                          |
| 8.25             | User configuration bytes                                            |
| 8.25<br>8.26     | User sector security bytes                                          |
|                  |                                                                     |
| 9                | Limiting values 35                                                  |
| 10               | Static characteristics 36                                           |
| 11               | Dynamic characteristics 38                                          |
| 12               | Comparator electrical characteristics 41                            |
| 13               | Package outline                                                     |
| 14               | Revision history 44                                                 |
| 15               | Data sheet status                                                   |
| 16               | Definitions                                                         |
| 17               | Disclaimers 45                                                      |
| 18               | Licenses                                                            |
|                  |                                                                     |



Let's make things better.