#### NXP USA Inc. - P89LPC9102FTK,115 Datasheet





#### Welcome to <u>E-XFL.COM</u>

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

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

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

#### Details

| Product Status             | Obsolete                                                                  |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | 8051                                                                      |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 18MHz                                                                     |
| Connectivity               | -                                                                         |
| Peripherals                | Brown-out Detect/Reset, LED, POR, PWM, WDT                                |
| Number of I/O              | 8                                                                         |
| Program Memory Size        | 1KB (1K x 8)                                                              |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.4V ~ 3.6V                                                               |
| Data Converters            | A/D 4x10b                                                                 |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 10-VFDFN Exposed Pad                                                      |
| Supplier Device Package    | 10-HVSON (3x3)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89lpc9102ftk-115 |

Email: info@E-XFL.COM

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

### **NXP Semiconductors**

## P89LPC9102/9103/9107

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



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

| Symbol          | Pin | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1.5/RST        | 2   | 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. When using an oscillator frequency above 12 MHz, the reset input function of P1.5 must be enabled. An external circuit is required to hold the device in reset at power-up until V <sub>DD</sub> has reached its specified level. When system power is removed V <sub>DD</sub> will fall below the minimum specified operating voltage. When using an oscillator frequency above 12 MHz, in some applications, an external brownout detect circuit may be required to hold the device in reset when V <sub>DD</sub> falls below the minimum specified operating voltage. |
| V <sub>SS</sub> | 3   | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| V <sub>DD</sub> | 7   | I    | <b>Power supply:</b> This is the power supply voltage for normal operation as well as Idle mode and Power-down mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|                       | LPC9107 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol                | Pin     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| P0.1 to P0.5,<br>P0.7 |         | I/O  | <b>Port 0:</b> Port 0 is an I/O port with a user-configurable output type. During reset Port 0 latches are configured in the input-only mode with the internal pull-up disabled. The operation of Port 0 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to <u>Section 8.12.1 "Port</u> <u>configurations"</u> and <u>Table 12 "Static characteristics"</u> for details. |
|                       |         |      | The Keypad Interrupt feature operates with Port 0 pins.                                                                                                                                                                                                                                                                                                                                                                                            |
|                       |         |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                            |
|                       |         |      | Port 0 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                 |
| P0.1/KBI1/            | 5       | I/O  | <b>P0.1</b> — Port 0 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| AD10                  |         | I    | KBI1 — Keyboard input 1.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                       |         | I    | AD10 — ADC1 channel 0 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                |
| P0.2/KBI2/            | 1       | I/O  | <b>P0.2</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| AD11                  |         | I    | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                       |         | I    | AD11 — ADC1 channel 1 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                |
| P0.3/CIN1B/           | 14      | I/O  | <b>P0.3</b> — Port 0 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| AD12                  |         | I    | CIN1B — Comparator 1 positive input.                                                                                                                                                                                                                                                                                                                                                                                                               |
|                       |         | I    | AD12 — ADC1 channel 2 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                |
| P0.4/CIN1A/           | 12      | I/O  | <b>P0.4</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| AD13/DAC1             |         | I    | CIN1A — Comparator 1 positive input.                                                                                                                                                                                                                                                                                                                                                                                                               |
|                       |         | I    | AD13 — ADC1 channel 3 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                |
|                       |         | 0    | DAC1 — Digital to analog converter output.                                                                                                                                                                                                                                                                                                                                                                                                         |
| P0.5/CMPREF/          | 11      | I/O  | <b>P0.5</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CLKIN                 |         | I    | CMPREF — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                                    |
|                       |         | l    | CLKIN — External clock input.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P0.7/T1/              | 8       | I/O  | <b>P0.7</b> — Port 0 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CLKOUT                |         | I/O  | T1 — Timer/counter 1 external count input or overflow/PWM output.                                                                                                                                                                                                                                                                                                                                                                                  |
|                       |         | I    | CLKOUT — Clock output.                                                                                                                                                                                                                                                                                                                                                                                                                             |

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

| Symbol                | Pin        | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1.0 to P1.2,<br>P1.5 |            | I/O  | <ul> <li>Port 1: Port 1 is an I/O port with a user-configurable output type. During reset Port 1 latches are configured in the input-only mode with the internal pull-up disabled. The operation of the configurable Port 1 pins as inputs and outputs depends upon the port configuration selected. Each of the configurable port pins are programmed independently. Refer to Section 8.12.1 "Port configurations" and Table 12 "Static characteristics" for details. P1.5 is input-only.</li> <li>All pins have Schmitt triggered inputs.</li> <li>Port 1 also provides various special functions as described below:</li> </ul>                                                                                                                                                                                                                       |
| P1.0/TXD              | 6          | I/O  | <b>P1.0</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                       |            | 0    | <b>TXD</b> — Serial port transmitter data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P1.1/RXD              | P1.1/RXD 9 |      | <b>P1.1</b> — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                       |            | I    | RXD — Serial port receiver data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1.2/T0 7 I/C         |            | I/O  | <b>P1.2</b> — Port 1 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                       |            | I/O  | T0 — Timer/counter 0 external count input or overflow/PWM output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| P1.5/RST              | 3          | 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. When using an oscillator frequency above 12 MHz, the reset input function of P1.5 must be enabled. An external circuit is required to hold the device in reset at power-up until V <sub>DD</sub> has reached its specified level. When system power is removed V <sub>DD</sub> will fall below the minimum specified operating voltage. When using an oscillator frequency above 12 MHz, in some applications, an external brownout detect circuit may be required to hold the device in reset when V <sub>DD</sub> falls below the minimum specified operating voltage. |
| V <sub>SS</sub>       | 4          | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| V <sub>DD</sub>       | 10         | I    | <b>Power supply:</b> This is the power supply voltage for normal operation as well as Idle mode and Power-down mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 8. Functional description

**Remark:** Please refer to the *P89LPC9102/9103/9107 User manual UM10112* for a more detailed functional description.

### 8.1 Special function registers

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

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

#### P89LPC9102 special function registers ... continued Table 7.

\* indicates SFRs that are bit addressable.

| Name   | Description                       | SFR    | Bit functions and addresses |       |        |        |        |           | Reset value |        |                     |           |
|--------|-----------------------------------|--------|-----------------------------|-------|--------|--------|--------|-----------|-------------|--------|---------------------|-----------|
|        |                                   | addr.  | MSB                         |       |        |        |        |           |             | LSB    | Hex                 | Binary    |
| RSTSRC | Reset source register             | DFH    | -                           | -     | BOF    | POF    | -      | R_WD      | R_SF        | R_EX   | [3]                 |           |
| RTCCON | Real-time clock control           | D1H    | RTCF                        | RTCS1 | RTCS0  | -      | -      | -         | ERTC        | RTCEN  | 60 <mark>[4]</mark> | 011x xx00 |
| RTCH   | Real-time clock register high     | D2H    |                             |       |        |        |        |           |             |        | 00 <mark>[4]</mark> | 0000 0000 |
| RTCL   | Real-time clock register low      | D3H    |                             |       |        |        |        |           |             |        | 00 <mark>[4]</mark> | 0000 0000 |
| SP     | Stack pointer                     | 81H    |                             |       |        |        |        |           |             |        | 07                  | 0000 0111 |
| TAMOD  | Timer 0 and 1 auxiliary mode      | 8FH    | -                           | -     | -      | T1M2   | -      | -         | -           | T0M2   | 00                  | xxx0 xxx0 |
|        | Bit a                             | ddress | 8F                          | 8E    | 8D     | 8C     | 8B     | <b>8A</b> | 89          | 88     |                     |           |
| TCON*  | Timer 0 and 1 control             | 88H    | TF1                         | TR1   | TF0    | TR0    | -      | -         | -           | -      | 00                  | 0000 0000 |
| TH0    | Timer 0 high                      | 8CH    |                             |       |        |        |        |           |             |        | 00                  | 0000 0000 |
| TH1    | Timer 1 high                      | 8DH    |                             |       |        |        |        |           |             |        | 00                  | 0000 0000 |
| TL0    | Timer 0 low                       | 8AH    |                             |       |        |        |        |           |             |        | 00                  | 0000 0000 |
| TL1    | Timer 1 low                       | 8BH    |                             |       |        |        |        |           |             |        | 00                  | 0000 0000 |
| TMOD   | Timer 0 and 1 mode                | 89H    | -                           | -     | T1M1   | T1M0   | -      | -         | T0M1        | T0M0   | 00                  | 0000 0000 |
| TRIM   | Internal oscillator trim register | 96H    | RCCLK                       | ENCLK | TRIM.5 | TRIM.4 | TRIM.3 | TRIM.2    | TRIM.1      | TRIM.0 | [4][5]              |           |
| WDCON  | Watchdog control register         | A7H    | PRE2                        | PRE1  | PRE0   | -      | -      | WDRUN     | WDTOF       | WDCLK  | [4][6]              |           |
| WDL    | Watchdog load                     | C1H    |                             |       |        |        |        |           |             |        | FF                  | 1111 1111 |
| WFEED1 | Watchdog feed 1                   | C2H    |                             |       |        |        |        |           |             |        |                     |           |
| WFEED2 | Watchdog feed 2                   | СЗН    |                             |       |        |        |        |           |             |        |                     |           |

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

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

[3] The RSTSRC register reflects the cause of the P89LPC9102/9103/9107 reset. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on reset value is xx11 0000.

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

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

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

Product data

1 sheet

Rev. ີສ 10 July 2007

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

NXP

Semiconductors

10 July 2007

Rev. 03

T

Product data sheet

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

\_PC9102\_9103 [4] The RSTSRC register reflects the cause of the P89LPC9102/9103/9107 reset. Upon a power-up reset, all reset source flags are cleared except POF and BOF; the power-on reset value is xx11 0000.

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

- 9107 [6] On power-on reset, the TRIM SFR is initialized with a factory preprogrammed value. Other resets will not cause initialization of the TRIM register.
- [7] After reset, the value is 1110 01x1, i.e., PRE2 to PRE0 are all logic 1s, WDRUN = 1 and WDCLK = 1. WDTOF bit is logic 1 after watchdog timer reset and is logic 0 after power-on reset. Other resets will not affect WDTOF.

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

#### 8.12.2 Quasi-bidirectional output configuration

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

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

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

#### 8.12.3 Open-drain output configuration

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

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

#### 8.12.4 Input-only configuration

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

#### 8.12.5 Push-pull output configuration

The push-pull output configuration has the same pull-down structure as both the open-drain and the quasi-bidirectional output modes, but provides a continuous strong pull-up when the port latch contains a logic 1. The push-pull mode may be used when more source current is needed from a port output. A push-pull port pin has a Schmitt triggered input that also has a glitch suppression circuit.

#### 8.12.6 Port 0 analog functions

The P89LPC9102/9103/9107 incorporates an Analog Comparator. In order to give the best analog function performance and to minimize power consumption, pins that are being used for analog functions must have the digital outputs and digital inputs disabled.

Digital outputs are disabled by putting the port output into the Input-only (high-impedance) mode as described in <u>Section 8.12.4 "Input-only configuration"</u>.

Digital inputs on Port 0 may be disabled through the use of the PT0AD register. On any reset, the PT0AD bits default to logic 0s to enable digital functions.

#### 8.12.7 Additional port features

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

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

- Power-on detect
- Brownout detect
- Watchdog timer
- Software reset
- UART break character detect reset (P89LPC9103/9107).

For every reset source, there is a flag in the Reset Register, RSTSRC. The user can read this register to determine the most recent reset source. These flag bits can be cleared in software by writing a logic 0 to the corresponding bit. More than one flag bit may be set:

- During a power-on reset, both POF and BOF are set but the other flag bits are cleared.
- For any other reset, previously set flag bits that have not been cleared will remain set.

#### 8.16 Timers 0 and 1

The P89LPC9102 has two general purpose timer/counters which are similar to the standard 80C51 Timer 0 and Timer 1. These timers have five operating modes (modes 0, 1, 2, 3, and 6). Modes 0, 1, and 2 are the same for both Timers. Mode 3 is different.

The P89LPC9103/9107 has two general purpose timers which are similar to the standard 80C51 Timer 0 and Timer 1. These timers have four operating modes (modes 0, 1, 2, and 3). Modes 0, 1, and 2 are the same for both Timers. Mode 3 is different.

#### 8.16.1 Mode 0

Putting either Timer into Mode 0 makes it look like an 8048 Timer, which is an 8-bit Counter with a divide-by-32 prescaler. In this mode, the Timer register is configured as a 13-bit register. Mode 0 operation is the same for Timer 0 and Timer 1.

#### 8.16.2 Mode 1

Mode 1 is the same as Mode 0, except that all 16 bits of the timer register are used.

#### 8.16.3 Mode 2

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

#### 8.16.4 Mode 3

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

#### 8.16.5 Mode 6 (P89LPC9102/9107)

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

#### 8.21 Comparator interrupt

The comparator has an interrupt flag contained in its configuration register. This flag is set whenever the comparator output changes state. The flag may be polled by software or may be used to generate an interrupt.

#### 8.22 Comparator and power reduction modes

The comparator may remain enabled when Power-down mode or Idle mode is activated, but the comparator is disabled automatically in Total Power-down mode.

If the comparator interrupt is enabled (except in Total Power-down mode), a change of the comparator output state will generate an interrupt and wake-up the processor. If the comparator output to a pin is enabled, the pin should be configured in the push-pull mode in order to obtain fast switching times while in Power-down mode. The reason is that with the oscillator stopped, the temporary strong pull-up that normally occurs during switching on a quasi-bidirectional port pin does not take place.

The comparator consumes power in Power-down mode and Idle mode, as well as in the normal operating mode. This fact should be taken into account when system power consumption is an issue. To minimize power consumption, the user can disable the comparator via PCONA.5 or put the device in Total Power-down mode.

### 8.23 Keypad interrupt (KBI)

The Keypad Interrupt function is intended primarily to allow a single interrupt to be generated when Port 0 is equal to or not equal to a certain pattern. This function can be used for bus address recognition or keypad recognition. The user can configure the port via SFRs for different tasks.

The Keypad Interrupt Mask Register (KBMASK) is used to define which input pins connected to Port 0 can trigger the interrupt. The Keypad Pattern Register (KBPATN) is used to define a pattern that is compared to the value of Port 0. The Keypad Interrupt Flag (KBIF) in the Keypad Interrupt Control Register (KBCON) is set when the condition is matched while the Keypad Interrupt function is active. An interrupt will be generated if enabled. The PATN\_SEL bit in the Keypad Interrupt Control Register (KBCON) is used to define equal or not-equal for the comparison.

In order to use the Keypad Interrupt as an original KBI function like in 87LPC76x series, the user needs to set KBPATN = 0FFH and PATN\_SEL = 1 (not equal), then any key connected to Port 0 which is enabled by the KBMASK register will cause the hardware to set KBIF and generate an interrupt if it has been enabled. The interrupt may be used to wake-up the CPU from Idle mode or Power-down mode. This feature is particularly useful in handheld, battery powered systems that need to carefully manage power consumption yet also need to be convenient to use.

In order to set the flag and cause an interrupt, the pattern on Port 0 must be held longer than six CCLKs.

### 8.24 Watchdog timer

The watchdog timer causes a system reset when it underflows as a result of a failure to feed the timer prior to the timer reaching its terminal count. It consists of a programmable 12-bit prescaler, and an 8-bit down counter. The down counter is decremented by a tap

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

#### 8.26 Flash program memory

#### 8.26.1 General description

The P89LPC9102/9103/9107 flash memory provides in-circuit electrical erasure and programming. The flash can be erased, read, and written as bytes. The Sector and Page Erase functions can erase any flash sector (256 bytes) or page (16 bytes). The Chip Erase operation will erase the entire program memory. In-Circuit Programming using standard commercial programmers is available. In addition, In-Application Programming Lite (IAP-Lite) and byte erase allows code memory to be used for non-volatile data storage. On-chip erase and write timing generation contribute to a user-friendly programming interface. The P89LPC9102/9103/9107 flash reliably stores memory contents even after more than 400000 erase and program cycles. The cell is designed to optimize the erase and programming mechanisms. The P89LPC9102/9103/9107 uses V<sub>DD</sub> as the supply voltage to perform the Program/Erase algorithms.

#### 8.26.2 Features

- Programming and erase over the full operating voltage range.
- Byte-erase allowing code memory to be used for data storage.
- Read/Programming/Erase using ICP.
- Any flash program/erase operation in 2 ms.
- Programming with industry-standard commercial programmers.
- Programmable security for the code in the flash for each sector.
- More than 400000 minimum erase/program cycles for each byte.
- 20-year minimum data retention.

#### 8.26.3 Flash organization

The P89LPC9102/9103/9107 program memory consists of four 256 byte sectors. Each sector can be further divided into 16-byte pages. In addition to sector erase, page erase, and byte erase, a 16-byte page register is included which allows from 1 byte to 16 bytes of a given page to be programmed at the same time, substantially reducing overall programming time. In addition, erasing and reprogramming of user-programmable configuration bytes including UCFG1, the Boot Status Bit, and the Boot Vector is supported.

#### 8.26.4 Flash programming and erasing

Different methods of erasing or programming of the flash are available. The flash may be programmed or erased in the end-user application (IAP-Lite) under control of the application's firmware. Another option is to use the ICP mechanism. This ICP system provides for programming through a serial clock- serial data interface. Third, the flash may be programmed or erased using a commercially available EPROM programmer which supports this device. This device does not provide for direct verification of code memory contents. Instead this device provides a 32-bit CRC result on either a sector or the entire 1 kB of user code space.

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

### 9. A/D Converter

#### 9.1 General description

The P89LPC9102/9103/9107 has an 8-bit, 4-channel multiplexed successive approximation analog-to-digital converter. The A/D consists of a 4-input multiplexer which feeds a sample-and-hold circuit providing an input signal to one of two comparator inputs. The control logic in combination with the Successive Approximation Register (SAR) drives a digital-to-analog converter which provides the other input to the comparator. The output of the comparator is fed to the SAR. A block diagram of the A/D converter is shown in Figure 18.

#### 9.2 Features

- 8-bit, 4-channel multiplexed input, successive approximation A/D converter
- Four result registers
- Six operating modes
  - Fixed channel, single conversion mode
  - Fixed channel, continuous conversion mode
  - Auto scan, single conversion mode
  - Auto scan, continuous conversion mode
  - Dual channel, continuous conversion mode
  - Single step mode
- Two conversion start modes
  - Timer triggered start
  - Start immediately
- **8**-bit conversion time of  $\geq$  3.9 µs at an ADC clock of 3.3 MHz
- Interrupt or polled operation
- Boundary limits interrupt
- DAC output to a port pin with high output impedance
- Clock divider
- Power-down mode

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

### **10. Limiting values**

#### Table 11. Limiting values

In accordance with the Absolute Maximum Rating System (IEC 60134).[1]

| Symbol                 | Parameter                                         | Conditions                                                         | Min  | Max  | Unit |
|------------------------|---------------------------------------------------|--------------------------------------------------------------------|------|------|------|
| T <sub>amb(bias)</sub> | bias ambient temperature                          |                                                                    | -55  | +125 | °C   |
| T <sub>stg</sub>       | storage temperature                               |                                                                    | -65  | +150 | °C   |
| I <sub>OH(I/O)</sub>   | HIGH-level output current per<br>input/output pin |                                                                    | -    | 8    | mA   |
| I <sub>OL(I/O)</sub>   | LOW-level output current per<br>input/output pin  |                                                                    | -    | 20   | mA   |
| II/Otot(max)           | maximum total input/output current                |                                                                    | -    | 120  | mA   |
| V <sub>n</sub>         | voltage on any other pin                          | except $V_{SS}$ , with respect to $V_{DD}$                         | -0.5 | +5.5 | V    |
| P <sub>tot(pack)</sub> | total power dissipation per package               | based on package heat<br>transfer, not device power<br>consumption | -    | 1.5  | W    |
|                        |                                                   |                                                                    |      |      |      |

[1] The following applies to <u>Table 11 "Limiting values</u>":

a) Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any conditions other than those described in <u>Table 12 "Static characteristics</u>" and <u>Table 13 "Dynamic characteristics (12 MHz)</u>" section of this specification are not implied.

b) This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maximum.

c) Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted.

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

#### Table 12. Static characteristics ... continued

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

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

| Symbol               | Parameter                           | Conditions                                          | Min  | Typ <mark>[1]</mark> | Max  | Unit   |
|----------------------|-------------------------------------|-----------------------------------------------------|------|----------------------|------|--------|
| V <sub>bo</sub>      | brownout trip voltage               | 2.4 V < $V_{DD}$ < 3.6 V; with<br>BOV = 1, BOPD = 0 | 2.40 | -                    | 2.70 | V      |
| V <sub>ref(bg)</sub> | band gap reference voltage          |                                                     | 1.19 | 1.23                 | 1.27 | V      |
| $TC_{bg}$            | band gap temperature<br>coefficient |                                                     | -    | 10                   | 20   | ppm/°C |

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

[2] The I<sub>DD(oper)</sub>, I<sub>DD(idle)</sub>, and I<sub>DD(pd)</sub> specifications are measured using an external clock with the following functions disabled: comparators, real-time clock, and watchdog timer.

[3] The I<sub>DD(oper)</sub> and I<sub>DD(idle)</sub> specifications are measured using with the following functions disabled: comparators, real-time clock, and watchdog timer.

[4] The I<sub>DD(tpd)</sub> specification is measured using an external clock with the following functions disabled: comparators, real-time clock, brownout detect, and watchdog timer.

- [5] Applies to all ports, in all modes except Hi-Z.
- [6] Pin capacitance is characterized but not tested.
- [7] Measured with port in quasi-bidirectional mode.
- [8] Measured with port in high-impedance mode.
- [9] Ports in quasi-bidirectional mode with weak pull-up (applies to all port pins with pull-ups)
- [10] Port pins source a transition current when used in quasi-bidirectional mode and externally driven from logic 1 to logic 0. This current is highest when V<sub>1</sub> is approximately 2 V.

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

### **13. Other characteristics**

#### **13.1 Comparator electrical characteristics**

#### Table 15. Comparator electrical characteristics

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

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

| anno                  |                                  | •                    |              |     |                |      |
|-----------------------|----------------------------------|----------------------|--------------|-----|----------------|------|
| Symbol                | Parameter                        | Conditions           | Min          | Тур | Max            | Unit |
| V <sub>IO</sub>       | input offset voltage             |                      | -            | -   | ±10            | mV   |
| V <sub>IC</sub>       | common-mode input voltage        |                      | 0            | -   | $V_{DD} - 0.3$ | V    |
| CMRR                  | common-mode rejection ratio      |                      | <u>[1]</u> _ | -   | -50            | dB   |
| t <sub>res(tot)</sub> | total response time              |                      | -            | 250 | 500            | ns   |
| t <sub>(CE-OV)</sub>  | chip enable to output valid time |                      | -            | -   | 10             | μs   |
| ILI                   | input leakage current            | $0 V < V_I < V_{DD}$ | -            | -   | ±1             | μΑ   |
|                       |                                  |                      |              |     |                |      |

[1] This parameter is characterized, but not tested in production.

#### 13.2 A/D converter electrical characteristics

#### Table 16. A/D converter electrical characteristics

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

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

All limits valid for an external source impedance of less than 10 k $\Omega$ .

| Symbol               | Parameter                     | Conditions       | Min            | Тур | Max                     | Unit |
|----------------------|-------------------------------|------------------|----------------|-----|-------------------------|------|
| V <sub>IA</sub>      | analog input voltage          |                  | $V_{SS} - 0.2$ | -   | $V_{SS}$ + 0.2          | V    |
| C <sub>iss</sub>     | input capacitance             |                  | -              | -   | 15                      | pF   |
| E <sub>D</sub>       | differential linearity error  |                  | -              | -   | ±1                      | LSB  |
| E <sub>L(adj)</sub>  | integral non-linearity        |                  | -              | -   | ±1                      | LSB  |
| Eo                   | offset error                  |                  | -              | -   | ±2                      | LSB  |
| E <sub>G</sub>       | gain error                    |                  | -              | -   | ±1                      | %    |
| E <sub>u(tot)</sub>  | total unadjusted error        |                  | -              | -   | ±2                      | LSB  |
| M <sub>CTC</sub>     | channel-to-channel matching   |                  | -              | -   | ±1                      | LSB  |
| $\alpha_{ct(port)}$  | crosstalk between port inputs | 0 kHz to 100 kHz | -              | -   | -60                     | dB   |
| SR <sub>in</sub>     | input slew rate               |                  | -              | -   | 100                     | V/ms |
| T <sub>cy(ADC)</sub> | ADC clock cycle               |                  | 111            | -   | 2000                    | ns   |
| t <sub>ADC</sub>     | ADC conversion time           | A/D enabled      | -              | -   | 13t <sub>CLK(ADC)</sub> | μs   |

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



#### Fig 22. Package outline SOT402-1 (TSSOP14)

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



#### Fig 23. Package outline SOT27-1 (DIP14)

P89LPC9102\_9103\_9107\_3 Product data sheet 8-bit microcontrollers with two-clock accelerated 80C51 core

### **16. Revision history**

| Table 18.Revision history                                                                                                                                                                                                                                                              |              |                    |               |                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------|---------------|------------------------|
| Document ID                                                                                                                                                                                                                                                                            | Release date | Data sheet status  | Change notice | Supersedes             |
| P89LPC9102_9103_9107_3                                                                                                                                                                                                                                                                 | 20070710     | Product data sheet | -             | P89LPC9102_9103_9107_2 |
| <ul> <li>Modifications:</li> <li>The format of this data sheet has been redesigned to comply with the new identiguidelines of NXP Semiconductors.</li> <li>Legal texts have been adapted to the new company name where appropriate.</li> <li>Added new device P89LPC9107FN.</li> </ul> |              |                    |               |                        |
| P89LPC9102_9103_9107_2                                                                                                                                                                                                                                                                 | 20050411     | Product data sheet | -             | P89LPC9102_9103_9107_1 |
| P89LPC9102_9103_9107_1                                                                                                                                                                                                                                                                 | 20050111     | Product data sheet | -             | -                      |

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

### **17. Legal information**

### 17.1 Data sheet status

| Document status <sup>[1][2]</sup> | Product status <sup>[3]</sup> | Definition                                                                            |
|-----------------------------------|-------------------------------|---------------------------------------------------------------------------------------|
| Objective [short] data sheet      | Development                   | This document contains data from the objective specification for product development. |
| Preliminary [short] data sheet    | Qualification                 | This document contains data from the preliminary specification.                       |
| Product [short] data sheet        | Production                    | This document contains the product specification.                                     |

[1] Please consult the most recently issued document before initiating or completing a design.

[2] The term 'short data sheet' is explained in section "Definitions".

[3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL http://www.nxp.com.

#### 17.2 Definitions

**Draft** — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information.

Short data sheet — A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail.

### 17.3 Disclaimers

**General** — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

**Suitability for use** — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in medical, military, aircraft, space or life support equipment, nor in applications where failure or

malfunction of a NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

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

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) may cause permanent damage to the device. Limiting values are stress ratings only and operation of the device at these or any other conditions above those given in the Characteristics sections of this document is not implied. Exposure to limiting values for extended periods may affect device reliability.

Terms and conditions of sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at <a href="http://www.nxp.com/profile/terms">http://www.nxp.com/profile/terms</a>, including those pertaining to warranty, intellectual property rights infringement and limitation of liability, unless explicitly otherwise agreed to in writing by NXP Semiconductors. In case of any inconsistency or conflict between information in this document and such terms and conditions, the latter will prevail.

**No offer to sell or license** — Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights.

### 17.4 Trademarks

Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners.

### **18. Contact information**

For additional information, please visit: http://www.nxp.com

For sales office addresses, send an email to: <a href="mailto:salesaddresses@nxp.com">salesaddresses@nxp.com</a>

P89LPC9102\_9103\_9107\_3

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

### **19. Contents**

| 1              | General description 1                       |
|----------------|---------------------------------------------|
| 2              | Features 1                                  |
| 2.1            | Principal features 1                        |
| 2.2            | Additional features 1                       |
| 3              | Product comparison overview 2               |
| 4              | Ordering information 3                      |
| 4.1            | Ordering options 3                          |
| 5              | Block diagram 4                             |
| 6              | Functional diagram 6                        |
| 7              | Pinning information 8                       |
| 7.1            | Pinning                                     |
| 7.2            | Pin description 10                          |
| 8              | Functional description                      |
| 8.1            | Special function registers                  |
| 8.2            | Enhanced CPU                                |
| 8.3            | Clocks                                      |
| 8.3.1          | Clock definitions 27                        |
| 8.3.2          | CPU clock (CCLK) 27                         |
| 8.4            | On-chip RC oscillator option 27             |
| 8.5            | Watchdog oscillator option 28               |
| 8.6            | External clock input option 28              |
| 8.7            | CCLK wake-up delay 29                       |
| 8.8            | CCLK modification: DIVM register            |
| 8.9            | Low power select                            |
| 8.10           | Memory organization                         |
| 8.11<br>8.11.1 | Interrupts                                  |
| 8.12           | External interrupt inputs                   |
| 8.12.1         | I/O ports                                   |
| 8.12.1         | Quasi-bidirectional output configuration 32 |
| 8.12.3         | Open-drain output configuration             |
| 8.12.4         | Input-only configuration                    |
| 8.12.5         | Push-pull output configuration              |
| 8.12.6         | Port 0 analog functions                     |
| 8.12.7         | Additional port features                    |
| 8.13           | Power monitoring functions                  |
| 8.13.1         | Brownout detection                          |
| 8.13.2         | Power-on detection                          |
| 8.14           | Power reduction modes                       |
| 8.14.1         | Idle mode                                   |
| 8.14.2         | Slow-down mode using the DIVM register 34   |
| 8.14.3         | Power-down mode 34                          |
| 8.14.4         | Total Power-down mode                       |
| 8.15           | Reset 34                                    |
| 8.16           | Timers 0 and 1                              |
| 8.16.1         | Mode 0                                      |

| 8.16.2  | Mode 1                                              | 35 |
|---------|-----------------------------------------------------|----|
| 8.16.3  | Mode 2                                              | 35 |
| 8.16.4  | Mode 3                                              | 35 |
| 8.16.5  | Mode 6 (P89LPC9102/9107)                            | 35 |
| 8.16.6  | Timer overflow toggle output                        |    |
| 0.10.0  | (P89LPC9102/9107)                                   | 36 |
| 8.17    | RTC/system timer.                                   | 36 |
| 8.18    | UART (P89LPC9103/9107)                              | 36 |
| 8.18.1  | Mode 0                                              | 36 |
| 8.18.2  | Mode 1                                              | 36 |
| 8.18.3  |                                                     | 36 |
| 8.18.4  | Mode 2                                              | 30 |
|         |                                                     | 37 |
| 8.18.5  | Baud rate generator and selection                   | -  |
| 8.18.6  | Framing error                                       | 37 |
| 8.18.7  | Break detect                                        | 37 |
| 8.18.8  | Double buffering.                                   | 37 |
| 8.18.9  | Transmit interrupts with double buffering           |    |
|         | enabled (Modes 1, 2 and 3)                          | 38 |
| 8.18.10 | The 9 <sup>th</sup> bit (bit 8) in double buffering |    |
|         | (Modes 1, 2 and 3)                                  | 38 |
| 8.19    | Analog comparators                                  | 38 |
| 8.20    | Internal reference voltage                          | 38 |
| 8.21    | Comparator interrupt                                | 39 |
| 8.22    | Comparator and power reduction modes                | 39 |
| 8.23    | Keypad interrupt (KBI)                              | 39 |
| 8.24    | Watchdog timer                                      | 39 |
| 8.25    | Additional features                                 | 40 |
| 8.25.1  | Software reset                                      | 40 |
| 8.25.2  | Dual data pointers                                  | 40 |
| 8.26    | Flash program memory                                | 41 |
| 8.26.1  | General description                                 | 41 |
| 8.26.2  | Features                                            | 41 |
| 8.26.3  | Flash organization                                  | 41 |
| 8.26.4  | Flash programming and erasing.                      | 41 |
| 8.26.5  | In-circuit programming                              | 42 |
| 8.26.6  | In-application programming (IAP-Lite)               | 42 |
| 8.26.7  | Using flash as data storage                         | 42 |
| 8.26.8  | User configuration bytes.                           | 42 |
| 8.26.9  | User sector security bytes                          | 42 |
|         | A/D Converter                                       | 43 |
| •       |                                                     |    |
| 9.1     | General description                                 | 43 |
| 9.2     | Features                                            | 43 |
| 9.3     | Block diagram.                                      | 44 |
| 9.4     | A/D operating modes                                 | 44 |
| 9.4.1   | Fixed channel, single conversion mode               | 44 |
| 9.4.2   | Fixed channel, continuous conversion mode .         | 44 |
| 9.4.3   | Auto scan, single conversion mode                   | 44 |
| 9.4.4   | Auto scan, continuous conversion mode               | 44 |
|         |                                                     |    |

#### continued >>

founded by

**PHILIPS** 

## P89LPC9102/9103/9107

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

| 9.4.5 | Dual channel, continuous conversion mode 45 |
|-------|---------------------------------------------|
| 9.4.6 | Single step mode 45                         |
| 9.5   | Conversion start modes 45                   |
| 9.5.1 | Timer triggered start 45                    |
| 9.5.2 | Start immediately 45                        |
| 9.6   | Boundary limits interrupt 45                |
| 9.7   | DAC output to a port pin with high output   |
|       | impedance 45                                |
| 9.8   | Clock divider                               |
| 9.9   | Power-down and Idle mode 46                 |
| 10    | Limiting values 47                          |
| 11    | Static characteristics 48                   |
| 12    | Dynamic characteristics 50                  |
| 12.1  | Waveforms 52                                |
| 13    | Other characteristics 53                    |
| 13.1  | Comparator electrical characteristics 53    |
| 13.2  | A/D converter electrical characteristics 53 |
| 14    | Package outline 54                          |
| 15    | Abbreviations 57                            |
| 16    | Revision history 58                         |
| 17    | Legal information 59                        |
| 17.1  | Data sheet status 59                        |
| 17.2  | Definitions 59                              |
| 17.3  | Disclaimers                                 |
| 17.4  | Trademarks 59                               |
| 18    | Contact information 59                      |
| 19    | Contents 60                                 |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

© NXP B.V. 2007.

All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com

Date of release: 10 July 2007 Document identifier: P89LPC9102\_9103\_9107\_3