# mail

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 microcontroller with accelerated two-clock 80C51 core 8 kB 3 V byte-erasable flash with 512-byte data EEPROM

Rev. 2 — 16 November 2010

**Product data sheet** 

### 1. General description

The P89LPC9321 is a single-chip microcontroller, available in low cost 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 P89LPC9321 in order to reduce component count, board space, and system cost.

### 2. Features and benefits

### 2.1 Principal features

- 8 kB byte-erasable flash code memory organized into 1 kB sectors and 64-byte pages. Single-byte erasing allows any byte(s) to be used as non-volatile data storage.
- 256-byte RAM data memory and a 512-byte auxiliary on-chip RAM.
- 512-byte customer data EEPROM on-chip allows serialization of devices, storage of setup parameters, etc.
- Two analog comparators with selectable inputs and reference source.
- Single Programmable Gain Amplifier (PGA) with selectable gains of 2x, 4x, 8x, or 16x can be applied to analog comparator inputs.
- Two 16-bit counter/timers (each may be configured to toggle a port output upon timer overflow or to become a PWM output).
- A 23-bit system timer that can also be used as real-time clock consisting of a 7-bit prescaler and a programmable and readable 16-bit timer.
- Enhanced UART with a fractional baud rate generator, break detect, framing error detection, and automatic address detection; 400 kHz byte-wide I<sup>2</sup>C-bus communication port and SPI communication port.
- Capture/Compare Unit (CCU) provides PWM, input capture, and output compare functions.
- 2.4 V to 3.6 V V<sub>DD</sub> operating range. I/O pins are 5 V tolerant (may be pulled up or driven to 5.5 V).
- 4-level low voltage (brownout) detect allows a graceful system shutdown when power fails. May optionally be configured as an interrupt.
- 28-pin TSSOP, PLCC and DIP packages with 23 I/O pins minimum and up to 26 I/O pins while using on-chip oscillator and reset options.



### 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. 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.
- Serial flash In-Circuit Programming (ICP) allows simple production coding with commercial EPROM programmers. Flash security bits prevent reading of sensitive application programs.
- Serial flash In-System Programming (ISP) allows coding while the device is mounted in the end application.
- In-Application Programming (IAP) of the flash code memory. This allows changing the code in a running application.
- Watchdog timer with separate on-chip oscillator, nominal 400 kHz, calibrated to ±5 %, requiring no external components. The watchdog prescaler is selectable from eight values.
- High-accuracy internal RC oscillator option, with clock doubler option, allows operation without external oscillator components. The RC oscillator option is selectable and fine tunable.
- Switching on the fly among internal RC oscillator, watchdog oscillator, external clock source provides optimal support of minimal power active mode with fast switching to maximum performance.
- 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 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.
- Oscillator fail detect. The watchdog timer has a separate fully on-chip oscillator allowing it to perform an oscillator fail detect function.
- Programmable port output configuration options: quasi-bidirectional, open drain, push-pull, input-only.
- High current sourcing/sinking (20 mA) on eight I/O pins (P0.3 to P0.7, P1.4, P1.6, P1.7). All other port pins have high sinking capability (20 mA). A maximum limit is specified for the entire chip.
- 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.
- 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 P89LPC9321 when internal reset option is selected.
- Four interrupt priority levels.
- Eight keypad interrupt inputs, plus two additional external interrupt inputs.
- Schmitt trigger port inputs.
- Second data pointer.
- Emulation support.

### 3. Ordering information

| Table 1. Ordering | g information |                                                                           |          |
|-------------------|---------------|---------------------------------------------------------------------------|----------|
| Type number       | Package       |                                                                           |          |
|                   | Name          | Description                                                               | Version  |
| P89LPC9321FA      | PLCC28        | plastic leaded chip carrier; 28 leads                                     | SOT261-2 |
| P89LPC9321FDH     | TSSOP28       | plastic thin shrink small outline package; 28<br>leads; body width 4.4 mm | SOT361-1 |
| P89LPC9321FN      | DIP28         | plastic dual in-line package; 28 leads; (600 mil)                         | SOT117-1 |

### 3.1 Ordering options

### Table 2.Ordering options

| Type number   | Flash memory | Temperature range | Frequency       |
|---------------|--------------|-------------------|-----------------|
| P89LPC9321FA  | 8 kB         | –40 °C to +85 °C  | 0 MHz to 18 MHz |
| P89LPC9321FDH | 8 kB         | –40 °C to +85 °C  | 0 MHz to 18 MHz |
| P89LPC9321FN  | 8 kB         | –40 °C to +85 °C  | 0 MHz to 18 MHz |

8-bit microcontroller with accelerated two-clock 80C51 core

### 4. Block diagram



8-bit microcontroller with accelerated two-clock 80C51 core

### 5. Functional diagram



8-bit microcontroller with accelerated two-clock 80C51 core

### 6. Pinning information

### 6.1 Pinning



### **NXP Semiconductors**

8-bit microcontroller with accelerated two-clock 80C51 core



### 6.2 Pin description

| Symbol                                             | Pin | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0.0 to P0.7                                       |     | I/O  | <b>Port 0:</b> Port 0 is an 8-bit I/O port with a user-configurable output type. During reset 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 <u>Section</u> 7.16.1 "Port configurations" and <u>Table 10 "Static characteristics"</u> for details. |
|                                                    |     |      | The Keypad Interrupt feature operates with Port 0 pins.                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                    |     |      | All pins have Schmitt trigger inputs.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                    |     |      | Port 0 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                |
| P0.0/CMP2/                                         | 3   | I/O  | <b>P0.0</b> — Port 0 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| (BI0<br>20.1/CIN2B/<br>(BI1                        |     | 0    | CMP2 — Comparator 2 output                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                    |     | I    | KBI0 — Keyboard input 0.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.1/CIN2B/<br>KBI1                                | 26  | I/O  | <b>P0.1</b> — Port 0 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                    |     | I    | CIN2B — Comparator 2 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                    |     | I    | KBI1 — Keyboard input 1.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.2/CIN2A/                                        | 25  | I/O  | <b>P0.2</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| KBI0<br>P0.1/CIN2B/<br>KBI1<br>P0.2/CIN2A/<br>KBI2 |     | I    | CIN2A — Comparator 2 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                    |     | I    | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.3/CIN1B/                                        | 24  | I/O  | P0.3 — Port 0 bit 3. High current source.                                                                                                                                                                                                                                                                                                                                                                                                         |
| KBI3                                               |     | I    | CIN1B — Comparator 1 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                            |
| (BI1<br>20.2/CIN2A/<br>(BI2<br>20.3/CIN1B/         |     | I    | KBI3 — Keyboard input 3.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.4/CIN1A/                                        | 23  | I/O  | P0.4 — Port 0 bit 4. High current source.                                                                                                                                                                                                                                                                                                                                                                                                         |
| KBI4                                               |     | I    | CIN1A — Comparator 1 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                    |     | I    | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.5/CMPREF/                                       | 22  | I/O  | P0.5 — Port 0 bit 5. High current source.                                                                                                                                                                                                                                                                                                                                                                                                         |
| KBI5                                               |     | Ι    | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                    |     | 1    | KBI5 — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                                          |

### **NXP Semiconductors**

### P89LPC9321

### 8-bit microcontroller with accelerated two-clock 80C51 core

| Table 3. Pin de      | scription . | continued     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------|-------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol               | Pin         | Туре          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P0.6/CMP1/KBI6       | 20          | I/O           | <b>P0.6</b> — Port 0 bit 6. High current source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                      |             | 0             | CMP1 — Comparator 1 output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      |             | I             | KBI6 — Keyboard input 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P0.7/T1/KBI7         | 19          | I/O           | <b>P0.7</b> — Port 0 bit 7. High current source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                      |             | I/O           | T1 — Timer/counter 1 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                      |             | I             | KBI7 — Keyboard input 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P1.0 to P1.7         |             | I/O, I<br>[1] | <b>Port 1:</b> Port 1 is an 8-bit I/O port with a user-configurable output type, except for three pins as noted below. During reset Port 1 latches are configured in the input only mode with the internal pull-up disabled. The operation of the configurable Port 1 pins as inputs and outputs depends upon the port configuration selected. Each of the configurable port pins are programmed independently. Refer to <u>Section 7.16.1 "Port configurations"</u> and <u>Table 10 "Static characteristics"</u> for details. P1.2 to P1.3 are open drain when used as outputs. P1.5 is input only. |
|                      |             |               | All pins have Schmitt trigger inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      |             |               | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P1.0/TXD<br>P1.1/RXD | 18          | I/O           | <b>P1.0</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      |             | 0             | <b>TXD</b> — Transmitter output for serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| P1.1/RXD             | 17          | I/O           | <b>P1.1</b> — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      |             | I             | <b>RXD</b> — Receiver input for serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1.2/T0/SCL          | 12          | I/O           | P1.2 — Port 1 bit 2 (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      |             | I/O           | <b>T0</b> — Timer/counter 0 external count input or overflow output (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      |             | I/O           | SCL — I <sup>2</sup> C-bus serial clock input/output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P1.3/INT0/SDA        | 11          | I/O           | P1.3 — Port 1 bit 3 (open-drain when used as output).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      |             | I             | INT0 — External interrupt 0 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      |             | I/O           | SDA — I <sup>2</sup> C-bus serial data input/output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| P1.4/INT1            | 10          | I/O           | P1.4 — Port 1 bit 4. High current source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                      |             | I             | INT1 — External interrupt 1 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P1.5/RST             | 6           | 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 ISP mode.                                                                                                                                                                                                                                                             |
| P1.6/OCB             | 5           | I/O           | P1.6 — Port 1 bit 6. High current source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                      |             | 0             | OCB — Output Compare B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P1.7/OCC             | 4           | I/O           | P1.7 — Port 1 bit 7. High current source.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                      |             | 0             | OCC — Output Compare C.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P2.0 to P2.7         |             | I/O           | <b>Port 2:</b> Port 2 is an 8-bit I/O port with a user-configurable output type. During reset<br>Port 2 latches are configured in the input only mode with the internal pull-up<br>disabled. The operation of Port 2 pins as inputs and outputs depends upon the port<br>configuration selected. Each port pin is configured independently. Refer to <u>Section</u><br><u>7.16.1 "Port configurations"</u> and <u>Table 10 "Static characteristics"</u> for details.                                                                                                                                 |
|                      |             |               | All pins have Schmitt trigger inputs.<br>Port 2 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                      |             |               | 1 on 2 also provides various special functions as described below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### **NXP Semiconductors**

# P89LPC9321

### 8-bit microcontroller with accelerated two-clock 80C51 core

|                 | Pin description | -   |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Pin             |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P2.0/ICB        | 1               | I/O | <b>P2.0</b> — Port 2 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | ļ   | ICB — Input Capture B.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P2.1/OCD        | 2               | I/O | <b>P2.1</b> — Port 2 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | 0   | <b>OCD</b> — Output Compare D.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P2.2/MOSI       | 13              | I/O | <b>P2.2</b> — Port 2 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | I/O | <b>MOSI</b> — SPI master out slave in. When configured as master, this pin is output; when configured as slave, this pin is input.                                                                                                                                                                                                                                                                                                               |
| P2.3/MISO       | 14              | I/O | <b>P2.3</b> — Port 2 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | I/O | <b>MISO</b> — When configured as master, this pin is input, when configured as slave, this pin is output.                                                                                                                                                                                                                                                                                                                                        |
| P2.4/SS         | 15              | I/O | <b>P2.4</b> — Port 2 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | I/O | SS — SPI Slave select.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P2.5/SPICL      | K 16            | I/O | <b>P2.5</b> — Port 2 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | I/O | <b>SPICLK</b> — SPI clock. When configured as master, this pin is output; when configured as slave, this pin is input.                                                                                                                                                                                                                                                                                                                           |
| P2.6/OCA        | 27              | I/O | <b>P2.6</b> — Port 2 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | 0   | OCA — Output Compare A.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P2.7/ICA        | 28              | I/O | <b>P2.7</b> — Port 2 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | Ι   | ICA — Input Capture A.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P3.0 to P3.     | 1               | I/O | <b>Port 3:</b> Port 3 is a 2-bit I/O port with a user-configurable output type. 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 <u>Section</u> 7.16.1 "Port configurations" and <u>Table 10 "Static characteristics"</u> for details. |
|                 |                 |     | All pins have Schmitt trigger inputs.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 |                 |     | Port 3 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                               |
| P3.0/XTAL2      | 2/ 9            | I/O | <b>P3.0</b> — Port 3 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| CLKOUT          |                 | 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 -TRIM.6).<br>It can be used if the CPU clock is the internal RC oscillator, watchdog oscillator or<br>external clock input, except when XTAL1/XTAL2 are used to generate clock source<br>for the RTC/system timer.                                                                                                                                                        |
| P3.1/XTAL       | 1 8             | I/O | <b>P3.1</b> — Port 3 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                 |                 | I   | <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 RTC/system timer.                                                                                                                  |
| V <sub>SS</sub> | 7               | I   | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V <sub>DD</sub> | 21              | I   | <b>Power supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                                                                                                                                 |

[1] Input/output for P1.0 to P1.4, P1.6, P1.7. Input for P1.5.

P89LPC9321 Product data sheet

### 7. Functional description

**Remark:** Please refer to the P89LPC9321 *User manual* for a more detailed functional description.

### 7.1 Special function registers

Remark: SFR 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.

P89LPC9321

| able 1  | Createl | function | register |
|---------|---------|----------|----------|
| able 4. | Special | function | register |

| Name                 | Description                              | SFR    | Bit function | ns and addro | esses  |       |       |        |        |           | Reset               | value    |
|----------------------|------------------------------------------|--------|--------------|--------------|--------|-------|-------|--------|--------|-----------|---------------------|----------|
|                      |                                          | addr.  | MSB          |              |        |       |       |        |        | LSB       | Hex                 | Binary   |
|                      | Bit a                                    | ddress | E7           | <b>E6</b>    | E5     | E4    | E3    | E2     | E1     | <b>E0</b> |                     |          |
| ACC*                 | Accumulator                              | E0H    |              |              |        |       |       |        |        |           | 00                  | 0000 00  |
| AUXR1                | Auxiliary<br>function<br>register        | A2H    | CLKLP        | EBRR         | ENT1   | ENT0  | SRST  | 0      | -      | DPS       | 00                  | 0000 00  |
|                      | Bit a                                    | ddress | <b>F</b> 7   | <b>F6</b>    | F5     | F4    | F3    | F2     | F1     | <b>F0</b> |                     |          |
| B*                   | B register                               | F0H    |              |              |        |       |       |        |        |           | 00                  | 0000 00  |
| BRGR0 <sup>[2]</sup> | Baud rate<br>generator 0<br>rate low     | BEH    |              |              |        |       |       |        |        |           | 00                  | 0000 00  |
| BRGR1 <sup>[2]</sup> | Baud rate<br>generator 0<br>rate high    | BFH    |              |              |        |       |       |        |        |           | 00                  | 0000 00  |
| BRGCON               | Baud rate<br>generator 0<br>control      | BDH    | -            | -            | -      | -     | -     | -      | SBRGS  | BRGEN     | 00[2]               | xxxx xx( |
| CCCRA                | Capture<br>compare A<br>control register | EAH    | ICECA2       | ICECA1       | ICECA0 | ICESA | ICNFA | FCOA   | OCMA1  | OCMA0     | 00                  | 0000 00  |
| CCCRB                | Capture<br>compare B<br>control register | EBH    | ICECB2       | ICECB1       | ICECB0 | ICESB | ICNFB | FCOB   | OCMB1  | OCMB0     | 00                  | 0000 00  |
| CCCRC                | Capture<br>compare C<br>control register | ECH    | -            | -            | -      | -     | -     | FCOC   | OCMC1  | OCMC0     | 00                  | xxxx x00 |
| CCCRD                | Capture<br>compare D<br>control register | EDH    | -            | -            | -      | -     | -     | FCOD   | OCMD1  | OCMD0     | 00                  | xxxx x00 |
| CMP1                 | Comparator 1 control register            | ACH    | -            | -            | CE1    | CP1   | CN1   | OE1    | CO1    | CMF1      | 00 <mark>[1]</mark> | xx00 00  |
| CMP2                 | Comparator 2 control register            | ADH    | -            | -            | CE2    | CP2   | CN2   | OE2    | CO2    | CMF2      | 00[1]               | xx00 00  |
| DEECON               | Data EEPROM control register             | F1H    | EEIF         | HVERR        | ECTL1  | ECTL0 | -     | EWERR1 | EWERR0 | EADR8     | 08                  | 0000 10  |

# **NXP Semiconductors**

8-bit microcontroller with accelerated two-clock 80C51 core

P89LPC9321

| Table 4. | <b>Special</b> | function         | registers                 | continued                           |
|----------|----------------|------------------|---------------------------|-------------------------------------|
|          | Table 4.       | Table 4. Special | Table 4. Special function | Table 4. Special function registers |

| Name   | Description                                       | SFR    | Bit function | ns and addro | esses   |         |         |         |         |         | Reset | value     |
|--------|---------------------------------------------------|--------|--------------|--------------|---------|---------|---------|---------|---------|---------|-------|-----------|
|        |                                                   | addr.  | MSB          |              |         |         |         |         |         | LSB     | Hex   | Binary    |
| DEEDAT | Data EEPROM data register                         | F2H    |              |              |         |         |         |         |         |         | 00    | 0000 0000 |
| DEEAD  | A Data EEPROM<br>address<br>register              | F3H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| DIVM   | CPU clock<br>divide-by-M<br>control               | 95H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| DPTR   | Data pointer<br>(2 bytes)                         |        |              |              |         |         |         |         |         |         |       |           |
| DPH    | Data pointer<br>high                              | 83H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| DPL    | Data pointer<br>low                               | 82H    |              |              |         |         |         |         |         |         | 00    | 000 000   |
| FMADR  | H Program flash<br>address high                   | E7H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| FMADRI | Program flash address low                         | E6H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| FMCON  | Program flash control (Read)                      | E4H    | BUSY         | -            | -       | -       | HVA     | HVE     | SV      | OI      | 70    | 0111 0000 |
|        | Program flash control (Write)                     | E4H    | FMCMD.7      | FMCMD.6      | FMCMD.5 | FMCMD.4 | FMCMD.3 | FMCMD.2 | FMCMD.1 | FMCMD.0 |       |           |
| FMDATA | Program flash<br>data                             | E5H    |              |              |         |         |         |         |         |         | 00    | 0000 000  |
| I2ADR  | l <sup>2</sup> C-bus slave<br>address<br>register | DBH    | I2ADR.6      | I2ADR.5      | I2ADR.4 | I2ADR.3 | I2ADR.2 | I2ADR.1 | I2ADR.0 | GC      | 00    | 0000 000  |
|        | Bit a                                             | ddress | DF           | DE           | DD      | DC      | DB      | DA      | D9      | D8      |       |           |
| I2CON* | I <sup>2</sup> C-bus control register             | D8H    | -            | I2EN         | STA     | STO     | SI      | AA      | -       | CRSEL   | 00    | x000 00x0 |
| I2DAT  | I <sup>2</sup> C-bus data register                | DAH    |              |              |         |         |         |         |         |         |       |           |

# **NXP Semiconductors**

8-bit microcontroller with accelerated two-clock 80C51 core

P89LPC9321

#### Table 4.Special function registers ... continued\* indicates SFRs that are bit addressable. Table 4. P89LPC93

| Table 4.<br>* indicate.<br>Name                                           | Description                                                  | SFR     | Bit functio | ns and addre | sses  |              |       |      |            |            | Reset         | value     |
|---------------------------------------------------------------------------|--------------------------------------------------------------|---------|-------------|--------------|-------|--------------|-------|------|------------|------------|---------------|-----------|
|                                                                           |                                                              | addr.   | MSB         |              |       |              |       |      |            | LSB        | Hex           | Binary    |
| I2SCLH                                                                    | Serial clock<br>generator/SCL<br>duty cycle<br>register high | DDH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
| I2SCLL                                                                    | Serial clock<br>generator/SCL<br>duty cycle<br>register low  | DCH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
| I2STAT<br>▹                                                               | l <sup>2</sup> C-bus status<br>register                      | D9H     | STA.4       | STA.3        | STA.2 | STA.1        | STA.0 | 0    | 0          | 0          | F8            | 1111 1000 |
|                                                                           | Input capture A register high                                | ABH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
|                                                                           | Input capture A register low                                 | AAH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
|                                                                           | Input capture B register high                                | AFH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
| All information provided in this document is subject to legal disclaimers | Input capture B register low                                 | AEH     |             |              |       |              |       |      |            |            | 00            | 0000 0000 |
| ਨੂੰ<br>ਰ<br>ਛ                                                             | Bit a                                                        | address | AF          | AE           | AD    | AC           | AB    | AA   | A9         | <b>A8</b>  |               |           |
| disclaim                                                                  | Interrupt<br>enable 0                                        | A8H     | EA          | EWDRT        | EBO   | ES/ESR       | ET1   | EX1  | ET0        | EX0        | 00            | 0000 0000 |
| ers.                                                                      | Bit a                                                        | address | EF          | EE           | ED    | EC           | EB    | EA   | E9         | <b>E</b> 8 |               |           |
| IEN1*                                                                     | Interrupt<br>enable 1                                        | E8H     | EIEE        | EST          | -     | ECCU         | ESPI  | EC   | EKBI       | EI2C       | 00 <u>[1]</u> | 00x0 0000 |
|                                                                           | Bit a                                                        | address | BF          | BE           | BD    | BC           | BB    | BA   | <b>B</b> 9 | <b>B</b> 8 |               |           |
| IP0*                                                                      | Interrupt<br>priority 0                                      | B8H     | -           | PWDRT        | PBO   | PS/PSR       | PT1   | PX1  | PT0        | PX0        | 00[1]         | x000 0000 |
| IP0H<br><sup>©</sup> ₹                                                    | Interrupt<br>priority 0 high                                 | B7H     | -           | PWDRTH       | PBOH  | PSH/<br>PSRH | PT1H  | PX1H | PT0H       | PX0H       | 00[1]         | x000 0000 |
| P B.<                                                                     | Bit a                                                        | address | FF          | FE           | FD    | FC           | FB    | FA   | F9         | F8         |               |           |
| © NXP BV 2010. All rights reserved                                        | Interrupt<br>priority 1                                      | F8H     | PIEE        | PST          | -     | PCCU         | PSPI  | PC   | PKBI       | PI2C       | 00 <u>[1]</u> | 00x0 0000 |
| IP1H                                                                      | Interrupt<br>priority 1 high                                 | F7H     | PIEEH       | PSTH         | -     | PCCUH        | PSPIH | PCH  | PKBIH      | PI2CH      | 00[1]         | 00x0 0000 |

**NXP Semiconductors** 

P89LPC9321

| Table 4. Special function registers continue | P89 | P80 | Table 4. | Special | function | registers | continued | 1 |
|----------------------------------------------|-----|-----|----------|---------|----------|-----------|-----------|---|
|----------------------------------------------|-----|-----|----------|---------|----------|-----------|-----------|---|

\* indicates SFRs that are bit addressable.

| 2                                                                         | Name   | Description                          | SFR    | Bit function | is and add   | resses         |               |               |               |               |              | Reset | value     |
|---------------------------------------------------------------------------|--------|--------------------------------------|--------|--------------|--------------|----------------|---------------|---------------|---------------|---------------|--------------|-------|-----------|
|                                                                           |        |                                      | addr.  | MSB          |              |                |               |               |               |               | LSB          | Hex   | Binary    |
| All information provided in this document is subject to least disclaimers | KBCON  | Keypad control register              | 94H    | -            | -            | -              | -             | -             | -             | PATN<br>_SEL  | KBIF         | 00[1] | xxxx xx00 |
|                                                                           | KBMASK | Keypad<br>interrupt mask<br>register | 86H    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | KBPATN | Keypad pattern register              | 93H    |              |              |                |               |               |               |               |              | FF    | 1111 1111 |
|                                                                           | OCRAH  | Output<br>compare A<br>register high | EFH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRAL  | Output<br>compare A<br>register low  | EEH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRBH  | Output<br>compare B<br>register high | FBH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRBL  | Output<br>compare B<br>register low  | FAH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRCH  | Output<br>compare C<br>register high | FDH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRCL  | Output<br>compare C<br>register low  | FCH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRDH  | Output<br>compare D<br>register high | FFH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           | OCRDL  | Output<br>compare D<br>register low  | FEH    |              |              |                |               |               |               |               |              | 00    | 0000 000  |
|                                                                           |        | Bit a                                | ddress | 87           | 86           | 85             | 84            | 83            | 82            | 81            | 80           |       |           |
|                                                                           | P0*    | Port 0                               | 80H    | T1/KB7       | CMP1<br>/KB6 | CMPREF<br>/KB5 | CIN1A<br>/KB4 | CIN1B<br>/KB3 | CIN2A<br>/KB2 | CIN2B<br>/KB1 | CMP2<br>/KB0 | [1]   |           |
|                                                                           |        | Bit a                                | ddress | 97           | 96           | 95             | 94            | 93            | 92            | 91            | 90           |       |           |

8-bit microcontroller with accelerated two-clock 80C51 core

P89LPC9321

### Table 4.Special function registers ... continued\* indicates SFRs that are bit addressable. Table 4. P89LPC93

| Name   | Description                  | SFR     | Bit function | ns and addre | esses                             |            |            |          |            |            | Reset v                | /alue     |
|--------|------------------------------|---------|--------------|--------------|-----------------------------------|------------|------------|----------|------------|------------|------------------------|-----------|
|        |                              | addr.   | MSB          |              |                                   |            |            |          |            | LSB        | Hex                    | Binary    |
| P1*    | Port 1                       | 90H     | OCC          | OCB          | RST                               | INT1       | INT0/SDA   | T0/SCL   | RXD        | TXD        | [1]                    |           |
|        | Bit a                        | address | A7           | <b>A6</b>    | A5                                | <b>A</b> 4 | A3         | A2       | <b>A</b> 1 | <b>A</b> 0 |                        |           |
| P2*    | Port 2                       | A0H     | ICA          | OCA          | SPICLK                            | SS         | MISO       | MOSI     | OCD        | ICB        | [1]                    |           |
|        | Bit a                        | address | B7           | <b>B6</b>    | B5                                | <b>B</b> 4 | <b>B</b> 3 | B2       | <b>B</b> 1 | <b>B0</b>  |                        |           |
| P3*    | Port 3                       | B0H     | -            | -            | -                                 | -          | -          | -        | XTAL1      | XTAL2      | <u>[1]</u>             |           |
| P0M1   | Port 0 output<br>mode 1      | 84H     | (P0M1.7)     | (P0M1.6)     | (P0M1.5)                          | (P0M1.4)   | (P0M1.3)   | (P0M1.2) | (P0M1.1)   | (P0M1.0)   | FF[1]                  | 1111 1111 |
| P0M2   | Port 0 output<br>mode 2      | 85H     | (P0M2.7)     | (P0M2.6)     | <i>I</i> 2.6) (P0M2.5) (P0M2.4) ( |            | (P0M2.3)   | (P0M2.2) | (P0M2.1)   | (P0M2.0)   | 00[1]                  | 0000 000  |
| P1M1   | Port 1 output<br>mode 1      | 91H     | (P1M1.7)     | (P1M1.6)     | -                                 | (P1M1.4)   | (P1M1.3)   | (P1M1.2) | (P1M1.1)   | (P1M1.0)   | D3[1]                  | 11x1 xx1  |
| P1M2   | Port 1 output<br>mode 2      | 92H     | (P1M2.7)     | (P1M2.6)     | -                                 | (P1M2.4)   | (P1M2.3)   |          |            | 00[1]      | 00x0 xx0               |           |
| P2M1   | Port 2 output<br>mode 1      | A4H     | (P2M1.7)     | (P2M1.6)     | (P2M1.5)                          | (P2M1.4)   | (P2M1.3)   | (P2M1.2) | (P2M1.1)   | (P2M1.0)   | FF <u>[1]</u>          | 1111 1111 |
| P2M2   | Port 2 output<br>mode 2      | A5H     | (P2M2.7)     | (P2M2.6)     | (P2M2.5)                          | (P2M2.4)   | (P2M2.3)   | (P2M2.2) | (P2M2.1)   | (P2M2.0)   | 00[1]                  | 0000 000  |
| P3M1   | Port 3 output<br>mode 1      | B1H     | -            | -            | -                                 | -          | -          | -        | (P3M1.1)   | (P3M1.0)   | 03 <mark>[1]</mark>    | xxxx xx1  |
| P3M2   | Port 3 output<br>mode 2      | B2H     | -            | -            | -                                 | -          | -          | -        | (P3M2.1)   | (P3M2.0)   | 00[1]                  | xxxx xx00 |
| PCON   | Power control register       | 87H     | SMOD1        | SMOD0        | -                                 | BOI        | GF1        | GF0      | PMOD1      | PMOD0      | 00                     | 0000 000  |
| PCONA  | Power control<br>register A  | B5H     | RTCPD        | DEEPD        | VCPD                              | -          | I2PD       | SPPD     | SPD        | CCUPD      | 00[1]                  | 0000 000  |
|        | Bit a                        | address | D7           | <b>D6</b>    | D5                                | <b>D</b> 4 | D3         | D2       | D1         | <b>D</b> 0 |                        |           |
| PSW*   | Program status<br>word       | D0H     | CY           | AC           | F0                                | RS1        | RS0        | OV       | F1         | Ρ          | 00                     | 0000 000  |
| PT0AD  | Port 0 digital input disable | F6H     | -            | -            | PT0AD.5                           | PT0AD.4    | PT0AD.3    | PT0AD.2  | PT0AD.1    | -          | 00                     | xx00 000  |
| RSTSRC | Reset source register        | DFH     | -            | BOIF         | BOF                               | POF        | R_BK       | R_WD     | R_SF       | R_EX       | <u>[3]</u>             |           |
| RTCCON | RTC control                  | D1H     | RTCF         | RTCS1        | RTCS0                             | -          | _          | _        | ERTC       | RTCEN      | 60 <mark>[1][6]</mark> | 011x xx0  |

8-bit microcontroller with accelerated two-clock 80C51 core

P89LPC9321

| P89 | Table 4. | Special | function | registers | continued |
|-----|----------|---------|----------|-----------|-----------|
|-----|----------|---------|----------|-----------|-----------|

| Name   | Description                                | SFR    | Bit function | is and addre | esses |        |            |           |         |         | Reset               | value    |
|--------|--------------------------------------------|--------|--------------|--------------|-------|--------|------------|-----------|---------|---------|---------------------|----------|
|        |                                            | addr.  | MSB          |              |       |        |            |           |         | LSB     | Hex                 | Binary   |
| RTCH   | RTC register<br>high                       | D2H    |              |              |       |        |            |           |         |         | 00 <mark>6</mark> ] | 0000 000 |
| RTCL   | RTC register<br>low                        | D3H    |              |              |       |        |            |           |         |         | 00 <mark>[6]</mark> | 0000 000 |
| SADDR  | Serial port<br>address<br>register         | A9H    |              |              |       |        |            |           |         |         | 00                  | 0000 000 |
| SADEN  | Serial port<br>address enable              | B9H    |              |              |       |        |            |           |         |         | 00                  | 0000 000 |
| SBUF   | Serial Port data<br>buffer register        | 99H    |              |              |       |        |            |           |         |         | хх                  | XXXX XXX |
|        | Bit a                                      | ddress | 9F           | 9E           | 9D    | 9C 9B  |            | 9A        | 99      | 98      |                     |          |
| SCON*  | Serial port control                        | 98H    | SM0/FE       | SM1          | SM2   | REN    | TB8        | RB8       | ΤI      | RI      | 00                  | 0000 000 |
| SSTAT  | Serial port<br>extended<br>status register | BAH    | DBMOD        | INTLO        | CIDIS | DBISEL | FE         | BR        | OE      | STINT   | 00                  | 0000 000 |
| SP     | Stack pointer                              | 81H    |              |              |       |        |            |           |         |         | 07                  | 0000 01  |
| SPCTL  | SPI control<br>register                    | E2H    | SSIG         | SPEN         | DORD  | MSTR   | CPOL       | CPHA      | SPR1    | SPR0    | 04                  | 0000 010 |
| SPSTAT | SPI status<br>register                     | E1H    | SPIF         | WCOL         | -     | -      | -          | -         | -       | -       | 00                  | 00xx xxx |
| SPDAT  | SPI data<br>register                       | E3H    |              |              |       |        |            |           |         |         | 00                  | 0000 000 |
| TAMOD  | Timer 0 and 1<br>auxiliary mode            | 8FH    | -            | -            | -     | T1M2   | -          | -         | -       | T0M2    | 00                  | xxx0 xxx |
|        | Bit a                                      | ddress | 8F           | 8E           | 8D    | 8C     | 8 <b>B</b> | <b>8A</b> | 89      | 88      |                     |          |
| TCON*  | Timer 0 and 1 control                      | 88H    | TF1          | TR1          | TF0   | TR0    | IE1        | IT1       | IE0     | IT0     | 00                  | 0000 000 |
| TCR20* | CCU control<br>register 0                  | C8H    | PLEEN        | HLTRN        | HLTEN | ALTCD  | ALTAB      | TDIR2     | TMOD21  | TMOD20  | 00                  | 0000 000 |
| TCR21  | CCU control<br>register 1                  | F9H    | TCOU2        | -            | -     | -      | PLLDV.3    | PLLDV.2   | PLLDV.1 | PLLDV.0 | 00                  | 0xxx 000 |

# **NXP Semiconductors**

8-bit microcontroller with accelerated two-clock 80C51 core

P89LPC9321

| <b>P8</b> 9 | Table 4. | Special f | function | registers | continued |
|-------------|----------|-----------|----------|-----------|-----------|
|             |          |           |          |           |           |

| Ν | lame  | Description                                | SFR   | Bit function | ns and addre | esses    |          |          |          |          |          | Reset         | value     |
|---|-------|--------------------------------------------|-------|--------------|--------------|----------|----------|----------|----------|----------|----------|---------------|-----------|
|   |       |                                            | addr. | MSB          |              |          |          |          |          |          | LSB      | Hex           | Binary    |
| Т | -H0   | Timer 0 high                               | 8CH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | H1    | Timer 1 high                               | 8DH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | H2    | CCU timer high                             | CDH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | ICR2  | CCU interrupt control register             | C9H   | TOIE2        | TOCIE2D      | TOCIE2C  | TOCIE2B  | TOCIE2A  | -        | TICIE2B  | TICIE2A  | 00            | 0000 0x0  |
| Т | IFR2  | CCU interrupt flag register                | E9H   | TOIF2        | TOCF2D       | TOCF2C   | TOCF2B   | TOCF2A   | -        | TICF2B   | TICF2A   | 00            | 0000 0x0  |
| Т | ISE2  | CCU interrupt<br>status encode<br>register | DEH   | -            | -            | -        | -        | -        | ENCINT.2 | ENCINT.1 | ENCINT.0 | 00            | xxxx x00  |
| Т | L0    | Timer 0 low                                | 8AH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | Ľ1    | Timer 1 low                                | 8BH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | L2    | CCU timer low                              | CCH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | MOD   | Timer 0 and 1<br>mode                      | 89H   | T1GATE       | T1C/T        | T1M1     | T1M0     | TOGATE   | T0C/T    | T0M1     | T0M0     | 00            | 0000 000  |
| Т | OR2H  | CCU reload<br>register high                | CFH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | OR2L  | CCU reload register low                    | CEH   |              |              |          |          |          |          |          |          | 00            | 0000 000  |
| Т | PCR2H | Prescaler<br>control register<br>high      | CBH   | -            | -            | -        | -        | -        | -        | TPCR2H.1 | TPCR2H.0 | 00            | xxxx xx00 |
| Т | PCR2L | Prescaler<br>control register<br>low       | CAH   | TPCR2L.7     | TPCR2L.6     | TPCR2L.5 | TPCR2L.4 | TPCR2L.3 | TPCR2L.2 | TPCR2L.1 | TPCR2L.0 | 00            | 0000 000  |
| Т | RIM   | Internal<br>oscillator trim<br>register    | 96H   | RCCLK        | ENCLK        | TRIM.5   | TRIM.4   | TRIM.3   | TRIM.2   | TRIM.1   | TRIM.0   | <u>[5][6]</u> |           |
| V | VDCON | Watchdog<br>control register               | A7H   | PRE2         | PRE1         | PRE0     | -        | -        | WDRUN    | WDTOF    | WDCLK    | <u>[4][6]</u> |           |

**NXP Semiconductors** 

P89LPC9321

0. All rights reserved. 18 of 71

# NXP Semiconductors

#### Special function registers ... continued Table 4. Pro P89LPC932

\* indicates SFRs that are bit addressable.

| 0        |
|----------|
|          |
| <u>೧</u> |
| Ξ.       |
| 0        |
| <u></u>  |
| 0        |
| S        |
| 5        |
| ด        |
| Õ        |
|          |

| 321 | Name   | Description        |       | Bit functions and addresses | Reset value |           |  |
|-----|--------|--------------------|-------|-----------------------------|-------------|-----------|--|
|     |        |                    | addr. | MSB LSB                     | Hex         | Binary    |  |
|     | WDL    | Watchdog load      | C1H   |                             | FF          | 1111 1111 |  |
|     | WFEED1 | Watchdog<br>feed 1 | C2H   |                             |             |           |  |
|     |        | Watchdog<br>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 logic 0. If any are written while BRGEN = 1, the result is unpredictable. [2]

The RSTSRC register reflects the cause of the P89LPC9321 reset except BOIF bit. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on [3] reset value is x011 0000.

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

[5] On power-on reset and watchdog 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 sources that affect these SFRs are power-on reset and watchdog reset.

≥

τ

**J68** 

PC9321

#### Extended special function registers<sup>[1]</sup> Table 5.

| Name          | Description                              | SFR   | Bit functio | ns and addr  | resses       |              |         |         |         |               | Rese       | et value  |
|---------------|------------------------------------------|-------|-------------|--------------|--------------|--------------|---------|---------|---------|---------------|------------|-----------|
|               |                                          | addr. | MSB         |              |              |              |         |         |         | LSB           | Hex        | Binary    |
| BODCFG        | BOD<br>configuration<br>register         | FFC8H | -           | -            | -            | -            | -       | -       | BOICFG1 | BOICFG0       | [2]        |           |
| CLKCON        | CLOCK Control<br>register                | FFDEH | CLKOK       | -            | -            | XTALWD       | CLKDBL  | FOSC2   | FOSC1   | FOSC0         | <u>[3]</u> | 1000 010  |
| PGACON1       | PGA1 control<br>register                 | FFE1H | ENPGA1      | PGASEL1<br>1 | PGASEL1<br>0 | PGATRIM<br>1 | -       | -       | PGAG11  | PGAG10        | 00         | 0000 000  |
| PGACON1B      | PGA1 control<br>register B               | FFE4H | -           | -            | -            | -            | -       | -       | -       | PGAENO<br>FF1 | 00         | 0000 000  |
| PGA1TRIM8X16X | PGA1 trim<br>register                    | FFE3H | 16XTRIM3    | 16XTRIM2     | 16XTRIM1     | 16XTRIM0     | 8XTRIM3 | 8XTRIM2 | 8XTRIM1 | 8XTRIM0       | <u>[4]</u> |           |
| PGA1TRIM2X4X  | PGA1 trim<br>register                    | FFE2H | 4XTRIM3     | 4XTRIM2      | 4XTRIM1      | 4XTRIM0      | 2XTRIM3 | 2XTRIM2 | 2XTRIM1 | 2XTRIM0       | <u>[4]</u> |           |
| RTCDATH       | Real-time clock<br>data register<br>high | FFBFH |             |              |              |              | 1       |         |         |               | 00         | 0000 0000 |
| RTCDATL       | Real-time clock data register low        | FFBEH |             |              |              |              |         |         |         |               | 00         | 0000 0000 |

[3] CLKCON register reset value comes from UCFG1 and UCFG2. The reset value of CLKCON.2 to CLKCON.0 come from UCFG1.2 to UCFG1.0 and reset value of CLKDBL bit comes from UCFG2.7.

[4] On power-on reset and watchdog reset, the PGAxTRIM8X16X and PGAxTRIM2X4X registers are initialized with a factory preprogrammed value. Other resets will not cause initialization.

© NXP B.V. 2010. All rights reserved. 20 of 71

P891

Product data sheet

Rev. 2

16 November 2010

### 7.2 Enhanced CPU

The P89LPC9321 uses an enhanced 80C51 CPU which runs at six 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.

### 7.3 Clocks

### 7.3.1 Clock definitions

The P89LPC9321 device has several internal clocks as defined below:

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

Remark: 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. The clock doubler option, when enabled, provides an output frequency of 14.746 MHz.

PCLK — Clock for the various peripheral devices and is <sup>CCLK</sup>/<sub>2</sub>.

### 7.3.2 CPU clock (OSCCLK)

The P89LPC9321 provides several user-selectable oscillator options in generating the CPU clock. This allows optimization for a range of needs from high precision to lowest possible cost. These options are configured when the flash is programmed and include an on-chip watchdog oscillator, an on-chip RC oscillator, an oscillator using an external crystal, or an external clock source.

### 7.4 External crystal oscillator option

The external crystal oscillator can be optimized for low, medium, or high frequency crystals covering a range from 20 kHz to 18 MHz. It can be the clock source of OSCCLK and RTC. Low speed oscillator option can be the clock source of WDT.

### 7.4.1 Low speed oscillator option

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

### 7.4.2 Medium speed oscillator option

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

### 7.4.3 High speed oscillator option

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

### 7.5 Clock output

The P89LPC9321 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 XTAL1) and if the RTC and WDT are not using the crystal oscillator as their clock source. This allows external devices to synchronize to the P89LPC9321. This output is enabled by the ENCLK bit in the TRIM register.

The frequency of this clock output is  $\frac{1}{2}$  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.

### 7.6 On-chip RC oscillator option

The P89LPC9321 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 preprogrammed value to adjust the oscillator frequency to 7.373 MHz  $\pm$  1 % at room temperature. End-user applications can write to the TRIM register to adjust the on-chip RC oscillator to other frequencies. When the clock doubler option is enabled (UCFG2.7 = 1), the output frequency is 14.746 MHz. If CCLK is 8 MHz or slower, the CLKLP SFR bit (AUXR1.7) can be set to logic 1 to reduce power consumption. On reset, CLKLP is logic 0 allowing highest performance access. This bit can then be set in software if CCLK is running at 8 MHz or slower. When clock doubler option is enabled, BOE1 bit (UCFG1.5) and BOE0 bit (UCFG1.3) are required to hold the device in reset at power-up until V<sub>DD</sub> has reached its specified level.

### 7.7 Watchdog oscillator option

The watchdog has a separate oscillator which has a frequency of 400 kHz, calibrated to  $\pm 5$  % at room temperature. This oscillator can be used to save power when a high clock frequency is not needed.

### 7.8 External clock input option

In this configuration, the processor clock is derived from an external source driving the P3.1/XTAL1 pin. The rate may be from 0 Hz up to 18 MHz. The P3.0/XTAL2 pin may be used as a standard port pin or a clock output. When using an oscillator frequency above 12 MHz, BOE1 bit (UCFG1.5) and BOE0 bit (UCFG1.3) are required to hold the device in reset at power-up until V<sub>DD</sub> has reached its specified level.

### 7.9 Clock sources switch on the fly

P89LPC9321 can implement clock source switch in any sources of watchdog oscillator, 7 MHz/14 MHz IRC oscillator, external clock source (external crystal or external clock input) during code is running. CLKOK bit in CLKCON register is used to indicate the clock switch status. CLKOK is cleared when starting clock source switch and set when completed. Notice that when CLKOK is '0', writing to CLKCON register is not allowed.

### **NXP Semiconductors**

### P89LPC9321

### 8-bit microcontroller with accelerated two-clock 80C51 core



### 7.10 CCLK wake-up delay

The P89LPC9321 has an internal wake-up timer that delays the clock until it stabilizes depending on the clock source used. If the clock source is any of the three crystal selections (low, medium and high frequencies) the delay is 1024 OSCCLK cycles plus 60  $\mu$ s to 100  $\mu$ s. If the clock source is the internal RC oscillator, the delay is 200  $\mu$ s to 300  $\mu$ s. If the clock source is watchdog oscillator or external clock, the delay is 32 OSCCLK cycles.

### 7.11 CCLK modification: DIVM register

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

### 7.12 Low power select

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

### 7.13 Memory organization

The various P89LPC9321 memory spaces are as follows:

DATA

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

IDATA

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

• SFR

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

• XDATA

'External' Data or Auxiliary RAM. Duplicates the classic 80C51 64 kB memory space addressed via the MOVX instruction using the DPTR, R0, or R1. All or part of this space could be implemented on-chip. The P89LPC9321 has 512 bytes of on-chip XDATA memory, plus extended SFRs located in XDATA.

• CODE

64 kB of Code memory space, accessed as part of program execution and via the MOVC instruction. The P89LPC9321 has 8 kB of on-chip Code memory.

The P89LPC9321 also has 512 bytes of on-chip data EEPROM that is accessed via SFRs (see <u>Section 7.14</u>).

### 7.14 Data RAM arrangement

. . . . .

The 768 bytes of on-chip RAM are organized as shown in Table 6.

| Table 6. | On-chip data memory usages |  |
|----------|----------------------------|--|
|          |                            |  |

| Туре  | Data RAM                                                                                | Size (bytes) |
|-------|-----------------------------------------------------------------------------------------|--------------|
| DATA  | Memory that can be addressed directly and indirectly                                    | 128          |
| IDATA | Memory that can be addressed indirectly                                                 | 256          |
| XDATA | Auxiliary ('External Data') on-chip memory that is accessed using the MOVX instructions | 512          |

### 7.15 Interrupts

----

The P89LPC9321 uses a four priority level interrupt structure. This allows great flexibility in controlling the handling of the many interrupt sources. The P89LPC9321 supports 15 interrupt sources: external interrupts 0 and 1, timers 0 and 1, serial port TX, serial port RX, combined serial port RX/TX, brownout detect, watchdog/RTC, I<sup>2</sup>C-bus, keyboard, comparators 1 and 2, SPI, CCU, data EEPROM write completion.

Each interrupt source can be individually enabled or disabled by setting or clearing a bit in the interrupt enable registers IEN0 or IEN1. The IEN0 register also contains a global disable bit, EA, which disables all interrupts.

| All information | provided in | this | document | is | subject | to | legal | disclaim | iers. |
|-----------------|-------------|------|----------|----|---------|----|-------|----------|-------|
|                 |             |      |          |    |         |    |       |          |       |

P89LPC9321

Each interrupt source can be individually programmed to one of four priority levels by setting or clearing bits in the interrupt priority registers IP0, IP0H, IP1 and IP1H. An interrupt service routine in progress can be interrupted by a higher priority interrupt, but not by another interrupt of the same or lower priority. The highest priority interrupt service cannot be interrupted by any other interrupt source. If two requests of different priority level is serviced.

If requests of the same priority level are pending at the start of an instruction, an internal polling sequence determines which request is serviced. This is called the arbitration ranking. Note that the arbitration ranking is only used to resolve pending requests of the same priority level.

### 7.15.1 External interrupt inputs

The P89LPC9321 has two external interrupt inputs as well as the Keypad Interrupt function. The two interrupt inputs are identical to those present on the standard 80C51 microcontrollers.

These external interrupts can be programmed to be level-triggered or edge-triggered by setting or clearing bit IT1 or IT0 in Register TCON.

In edge-triggered mode, if successive samples of the INTn pin show a HIGH in one cycle and a LOW in the next cycle, the interrupt request flag IEn in TCON is set, causing an interrupt request.

If an external interrupt is enabled when the P89LPC9321 is put into Power-down or Idle mode, the interrupt will cause the processor to wake-up and resume operation. Refer to <u>Section 7.18 "Power reduction modes"</u> for details.

P89LPC9321