# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



8-bit microcontrollers with two-clock 80C51 core 1 kB 3 V Flash with 128-byte RAM

Rev. 05 — 17 December 2004

**Product data** 

### 1. General description

The P89LPC901/902/903 are single-chip microcontrollers in low-cost 8-pin packages, based on a high performance processor architecture that executes instructions in two to four clocks, six times the rate of standard 80C51 devices. Many system-level functions have been incorporated into the P89LPC901/902/903 in order to reduce component count, board space, and system cost.

### 2. Features

### 2.1 Principal features

- 1 kB byte-erasable Flash code memory organized into 256-byte sectors and 16-byte pages. Single-byte erasing allows any byte(s) to be used as non-volatile data storage.
- 128-byte RAM data memory.
- Two 16-bit counter/timers. (P89LPC901 Timer 0 may be configured to toggle a port output upon timer overflow or to become a PWM output.)
- 23-bit system timer that can also be used as a Real-Time clock.
- Two analog comparators (P89LPC902 and P89LPC903, single analog comparator on P89LPC901).
- Enhanced UART with fractional baudrate generator, break detect, framing error detection, automatic address detection and versatile interrupt capabilities (P89LPC903).
- High-accuracy internal RC oscillator option allows operation without external oscillator components. The RC oscillator (factory calibrated to ±1 %) option is selectable and fine tunable.
- 2.4 V to 3.6 V V<sub>DD</sub> operating range with 5 V tolerant I/O pins (may be pulled up or driven to 5.5 V). Industry-standard pinout with V<sub>DD</sub>, V<sub>SS</sub>, and reset at locations 1, 8, and 4.
- Up to six I/O pins when using internal oscillator and reset options.
- 8-pin SO-8 package.

### 2.2 Additional features

- 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 (167 ns to 333 ns at 12 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 (IAP-Lite) and byte erase allows code memory to be used for non-volatile data storage.





- Serial Flash In-Circuit Programming (ICP) allows simple production coding with commercial EPROM programmers. 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 8 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.
- Configurable on-chip oscillator with frequency range options selected by user programmed Flash configuration bits. Oscillator options support frequencies from 20 kHz to the maximum operating frequency of 18 MHz (P89LPC901).
- Watchdog timer with separate on-chip oscillator, requiring no external components. The watchdog prescaler is selectable from 8 values.
- 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.
- 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 P89LPC901/902/903 when internal reset option is selected.
- Four interrupt priority levels.
- Two (P89LPC901), three (P89LPC903), or five (P89LPC902) keypad interrupt inputs.
- Second data pointer.
- Schmitt trigger port inputs.
- Emulation support.

### 3. Ordering information

| Type number | ng information Package |                                                 |         |  |  |  |  |  |  |  |
|-------------|------------------------|-------------------------------------------------|---------|--|--|--|--|--|--|--|
|             | Name                   | Description                                     | Version |  |  |  |  |  |  |  |
| P89LPC901FD | SO8                    | plastic small outline package; 8 leads;         | SOT96-1 |  |  |  |  |  |  |  |
| P89LPC902FD |                        | body width 7.5 mm                               |         |  |  |  |  |  |  |  |
| P89LPC903FD |                        |                                                 |         |  |  |  |  |  |  |  |
| P89LPC901FN | DIP8                   | plastic dual in-line package; 8 leads (300 mil) | SOT97-1 |  |  |  |  |  |  |  |
| P89LPC902FN |                        |                                                 |         |  |  |  |  |  |  |  |

### 3.1 Ordering options

| Table 2:   Part options |                   |                         |
|-------------------------|-------------------|-------------------------|
| Type number             | Temperature range | Frequency               |
| P89LPC901xx             | –40 °C to +85 °C  | 0 MHz to 18 MHz         |
| P89LPC902xx             |                   | Internal RC or watchdog |
| P89LPC903xx             |                   | Internal RC or watchdog |

8-bit microcontrollers with two-clock 80C51 core

### 4. Block diagram



8-bit microcontrollers with two-clock 80C51 core



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



8-bit microcontrollers with two-clock 80C51 core

### 5. Pinning information

### 5.1 Pinning





| V <sub>DD</sub> 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| P0.2/CIN2A/KBI2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 7 P0.4/CIN1A/KBI4                                                                                                     |
| P0.0/CMP2/KBI0 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | G:       VSS         7       P0.4/CIN1A/KBI4         6       P0.5/CMPREF/KBI5         88       5       P0.6/CMP1/KBI6 |
| RST/P1.5 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5 P0.6/CMP1/KBI6                                                                                                      |
| La construction de la constructi | 002aaa439                                                                                                             |
| Fig 6. P89LPC902 pinning (SO8).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                       |



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



### 5.2 Pin description

| Table 3:   | P89LPC901 | pin descrip | tion                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol     | Pin       | Туре        | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.0 to P0 | ).6       | I/O         | <b>Port 0:</b> Port 0 is an I/O port with a user-configurable output type. During reset Port 0 latches are configured in the input only mode with the internal pull-up disabled. The operation of Port 0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to Section 8.12.1 "Port configurations" and Table 13 "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:                                                                                                                                                                                                                                                                                                                                                                   |
|            | 7         | I/O         | <b>P0.4</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |           | I           | CIN1A — Comparator 1 positive input.                                                                                                                                                                                                                                                                                                                                                                                                 |
|            |           | Ι           | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                             |
|            | 6         | I/O         | <b>P0.5</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |           | Ι           | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                               |
|            |           | I           | KBI5 — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                             |

| Symbol          | Pin | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1.0 to P1.5    |     |      | <b>Port 1:</b> Port 1 is an I/O port with a user-configurable output type. 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 13 "DC electrical characteristics" for details. P1.5 is input only.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 |     |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 |     |      | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 5   | I/O  | P1.2 — Port 1 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 |     | 0    | T0 — Timer/counter 0 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 | 4   | I    | P1.5 — Port 1 bit 5 (input only).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| P3.0 to P3.1    |     | 1    | <b>RST</b> — External Reset input during Power-on or if selected via UCFG1. When functioning as a reset input 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. Also used during a power-on sequence to force In-System Programming mode. |
| P3.0 to P3.1    |     | I/O  | <b>Port 3:</b> Port 3 is an I/O port with a user-configurable output types. During reset Port 3 latches are configured in the input only mode with the internal pull-up disabled. The operation of port 3 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to Section 8.12.1 "Port configurations" and Table 13 "DC electrical characteristics" for details. All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |     |      | Port 3 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                 | 3   | I/O  | <b>P3.0</b> — Port 3 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 |     | 0    | <b>XTAL2</b> — Output from the oscillator amplifier (when a crystal oscillator option is selected via the FLASH configuration).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 |     | 0    | <b>CLKOUT</b> — CPU clock divided by 2 when enabled via SFR bit (ENCLK to TRIM.6). It can be used if the CPU clock is the internal RC oscillator, Watchdog oscillator or external clock input, except when XTAL1/XTAL2 are used to generate clock source for the real time clock/system timer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 | 2   | I/O  | <b>P3.1</b> — Port 3 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 |     | Ι    | <b>XTAL1</b> — Input to the oscillator circuit and internal clock generator circuits (when selected via the FLASH configuration). It can be a port pin if internal RC oscillator or Watchdog oscillator is used as the CPU clock source, <b>and</b> if XTAL1/XTAL2 are not used to generate the clock for the real time clock/system timer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V <sub>SS</sub> | 8   | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| V <sub>DD</sub> | 1   | I    | <b>Power Supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Table 3: P89LPC901 pin description...continued

| Symbol                        | ן P89LPC902<br>Pin | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------|--------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Symbol</b><br>P0.0 to P0.6 |                    | l/O  | <b>Port 0:</b> Port 0 is an I/O port with a user-configurable output type. During reset Port 0                                                                                                                                                                                                                                                                                                                                                                                                  |
|                               |                    |      | latches are configured in the input only mode with the internal pull-up disabled. The operation of Port 0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to Section 8.12.1 "Port configurations" and Table 13 "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:                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                               | 3                  | I/O  | <b>P0.0</b> — Port 0 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | CMP2 — Comparator 2 output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | KBI0 — Keyboard input 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                               | 2                  | I/O  | P0.2 — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                               |                    | Ι    | <b>CIN2A</b> — Comparator 2 positive input.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                               | 7                  | I/O  | <b>P0.4</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | CIN1A — Comparator 1 positive input.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                               |                    | Ι    | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                               | 6                  | I/O  | <b>P0.5</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                               |                    | Ι    | KBI5 — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                               | 5                  | I/O  | <b>P0.6</b> — Port 0 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | 0    | CMP1 — Comparator 1 output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                               |                    | Ι    | KBI6 — Keyboard input 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| P1.0 to P1.                   | 5                  |      | <b>Port 1:</b> Port 1 is an I/O port with a user-configurable output type. 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 13 "DC electrical characteristics" for details. P1.5 is input only. |
|                               |                    |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                               |                    |      | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                               | 4                  | I    | P1.5 — Port 1 bit 5 (input only).                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                               |                    | I    | <b>RST</b> — External Reset input during Power-on or if selected via UCFG1. When functioning as a reset input 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. Also used during a power-on sequence to force In-System Programming mode.                                                                                                                                       |
| V <sub>SS</sub>               | 8                  | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V <sub>DD</sub>               | 1                  | Ι    | <b>Power Supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                                                                                                                                                                                |

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

| Table 5:        | P89LPC903 pin description |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|-----------------|---------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Symbol          | Pin                       | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| P0.0 to P0.     | 6                         | I/O  | <b>Port 0:</b> Port 0 is an I/O port with a user-configurable output type. During reset Port 0 latches are configured in the input only mode with the internal pull-up disabled. The operation of Port 0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to Section 8.12.1 "Port configurations" and Table 13 "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:                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|                 | 2                         | I/O  | <b>P0.2</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | Ι    | <b>CIN2A</b> — Comparator 2 positive input.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | Ι    | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|                 | 7                         | I/O  | <b>P0.4</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | Ι    | <b>CIN1A</b> — Comparator 1 positive input.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | Ι    | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|                 | 6                         | I/O  | <b>P0.5</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | I    | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|                 |                           | I    | KBI5 — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| P1.0 to P1.     | 5                         |      | <b>Port 1:</b> Port 1 is an I/O port with a user-configurable output type. 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 13 "DC electrical characteristics" for details. P1.5 is input only. |  |  |  |  |  |  |  |  |
|                 |                           |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                 |                           |      | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|                 | 5                         | I/O  | <b>P1.0</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | 0    | TxD — Serial port transmitter data.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|                 | 3                         | I/O  | <b>P1.1</b> — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                 |                           | Ι    | <b>RxD</b> — Serial port receiver data.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                 | 4                         | Ι    | P1.5 — Port 1 bit 5 (input only).                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                 |                           | I    | <b>RST</b> — External Reset input during Power-on or if selected via UCFG1. When functioning as a reset input 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. Also used during a power-on sequence to force In-System Programming mode.                                                                                                                                       |  |  |  |  |  |  |  |  |
| V <sub>SS</sub> | 8                         | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
| V <sub>DD</sub> | 1                         | I    | <b>Power Supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|                 |                           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |

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

### 6. Logic symbols







Table 6 highlights the differences between these three devices. For a complete list of device features, please see Section 2 "Features" on page 1.

Table 6:Product comparison overview

| Type number | External     | CLKOUT output | T0 PWM output | CMP2 input | CMP1 and     | UART |     |
|-------------|--------------|---------------|---------------|------------|--------------|------|-----|
|             | crystal pins |               |               |            | CMP2 outputs | TxD  | Rxd |
| P89LPC901xx | Х            | Х             | Х             | -          | -            | -    | -   |
| P89LPC902xx | -            | -             | -             | Х          | Х            | -    | -   |
| P89LPC903xx | -            | -             | -             | Х          | -            | Х    | Х   |

### 7. Special function registers

**Remark:** Special Function Registers (SFRs) accesses are restricted in the following ways:

- User must not attempt to access any SFR locations not defined.
- Accesses to any defined SFR locations must be strictly for the functions for the SFRs.
- SFR bits labeled '-', '0' or '1' can **only** be written and read as follows:
  - '-' Unless otherwise specified, **must** be written with '0', but can return any value when read (even if it was written with '0'). It is a reserved bit and may be used in future derivatives.
  - '0' **must** be written with '0', and will return a '0' when read.
  - '1' **must** be written with '1', and will return a '1' when read.

## Table 7:P89LPC901 Special function registers\* indicates SFRs that are bit addressable.

| Name   | Description                      | SFR         | Bit functions and addresses |             |             |             |             |             |              |             |                   | Reset value |  |  |
|--------|----------------------------------|-------------|-----------------------------|-------------|-------------|-------------|-------------|-------------|--------------|-------------|-------------------|-------------|--|--|
|        |                                  | addr.       | MSB                         |             |             |             |             |             |              | LSB         | Hex               | Binary      |  |  |
|        |                                  | Bit address | E7                          | <b>E6</b>   | <b>E</b> 5  | <b>E4</b>   | <b>E3</b>   | <b>E2</b>   | E1           | <b>E0</b>   |                   |             |  |  |
| ACC*   | Accumulator                      | E0H         |                             |             |             |             |             |             |              |             | 00                | 00000000    |  |  |
| AUXR1  | Auxiliary function register      | A2H         | CLKLP                       | -           | -           | ENT0        | SRST        | 0           | -            | DPS         | 00 <sup>[1]</sup> | 000000x0    |  |  |
|        |                                  | Bit address | F7                          | <b>F6</b>   | F5          | <b>F</b> 4  | <b>F3</b>   | F2          | F1           | F0          |                   |             |  |  |
| B*     | B register                       | F0H         |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| CMP1   | Comparator 1 control reg         | ister ACH   | -                           | -           | CE1         | -           | CN1         | -           | CO1          | CMF1        | 00[1]             | xx000000    |  |  |
| DIVM   | CPU clock divide-by-M<br>control | 95H         |                             |             |             |             |             |             |              |             | 00                | 00000000    |  |  |
| DPTR   | Data pointer (2 bytes)           |             |                             |             |             |             |             |             |              |             |                   |             |  |  |
| DPH    | Data pointer high                | 83H         |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| DPL    | Data pointer low                 | 82H         |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| FMADRH | Program Flash address h          | igh E7H     |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| FMADRL | Program Flash address lo         | w E6H       |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| FMCON  | Program Flash Control<br>(Read)  | E4H         | BUSY                        | -           | -           | -           | HVA         | HVE         | SV           | OI          | 70                | 01110000    |  |  |
|        | Program Flash Control<br>(Write) |             | FMCMD.<br>7                 | FMCMD.<br>6 | FMCMD.<br>5 | FMCMD.<br>4 | FMCMD.<br>3 | FMCMD.<br>2 | FMCMD.<br>1  | FMCMD.<br>0 | _                 |             |  |  |
| FMDATA | Program Flash data               | E5H         |                             |             |             |             |             |             |              |             | 00                | 0000000     |  |  |
| IEN0*  | Interrupt enable 0               | A8H         | EA                          | EWDRT       | EBO         | -           | ET1         | -           | ET0          | -           | 00                | 0000000     |  |  |
|        |                                  | Bit address | EF                          | EE          | ED          | EC          | EB          | EA          | <b>E9</b>    | <b>E</b> 8  |                   |             |  |  |
| IEN1*  | Interrupt enable 1               | E8H         | -                           | -           | -           | -           | -           | EC          | EKBI         | -           | 00[1]             | 00x0000     |  |  |
|        |                                  | Bit address | BF                          | BE          | BD          | BC          | BB          | BA          | <b>B</b> 9   | <b>B</b> 8  |                   |             |  |  |
| IP0*   | Interrupt priority 0             | B8H         | -                           | PWDRT       | PBO         | -           | PT1         | -           | PT0          | -           | 00[1]             | x000000     |  |  |
| IP0H   | Interrupt priority 0 high        | B7H         | -                           | PWDRT<br>H  | PBOH        | -           | PT1H        | -           | PT0H         | -           | 00[1]             | x0000000    |  |  |
|        |                                  | Bit address | FF                          | FE          | FD          | FC          | FB          | FA          | <b>F</b> 9   | <b>F</b> 8  |                   |             |  |  |
| IP1*   | Interrupt priority 1             | F8H         | -                           | -           | -           | -           | -           | PC          | PKBI         | -           | 00 <sup>[1]</sup> | 00x0000     |  |  |
| IP1H   | Interrupt priority 1 high        | F7H         | -                           | -           | -           | -           | -           | PCH         | PKBIH        | -           | 00 <sup>[1]</sup> | 00x0000     |  |  |
| KBCON  | Keypad control register          | 94H         | -                           | -           | -           | -           | -           | -           | PATN<br>_SEL | KBIF        | 00 <sup>[1]</sup> | xxxxxx00    |  |  |

8-bit microcontrollers with two-clock 80C51 core

P89LPC901/902/903

9397 750 14 Product data

## Table 7:P89LPC901 Special function registers...continued\* indicates SFRs that are bit addressable.

| Name   | Description                             | SFR         |            |           | Reset value    |               |            |           |          |           |                          |          |
|--------|-----------------------------------------|-------------|------------|-----------|----------------|---------------|------------|-----------|----------|-----------|--------------------------|----------|
|        |                                         | addr.       | MSB        |           |                |               |            |           |          | LSB       | Hex                      | Binary   |
| KBMASK | Keypad interrupt mask register          | 86H         |            |           |                |               |            |           |          |           | 00                       | 0000000  |
| KBPATN | Keypad pattern register                 | 93H         |            |           |                |               |            |           |          |           | FF                       | 1111111  |
|        |                                         | Bit address | 87         | 86        | 85             | 84            | 83         | 82        | 81       | 80        |                          |          |
| P0*    | Port 0                                  | 80H         | -          | -         | CMPREF<br>/KB5 | CIN1A<br>/KB4 | -          | -         | -        | -         | [1]                      |          |
|        |                                         | Bit address | 97         | 96        | 95             | 94            | 93         | 92        | 91       | 90        |                          |          |
| P1*    | Port 1                                  | 90H         | -          | -         | RST            | -             | -          | Т0        | -        | -         | [1]                      |          |
|        |                                         | Bit address | <b>B</b> 7 | <b>B6</b> | <b>B</b> 5     | <b>B</b> 4    | <b>B</b> 3 | <b>B2</b> | B1       | <b>B0</b> |                          |          |
| P3*    | Port 3                                  | B0H         | -          | -         | -              | -             | -          | -         | XTAL1    | XTAL2     | [1]                      |          |
| P0M1   | Port 0 output mode 1                    | 84H         | -          | -         | (P0M1.5)       | (P0M1.4)      | -          | -         | -        | -         | FF                       | 1111111  |
| P0M2   | Port 0 output mode 2                    | 85H         | -          | -         | (P0M2.5)       | (P0M2.4)      | -          | -         | -        | -         | 00                       | 0000000  |
| P1M1   | Port 1 output mode 1                    | 91H         | -          | -         | (P1M1.5)       | -             | -          | (P1M1.2)  | -        | -         | FF <sup>[1]</sup>        | 1111111  |
| P1M2   | Port 1 output mode 2                    | 92H         | -          | -         | (P1M2.5)       | -             | -          | (P1M2.2)  | -        | -         | 00[1]                    | 0000000  |
| P3M1   | Port 3 output mode 1                    | B1H         | -          | -         | -              | -             | -          | -         | (P3M1.1) | (P3M1.0)  | 03[1]                    | xxxxxx11 |
| P3M2   | Port 3 output mode 2                    | B2H         | -          | -         | -              | -             | -          | -         | (P3M2.1) | (P3M2.0)  | 00[1]                    | xxxxxx00 |
| PCON   | Power control register                  | 87H         | -          | -         | BOPD           | BOI           | GF1        | GF0       | PMOD1    | PMOD0     | 00                       | 0000000  |
| PCONA  | Power control register A                | B5H         | RTCPD      |           | VCPD           |               |            | -         | -        |           | 00[1]                    | 0000000  |
| PCONB  | reserved for Power Contro<br>Register B | ol B6H      | -          | -         | -              | -             | -          | -         | -        | -         | 00[1]                    | XXXXXXXX |
|        |                                         | Bit address | D7         | <b>D6</b> | D5             | D4            | D3         | D2        | D1       | <b>D0</b> |                          |          |
| PSW*   | Program status word                     | D0H         | CY         | AC        | F0             | RS1           | RS0        | OV        | F1       | Р         | 00                       | 0000000  |
| PT0AD  | Port 0 digital input disable            | e F6H       | -          | -         | PT0AD.5        | PT0AD.4       | -          | -         | -        | -         | 00                       | xx00000x |
| RSTSRC | Reset source register                   | DFH         | -          | -         | BOF            | POF           | -          | R_WD      | R_SF     | R_EX      | [3]                      |          |
| RTCCON | Real-time clock control                 | D1H         | RTCF       | RTCS1     | RTCS0          | -             | -          | -         | ERTC     | RTCEN     | 60 <sup>[1]</sup><br>[6] | 011xxx00 |
| RTCH   | Real-time clock register h              | igh D2H     |            |           |                |               |            |           |          |           | 00 <mark>[6]</mark>      | 0000000  |
| RTCL   | Real-time clock register lo             | ow D3H      |            |           |                |               |            |           |          |           | 00 <mark>[6]</mark>      | 0000000  |
| SP     | Stack pointer                           | 81H         |            |           |                |               |            |           |          |           | 07                       | 0000011  |
| TAMOD  | Timer 0 auxiliary mode                  | 8FH         | -          | -         | -              | -             | -          | -         | -        | T0M2      | 00                       | xxx0xxx0 |

8-bit microcontrollers with two-clock 80C51 core

P89LPC901/902/903

9397 750 Product data

Rev. 05 — 17 December 2004

#### Table 7: P89LPC901 Special function registers...continued

\* indicates SFRs that are bit addressable.

| Name   | Description                       | SFR    | Bit functions and addresses |      |        |            |        |           |        |        | Reset value |          |  |
|--------|-----------------------------------|--------|-----------------------------|------|--------|------------|--------|-----------|--------|--------|-------------|----------|--|
|        | addr.                             | MSB    |                             |      |        |            |        |           | LSB    | Hex    | Binary      |          |  |
|        | Bit a                             | ddress | 8F                          | 8E   | 8D     | 8 <b>C</b> | 8B     | <b>8A</b> | 89     | 88     |             |          |  |
| TCON*  | Timer 0 and 1 control             | 88H    | TF1                         | TR1  | TF0    | TR0        | -      | -         | -      | -      | 00          | 00000000 |  |
| TH0    | Timer 0 high                      | 8CH    |                             |      |        |            |        |           |        |        | 00          | 00000000 |  |
| TH1    | Timer 1 high                      | 8DH    |                             |      |        |            |        |           |        |        | 00          | 00000000 |  |
| TL0    | Timer 0 low                       | 8AH    |                             |      |        |            |        |           |        |        | 00          | 00000000 |  |
| TL1    | Timer 1 low                       | 8BH    |                             |      |        |            |        |           |        |        | 00          | 00000000 |  |
| TMOD   | Timer 0 and 1 mode                | 89H    | -                           | -    | T1M1   | T1M0       | -      | -         | T0M1   | T0M0   | 00          | 00000000 |  |
| TRIM   | Internal oscillator trim register | 96H    | -                           | -    | TRIM.5 | TRIM.4     | TRIM.3 | TRIM.2    | TRIM.1 | TRIM.0 | [5] [6]     |          |  |
| WDCON  | Watchdog control register         | A7H    | PRE2                        | PRE1 | PRE0   | -          | -      | WDRUN     | WDTOF  | WDCLK  | [4] [6]     |          |  |
| WDL    | Watchdog load                     | C1H    |                             |      |        |            |        |           |        |        | FF          | 11111111 |  |
| WFEED1 | Watchdog feed 1                   | C2H    |                             |      |        |            |        |           |        |        |             |          |  |
| WFEED2 | Watchdog feed 2                   | СЗН    |                             |      |        |            |        |           |        |        |             |          |  |

[1] All ports are in input only (high impedance) state after power-up.

[2] BRGR1 and BRGR0 must only be written if BRGEN in BRGCON SFR is '0'. If any are written while BRGEN = 1, the result is unpredictable. Unimplemented bits in SFRs (labeled '-') are X (unknown) at all times. Unless otherwise specified, ones should not be written to these bits since they may be used for other purposes in future derivatives. The reset values shown for these bits are '0's although they are unknown when read.

- [3] The RSTSRC register reflects the cause of the P89LPC901/902/903 reset. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on reset value is xx110000.
- [4] After reset, the value is 111001x1, i.e., PRE2-PRE0 are all '1', WDRUN = 1 and WDCLK = 1. WDTOF bit is '1' after Watchdog reset and is '0' after power-on reset. Other resets will not affect WDTOF.

[5] On power-on reset, the TRIM SFR is initialized with a factory preprogrammed value. Other resets will not cause initialization of the TRIM register.

[6] The only reset source that affects these SFRs is power-on reset.

9397 750 14465 Product data

**89** 

υ

C901/902/903

P89LPC901/902/903

## Table 8:P89LPC902 Special function registers\* indicates SFRs that are bit addressable.

| Name   | Description                      | SFR         | Bit functions and addresses |             |             |             |             |             |             |             |                   | Reset value |  |
|--------|----------------------------------|-------------|-----------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------------|-------------|--|
|        |                                  | addr.       | MSB                         |             |             |             |             |             |             | LSB         | Hex               | Binary      |  |
|        |                                  | Bit address | E7                          | <b>E6</b>   | <b>E</b> 5  | <b>E4</b>   | <b>E3</b>   | <b>E2</b>   | E1          | <b>E0</b>   |                   |             |  |
| ACC*   | Accumulator                      | E0H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| AUXR1  | Auxiliary function registe       | er A2H      | -                           | -           | -           | -           | SRST        | 0           | -           | DPS         | 00 <sup>[1]</sup> | 000000      |  |
|        |                                  | Bit address | F7                          | <b>F6</b>   | F5          | F4          | F3          | F2          | F1          | F0          |                   |             |  |
| B*     | B register                       | F0H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| CMP1   | Comparator 1 control re          | gister ACH  | -                           | -           | CE1         | -           | CN1         | OE1         | CO1         | CMF1        | 00 <sup>[1]</sup> | xx0000      |  |
| CMP2   | Comparator 2 control re          | gister ADH  | -                           | -           | CE2         | -           | CN2         | OE2         | CO2         | CMF2        | 00 <sup>[1]</sup> | xx0000      |  |
| DIVM   | CPU clock divide-by-M<br>control | 95H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| DPTR   | Data pointer (2 bytes)           |             |                             |             |             |             |             |             |             |             |                   |             |  |
| DPH    | Data pointer high                | 83H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| DPL    | Data pointer low                 | 82H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| FMADRH | Program Flash address            | high E7H    |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| FMADRL | Program Flash address            | low E6H     |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| FMCON  | Program Flash Control (Read)     | E4H         | BUSY                        | -           | -           | -           | HVA         | HVE         | SV          | OI          | 70                | 011100      |  |
|        | Program Flash Control<br>(Write) |             | FMCMD.<br>7                 | FMCMD.<br>6 | FMCMD.<br>5 | FMCMD.<br>4 | FMCMD.<br>3 | FMCMD.<br>2 | FMCMD.<br>1 | FMCMD.<br>0 |                   |             |  |
| FMDATA | Program Flash data               | E5H         |                             |             |             |             |             |             |             |             | 00                | 000000      |  |
| IEN0*  | Interrupt enable 0               | A8H         | EA                          | EWDRT       | EBO         | -           | ET1         | -           | ET0         | -           | 00                | 000000      |  |
|        |                                  | Bit address | EF                          | EE          | ED          | EC          | EB          | EA          | <b>E9</b>   | <b>E</b> 8  |                   |             |  |
| IEN1*  | Interrupt enable 1               | E8H         | -                           | -           | -           | -           | -           | EC          | EKBI        | -           | 00 <sup>[1]</sup> | 00x000      |  |
|        |                                  | Bit address | BF                          | BE          | BD          | BC          | BB          | BA          | <b>B</b> 9  | <b>B</b> 8  |                   |             |  |
| IP0*   | Interrupt priority 0             | B8H         | -                           | PWDRT       | PBO         | -           | PT1         | -           | PT0         | -           | 00 <sup>[1]</sup> | x00000      |  |
| IP0H   | Interrupt priority 0 high        | B7H         | -                           | PWDRT<br>H  | РВОН        | -           | PT1H        | -           | PT0H        | -           | 00 <sup>[1]</sup> | x00000      |  |
|        |                                  | Bit address | FF                          | FE          | FD          | FC          | FB          | FA          | <b>F9</b>   | <b>F</b> 8  |                   |             |  |
| IP1*   | Interrupt priority 1             | F8H         | -                           | -           | -           | -           | -           | PC          | PKBI        | -           | 00 <sup>[1]</sup> | 00x000      |  |
| IP1H   | Interrupt priority 1 high        | F7H         | -                           | -           | -           | -           | -           | PCH         | PKBIH       | -           | 00 <sup>[1]</sup> | 00x000      |  |

9397 750 14 Product data

## Table 8:P89LPC902 Special function registers...continued\* indicates SFRs that are bit addressable.

| Name   | Description                            | SFR         |       |              | Reset          | value         |           |           |              |            |                          |          |
|--------|----------------------------------------|-------------|-------|--------------|----------------|---------------|-----------|-----------|--------------|------------|--------------------------|----------|
|        |                                        | addr.       | MSB   |              |                |               |           |           |              | LSB        | Hex                      | Binary   |
| KBCON  | Keypad control register                | 94H         | -     | -            | -              | -             | -         | -         | PATN<br>_SEL | KBIF       | 00[1]                    | xxxxxx00 |
| KBMASK | Keypad interrupt mask<br>register      | 86H         |       |              |                |               |           |           |              |            | 00                       | 0000000  |
| KBPATN | Keypad pattern register                | 93H         |       |              |                |               |           |           |              |            | FF                       | 1111111  |
|        |                                        | Bit address | 87    | 86           | 85             | 84            | 83        | 82        | 81           | 80         |                          |          |
| P0*    | Port 0                                 | 80H         | -     | CMP1<br>/KB6 | CMPREF<br>/KB5 | CIN1A<br>/KB4 | -         | KB2       | -            | KB0        | [1]                      |          |
|        |                                        | Bit address | 97    | 96           | 95             | 94            | 93        | 92        | 91           | 90         |                          |          |
| P1*    | Port 1                                 | 90H         | -     | -            | RST            | -             | -         | -         | -            | -          |                          |          |
|        |                                        | Bit address | B7    | <b>B6</b>    | <b>B5</b>      | <b>B</b> 4    | <b>B3</b> | <b>B2</b> | B1           | <b>B</b> 0 |                          |          |
| P0M1   | Port 0 output mode 1                   | 84H         | -     | (P0M1.6)     | (P0M1.5)       | (P0M1.4)      | -         | (P0M1.2)  | -            | (P0M1.0)   | FF                       | 1111111  |
| P0M2   | Port 0 output mode 2                   | 85H         | -     | (P0M2.6)     | (P0M2.5)       | (P0M2.4)      | -         | (P0M2.2)  | -            | (P0M2.0)   | 00                       | 0000000  |
| P1M1   | Port 1 output mode 1                   | 91H         | -     | -            | (P1M1.5)       | -             | -         | -         | -            | -          | FF <sup>[1]</sup>        | 1111111  |
| P1M2   | Port 1 output mode 2                   | 92H         | -     | -            | (P1M2.5)       | -             | -         | -         | -            | -          | 00 <sup>[1]</sup>        | 0000000  |
| PCON   | Power control register                 | 87H         | -     | -            | BOPD           | BOI           | GF1       | GF0       | PMOD1        | PMOD0      | 00                       | 0000000  |
| PCONA  | Power control register A               | B5H         | RTCPD |              | VCPD           |               |           | -         | -            |            | 00 <sup>[1]</sup>        | 0000000  |
| PCONB  | reserved for Power Contr<br>Register B | rol B6H     | -     | -            | -              | -             | -         | -         | -            | -          | 00 <sup>[1]</sup>        | XXXXXXXX |
|        |                                        | Bit address | D7    | <b>D6</b>    | D5             | <b>D</b> 4    | D3        | D2        | D1           | <b>D</b> 0 |                          |          |
| PSW*   | Program status word                    | D0H         | CY    | AC           | F0             | RS1           | RS0       | OV        | F1           | Р          | 00                       | 0000000  |
| PT0AD  | Port 0 digital input disable           | e F6H       | -     | -            | PT0AD.5        | PT0AD.4       | -         | PT0AD.2   | -            | -          | 00                       | xx00000  |
| RSTSRC | Reset source register                  | DFH         | -     | -            | BOF            | POF           | -         | R_WD      | R_SF         | R_EX       | [3]                      |          |
| RTCCON | Real-time clock control                | D1H         | RTCF  | RTCS1        | RTCS0          | -             | -         | -         | ERTC         | RTCEN      | 60 <sup>[1]</sup><br>[6] | 011xxx0  |
| RTCH   | Real-time clock register h             | nigh D2H    |       |              |                |               |           |           |              |            | 00 <mark>[6]</mark>      | 0000000  |
| RTCL   | Real-time clock register I             | ow D3H      |       |              |                |               |           |           |              |            | 00 <mark>[6]</mark>      | 0000000  |
| SP     | Stack pointer                          | 81H         |       |              |                |               |           |           |              |            | 07                       | 0000011  |

8-bit microcontrollers with two-clock 80C51 core

P89LPC901/902/903

9397 750 -Product data

Rev. 05 — 17 December 2004

#### Table 8: P89LPC902 Special function registers...continued

| * indicates 3<br>Name | Description                      | SFR     |      |      | Reset value |        |        |            |        |        |         |          |
|-----------------------|----------------------------------|---------|------|------|-------------|--------|--------|------------|--------|--------|---------|----------|
|                       |                                  | addr.   | MSB  |      |             |        |        |            |        | LSB    | Hex     | Binary   |
|                       | Bit                              | address | 8F   | 8E   | 8D          | 8C     | 8B     | <b>8</b> A | 89     | 88     |         |          |
| TCON*                 | Timer 0 and 1 control            | 88H     | TF1  | TR1  | TF0         | TR0    | -      | -          | -      | -      | 00      | 0000000  |
| TH0                   | Timer 0 high                     | 8CH     |      |      |             |        |        |            |        |        | 00      | 00000000 |
| TH1                   | Timer 1 high                     | 8DH     |      |      |             |        |        |            |        |        | 00      | 00000000 |
| TL0                   | Timer 0 low                      | 8AH     |      |      |             |        |        |            |        |        | 00      | 00000000 |
| TL1                   | Timer 1 low                      | 8BH     |      |      |             |        |        |            |        |        | 00      | 00000000 |
| TMOD                  | Timer 0 and 1 mode               | 89H     | -    | -    | T1M1        | T1M0   | -      | -          | T0M1   | T0M0   | 00      | 00000000 |
| TRIM                  | Internal oscillator trim registe | r 96H   | -    | -    | TRIM.5      | TRIM.4 | TRIM.3 | TRIM.2     | TRIM.1 | TRIM.0 | [5] [6] |          |
| WDCON                 | Watchdog control register        | A7H     | PRE2 | PRE1 | PRE0        | -      | -      | WDRUN      | WDTOF  | WDCLK  | [4] [6] |          |
| WDL                   | Watchdog load                    | C1H     |      |      |             |        |        |            |        |        | FF      | 11111111 |
| WFEED1                | Watchdog feed 1                  | C2H     |      |      |             |        |        |            |        |        |         |          |
| WFEED2                | Watchdog feed 2                  | СЗН     |      |      |             |        |        |            |        |        |         |          |

[1] All ports are in input only (high impedance) state after power-up.

BRGR1 and BRGR0 must only be written if BRGEN in BRGCON SFR is '0'. If any are written while BRGEN = 1, the result is unpredictable. [2] Unimplemented bits in SFRs (labeled '-') are X (unknown) at all times. Unless otherwise specified, ones should not be written to these bits since they may be used for other purposes in future derivatives. The reset values shown for these bits are '0's although they are unknown when read.

- The RSTSRC register reflects the cause of the P89LPC901/902/903 reset. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on reset [3] value is xx110000.
- After reset, the value is 111001x1, i.e., PRE2-PRE0 are all '1', WDRUN = 1 and WDCLK = 1. WDTOF bit is '1' after Watchdog reset and is '0' after power-on reset. Other resets will [4] not affect WDTOF.
- On power-on reset, the TRIM SFR is initialized with a factory preprogrammed value. Other resets will not cause initialization of the TRIM register. [5]
- The only reset source that affects these SFRs is power-on reset. [6]

Product data

**89** 

υ

C901/902/903

## Table 9:P89LPC903 Special function registers\* indicates SFRs that are bit addressable.

| Name                 | Description                      | SFR        |             | Reset       | t value     |              |             |             |             |             |                     |          |
|----------------------|----------------------------------|------------|-------------|-------------|-------------|--------------|-------------|-------------|-------------|-------------|---------------------|----------|
|                      |                                  | addr.      | MSB         |             |             |              |             |             |             | LSB         | Hex                 | Binary   |
|                      | Bi                               | it address | E7          | <b>E6</b>   | E5          | E4           | E3          | E2          | E1          | <b>E0</b>   |                     |          |
| ACC*                 | Accumulator                      | E0H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| AUXR1                | Auxiliary function register      | A2H        | -           | EBRR        | -           | -            | SRST        | 0           | -           | DPS         | 00 <sup>[1]</sup>   | 000000x0 |
|                      | Bi                               | it address | F7          | <b>F6</b>   | F5          | <b>F</b> 4   | <b>F3</b>   | F2          | F1          | F0          |                     |          |
| B*                   | B register                       | F0H        |             |             |             |              |             |             |             |             | 00                  | 00000000 |
| BRGR0 <sup>[2]</sup> | Baud rate generator rate lo      | w BEH      |             |             |             |              |             |             |             |             | 00                  | 00000000 |
| BRGR1 <sup>[2]</sup> | Baud rate generator rate hi      | gh BFH     |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| BRGCON               | Baud rate generator contro       | I BDH      | -           | -           | -           | -            | -           | -           | SBRGS       | BRGEN       | 00 <mark>[6]</mark> | xxxxxx00 |
| CMP1                 | Comparator 1 control regist      | ter ACH    | -           | -           | CE1         | -            | CN1         | -           | CO1         | CMF1        | 00 <sup>[1]</sup>   | xx000000 |
| CMP2                 | Comparator 2 control regist      | ter ADH    | -           | -           | CE2         | -            | CN2         | -           | CO2         | CMF2        | 00[1]               | xx000000 |
| DIVM                 | CPU clock divide-by-M control    | 95H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| DPTR                 | Data pointer (2 bytes)           |            |             |             |             |              |             |             |             |             |                     |          |
| DPH                  | Data pointer high                | 83H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| DPL                  | Data pointer low                 | 82H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| FMADRH               | Program Flash address hig        | h E7H      |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| FMADRL               | Program Flash address low        | E6H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| FMCON                | Program Flash Control<br>(Read)  | E4H        | BUSY        | -           | -           | -            | HVA         | HVE         | SV          | OI          | 70                  | 0111000  |
|                      | Program Flash Control<br>(Write) |            | FMCMD.<br>7 | FMCMD.<br>6 | FMCMD.<br>5 | FMCMD.<br>4  | FMCMD.<br>3 | FMCMD.<br>2 | FMCMD.<br>1 | FMCMD.<br>0 |                     |          |
| FMDATA               | Program Flash data               | E5H        |             |             |             |              |             |             |             |             | 00                  | 0000000  |
| IEN0*                | Interrupt enable 0               | A8H        | EA          | EWDRT       | EBO         | ES/ESR       | ET1         | -           | ET0         | -           | 00                  | 0000000  |
|                      | Bi                               | it address | EF          | EE          | ED          | EC           | EB          | EA          | <b>E9</b>   | <b>E</b> 8  |                     |          |
| IEN1*                | Interrupt enable 1               | E8H        | -           | EST         | -           | -            | -           | EC          | EKBI        | -           | 00[1]               | 00x0000  |
|                      | Bi                               | it address | BF          | BE          | BD          | BC           | BB          | BA          | <b>B</b> 9  | <b>B</b> 8  |                     |          |
| IP0*                 | Interrupt priority 0             | B8H        | -           | PWDRT       | PBO         | PS/PSR       | PT1         | -           | PT0         | -           | 00[1]               | x000000  |
| IP0H                 | Interrupt priority 0 high        | B7H        | -           | PWDRT<br>H  | PBOH        | PSH<br>/PSRH | PT1H        | -           | PT0H        | -           | 00 <sup>[1]</sup>   | x000000  |
|                      | Bi                               | it address | FF          | FE          | FD          | FC           | FB          | FA          | F9          | <b>F</b> 8  |                     |          |

8-bit microcontrollers with two-clock 80C51 core

P89LPC901/902/903

9397 750 1. Product data

## Table 9:P89LPC903 Special function registers...continued\* indicates SFRs that are bit addressable.

| Name   | Description                            | SFR         |       | Reset     | value          |               |      |          |              |           |                          |          |
|--------|----------------------------------------|-------------|-------|-----------|----------------|---------------|------|----------|--------------|-----------|--------------------------|----------|
|        |                                        | addr.       | MSB   |           |                |               |      |          |              | LSB       | Hex                      | Binary   |
| IP1*   | Interrupt priority 1                   | F8H         | -     | PST       | -              | -             | -    | PC       | PKBI         | -         | 00 <sup>[1]</sup>        | 00x0000  |
| IP1H   | Interrupt priority 1 high              | F7H         | -     | PSTH      | -              | -             | -    | PCH      | PKBIH        | -         | 00 <sup>[1]</sup>        | 00x0000  |
| KBCON  | Keypad control register                | 94H         | -     | -         | -              | -             | -    | -        | PATN<br>_SEL | KBIF      | 00 <sup>[1]</sup>        | xxxxxx00 |
| KBMASK | Keypad interrupt mask register         | 86H         |       |           |                |               |      |          |              |           | 00                       | 0000000  |
| KBPATN | Keypad pattern register                | 93H         |       |           |                |               |      |          |              |           | FF                       | 11111111 |
|        |                                        | Bit address | 87    | 86        | 85             | 84            | 83   | 82       | 81           | 80        |                          |          |
| P0*    | Port 0                                 | 80H         | -     | -         | CMPREF<br>/KB5 | CIN1A<br>/KB4 | -    | KB2      | -            | -         | [1]                      |          |
|        |                                        | Bit address | 97    | 96        | 95             | 94            | 93   | 92       | 91           | 90        |                          |          |
| P1*    | Port 1                                 | 90H         | -     | -         | RST            | -             | -    | -        | RxD          | TxD       |                          |          |
| P0M1   | Port 0 output mode 1                   | 84H         | -     | -         | (P0M1.5)       | (P0M1.4)      | -    | (P0M1.2) | -            | -         | FF                       | 1111111  |
| P0M2   | Port 0 output mode 2                   | 85H         | -     | -         | (P0M2.5)       | (P0M2.4)      | -    | (P0M2.2) | -            | -         | 00                       | 0000000  |
| P1M1   | Port 1 output mode 1                   | 91H         | -     | -         | (P1M1.5)       | -             | -    | -        | (P1M1.1)     | (P1M1.0)  | FF <sup>[1]</sup>        | 1111111  |
| P1M2   | Port 1 output mode 2                   | 92H         | -     | -         | (P1M2.5)       | -             | -    | -        | (P1M2.1)     | (P1M2.0)  | 00 <sup>[1]</sup>        | 0000000  |
| PCON   | Power control register                 | 87H         | SMOD1 | SMOD0     | BOPD           | BOI           | GF1  | GF0      | PMOD1        | PMOD0     | 00                       | 0000000  |
| PCONA  | Power control register A               | B5H         | RTCPD |           | VCPD           |               |      | -        | SPD          |           | 00 <sup>[1]</sup>        | 0000000  |
| PCONB  | reserved for Power Contr<br>Register B | ol B6H      | -     | -         | -              | -             | -    | -        | -            | -         | 00 <sup>[1]</sup>        | XXXXXXXX |
|        |                                        | Bit address | D7    | <b>D6</b> | D5             | <b>D</b> 4    | D3   | D2       | D1           | <b>D0</b> |                          |          |
| PSW*   | Program status word                    | D0H         | CY    | AC        | F0             | RS1           | RS0  | OV       | F1           | Р         | 00                       | 0000000  |
| PT0AD  | Port 0 digital input disable           | e F6H       | -     | -         | PT0AD.5        | PT0AD.4       | -    | PT0AD.2  | -            | -         | 00                       | xx00000x |
| RSTSRC | Reset source register                  | DFH         | -     | -         | BOF            | POF           | R_BK | R_WD     | R_SF         | R_EX      | [3]                      |          |
| RTCCON | Real-time clock control                | D1H         | RTCF  | RTCS1     | RTCS0          | -             | -    | -        | ERTC         | RTCEN     | 60 <sup>[1]</sup><br>[6] | 011xxx00 |
| RTCH   | Real-time clock register h             | nigh D2H    |       |           |                |               |      |          |              |           | 00[6]                    | 0000000  |
| RTCL   | Real-time clock register lo            | ow D3H      |       |           |                |               |      |          |              |           | 00[6]                    | 0000000  |
| SADDR  | Serial port address regist             | er A9H      |       |           |                |               |      |          |              |           | 00                       | 0000000  |
| SADEN  | Serial port address enabl              | e B9H       |       |           |                |               |      |          |              |           | 00                       | 0000000  |

9397 750 -Product data

P89LPC901/902/903

#### Table 9: P89LPC903 Special function registers...continued

\* indicates SFRs that are bit addressable.

| Name   | Description                          | SFR    |        |       | Reset value |            |        |           |        |        |         |          |
|--------|--------------------------------------|--------|--------|-------|-------------|------------|--------|-----------|--------|--------|---------|----------|
|        |                                      | addr.  | MSB    |       |             |            |        |           |        | LSB    | Hex     | Binary   |
| SBUF   | Serial port data buffer register     | 99H    |        |       |             |            |        |           |        |        | xx      | xxxxxxx  |
|        | Bit a                                | ddress | 9F     | 9E    | 9D          | 9C         | 9B     | 9A        | 99     | 98     |         |          |
| SCON*  | Serial port control                  | 98H    | SM0/FE | SM1   | SM2         | REN        | TB8    | RB8       | TI     | RI     | 00      | 0000000  |
| SSTAT  | Serial port extended status register | BAH    | DBMOD  | INTLO | CIDIS       | DBISEL     | FE     | BR        | OE     | STINT  | 00      | 00000000 |
| SP     | Stack pointer                        | 81H    |        |       |             |            |        |           |        |        | 07      | 00000111 |
|        | Bit a                                | ddress | 8F     | 8E    | 8D          | 8 <b>C</b> | 8B     | <b>8A</b> | 89     | 88     |         |          |
| TCON*  | Timer 0 and 1 control                | 88H    | TF1    | TR1   | TF0         | TR0        | -      | -         | -      | -      | 00      | 0000000  |
| TH0    | Timer 0 high                         | 8CH    |        |       |             |            |        |           |        |        | 00      | 0000000  |
| TH1    | Timer 1 high                         | 8DH    |        |       |             |            |        |           |        |        | 00      | 0000000  |
| TL0    | Timer 0 low                          | 8AH    |        |       |             |            |        |           |        |        | 00      | 0000000  |
| TL1    | Timer 1 low                          | 8BH    |        |       |             |            |        |           |        |        | 00      | 0000000  |
| TMOD   | Timer 0 and 1 mode                   | 89H    | -      | -     | T1M1        | T1M0       | -      | -         | T0M1   | T0M0   | 00      | 0000000  |
| TRIM   | Internal oscillator trim register    | 96H    | -      | -     | TRIM.5      | TRIM.4     | TRIM.3 | TRIM.2    | TRIM.1 | TRIM.0 | [5] [6] |          |
| WDCON  | Watchdog control register            | A7H    | PRE2   | PRE1  | PRE0        | -          | -      | WDRUN     | WDTOF  | WDCLK  | [4] [6] |          |
| WDL    | Watchdog load                        | C1H    |        |       |             |            |        |           |        |        | FF      | 11111111 |
| WFEED1 | Watchdog feed 1                      | C2H    |        |       |             |            |        |           |        |        |         |          |
| WFEED2 | Watchdog feed 2                      | СЗН    |        |       |             |            |        |           |        |        |         |          |

[1] All ports are in input only (high impedance) state after power-up.

[2] BRGR1 and BRGR0 must only be written if BRGEN in BRGCON SFR is '0'. If any are written while BRGEN = 1, the result is unpredictable.

Unimplemented bits in SFRs (labeled '-') are X (unknown) at all times. Unless otherwise specified, ones should not be written to these bits since they may be used for other purposes in future derivatives. The reset values shown for these bits are '0's although they are unknown when read.

[3] The RSTSRC register reflects the cause of the P89LPC901/902/903 reset. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on reset value is xx110000.

[4] After reset, the value is 111001x1, i.e., PRE2-PRE0 are all '1', WDRUN = 1 and WDCLK = 1. WDTOF bit is '1' after Watchdog reset and is '0' after power-on reset. Other resets will not affect WDTOF.

[5] On power-on reset, the TRIM SFR is initialized with a factory preprogrammed value. Other resets will not cause initialization of the TRIM register.

[6] The only reset source that affects these SFRs is power-on reset.

Product data

8-bit microcontrollers with two-clock 80C51 core

**89** 

PC901/902/903

### 8. Functional description

**Remark:** Please refer to the *P89LPC901/902/903 User's Manual* for a more detailed functional description.

#### 8.1 Enhanced CPU

The P89LPC901/902/903 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 P89LPC901/902/903 device has several internal clocks as defined below:

**OSCCLK** — Input to the DIVM clock divider. OSCCLK is selected from one of the clock sources (see Figure 12, 13, and 14) 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 P89LPC901/902/903 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 and an on-chip RC oscillator.

The P89LPC901, in addition, includes an option for 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 (P89LPC901)

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 (P89LPC901)

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 (P89LPC901)

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 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. If CCLK is 8 MHz or slower, the CLKLP SFR bit (AUXR1.7) can be set to '1' to reduce power consumption. On 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.2.6 Clock output (P89LPC901)

The P89LPC901 supports a user selectable clock output function on the XTAL2/CLKOUT pin when crystal oscillator is not being used. This condition occurs if another clock source has been selected (on-chip RC oscillator, Watchdog oscillator, external clock input on X1) and if the Real-Time clock is not using the crystal oscillator as its clock source. This allows external devices to synchronize to the P89LPC901. This output is enabled by the ENCLK bit in the TRIM register. The frequency of this clock output is <sup>1</sup>/<sub>2</sub> that of the CCLK. If the clock output is not needed in Idle mode, it may be turned off prior to entering Idle, saving additional power.

#### 8.3 On-chip RC oscillator option

The P89LPC901/902/903 has a 6-bit TRIM register that can be used to tune the frequency of the RC oscillator. During reset, the TRIM value is initialized to a factory pre-programmed value to adjust the oscillator frequency to 7.373 MHz,  $\pm 2.5\%$ . End-user applications can write to the Trim register to adjust the on-chip RC oscillator to other frequencies. If CCLK is 8 MHz or slower, the CLKLP SFR bit (AUXR1.7) can be set to '1' to reduce power consumption. On 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.4 Watchdog oscillator option

The Watchdog has a separate oscillator which has a frequency of 400 kHz. This oscillator can be used to save power when a high clock frequency is not needed.

#### 8.5 External clock input option (P89LPC901)

In this configuration, the processor clock is derived from an external source driving the XTAL1/P3.1 pin. The rate may be from 0 Hz up to 18 MHz. The XTAL2/P3.0 pin may be used as a standard port pin or a clock output. 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.