



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | 8051                                                                     |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 18MHz                                                                    |
| Connectivity               | SPI, UART/USART                                                          |
| Peripherals                | Brown-out Detect/Reset, LED, POR, PWM, WDT                               |
| Number of I/O              | 12                                                                       |
| 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            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 14-TSSOP (0.173", 4.40mm Width)                                          |
| Supplier Device Package    | 14-TSSOP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89lpc913fdh-129 |

Email: info@E-XFL.COM

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

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

## 3. Product comparison

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

#### Table 1. Product comparison

| Type number | External     | X2 CLKOUT | T0 PWM | SPI with | SPI     | UART |     | Max f <sub>osc</sub> |  |
|-------------|--------------|-----------|--------|----------|---------|------|-----|----------------------|--|
|             | crystal pins |           | output | SS pin   | without | TXD  | RXD | (MHz)                |  |
| P89LPC912   | Х            | Х         | Х      | Х        | -       | -    | -   | 18                   |  |
| P89LPC913   | Х            | Х         | -      | -        | Х       | Х    | Х   | 18                   |  |
| P89LPC914   | -            | -         | Х      | Х        | -       | Х    | Х   | 12                   |  |

## 4. Ordering information

#### Table 2. Ordering information

| Type number  | Package |                                                                        |          |  |  |  |  |  |  |  |
|--------------|---------|------------------------------------------------------------------------|----------|--|--|--|--|--|--|--|
|              | Name    | Description                                                            | Version  |  |  |  |  |  |  |  |
| P89LPC912FDH | TSSOP14 | plastic thin shrink small outline package; 14 leads; body width 4.4 mm | SOT402-1 |  |  |  |  |  |  |  |
| P89LPC912HDH |         |                                                                        |          |  |  |  |  |  |  |  |
| P89LPC913FDH |         |                                                                        |          |  |  |  |  |  |  |  |
| P89LPC914FDH |         |                                                                        |          |  |  |  |  |  |  |  |

#### 4.1 Ordering options

#### Table 3. Ordering options

| Type number  | Temperature range | Frequency       |
|--------------|-------------------|-----------------|
| P89LPC912FDH | –40 °C to +85 °C  | 0 MHz to 18 MHz |
| P89LPC912HDH | –40 °C to +125 °C | 0 MHz to 18 MHz |
| P89LPC913FDH | –40 °C to +85 °C  | 0 MHz to 18 MHz |
| P89LPC914FDH | –40 °C to +85 °C  | 0 MHz to 12 MHz |

8-bit microcontrollers with two-clock 80C51 core

## 5. Block diagram



#### **NXP Semiconductors**

# P89LPC912/913/914

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



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

|                 |    |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P2.2 to P2.5    |    | I/O | <b>Port 2:</b> Port 2 is a 4-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>8.12.1 "Port configurations"</u> and <u>Table 13 "Static characteristics"</u> for details. |
|                 |    |     | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 |    |     | Port 2 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                  |
| P2.2/MOSI       | 1  | 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> — SPI master in slave out. When configured as master, this pin is input, when configured as slave, this pin is output.                                                                                                                                                                                                                                                                                                                                  |
| P2.4/SS         | 9  | I/O | <b>P2.4</b> — Port 2 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 |    | I   | SS — SPI Slave select.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P2.5/SPICLK     | 2  | I/O | <b>P2.5</b> — Port 2 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1/4             |    |     | <b>SPICLK</b> — SPI clock. When configured as master, this pin is output, when configured as slave, this pin is input.                                                                                                                                                                                                                                                                                                                                              |
| 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> 8.12.1 "Port configurations" and <u>Table 13</u> "Static characteristics" for details.                    |
|                 |    |     | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 |    |     | Port 3 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                  |
| P3.0/XTAL2/     | 8  | 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 Real-Time clock/system timer.                                                                                                                                                              |
| P3.1/XTAL1      | 7  | 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 Real-Time clock/system timer.                                                                                                                         |
| 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 and Power-down modes.                                                                                                                                                                                                                                                                                                                                                    |

#### Table 4. P89LPC912 pin description ...continued

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

| Symbol              | Pin | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------------------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| P2.2, P2.3,<br>P2.5 |     | I/O  | <b>Port 2:</b> Port 2 is a 3-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>8.12.1 "Port configurations"</u> and <u>Table 13 "Static characteristics"</u> for details. |  |  |  |  |  |
|                     |     |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                     |     |      | Port 2 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| P2.2/MOSI           | 1   | 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> — SPI master in slave out. When configured as master, this pin is input, when configured as slave, this pin is output.                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| P2.5/SPICLK         | 2   | 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.                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 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> 8.12.1 "Port configurations" and Table 13 "Static characteristics" for details.                           |  |  |  |  |  |
|                     |     |      | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                     |     |      | Port 3 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| P3.0/XTAL2/         | 8   | 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 Real-Time clock/system timer.                                                                                                                                                              |  |  |  |  |  |
| P3.1/XTAL1          | 7   | 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 Real-Time clock/system timer.                                                                                                                         |  |  |  |  |  |
| 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 and Power-down modes.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                     |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |

### Table 5. P89LPC913 pin description ...continued

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

| Name   | Description                    | SFR         | Bit functions and addresses |              |                 |               |            |               |              |           | Reset value         |           |
|--------|--------------------------------|-------------|-----------------------------|--------------|-----------------|---------------|------------|---------------|--------------|-----------|---------------------|-----------|
|        |                                | addr.       | MSB                         |              |                 |               |            |               |              | LSB       | Hex                 | Binary    |
|        |                                | Bit address | FF                          | FE           | FD              | FC            | FB         | FA            | F9           | F8        |                     |           |
| IP1*   | Interrupt priority 1           | F8H         | -                           | PST          | -               | -             | PSPI       | PC            | PKBI         | -         | 00[1]               | 00x0 0000 |
| IP1H   | Interrupt priority 1 high      | F7H         | -                           | PSTH         | -               | -             | PSPIH      | PCH           | PKBIH        | -         | 00[1]               | 00x0 0000 |
| KBCON  | Keypad control register        | 94H         | -                           | -            | -               | -             | -          | -             | PATN<br>_SEL | KBIF      | 00[1]               | xxxx xx00 |
| KBMASK | Keypad interrupt mask register | 86H         |                             |              |                 |               |            |               |              |           | 00                  | 0000 0000 |
| KBPATN | Keypad pattern register        | 93H         |                             |              |                 |               |            |               |              |           | FF                  | 1111 111  |
|        |                                | Bit address | 87                          | 86           | 85              | 84            | 83         | 82            | 81           | 80        |                     |           |
| P0*    | Port 0                         | 80H         |                             | CMP1/<br>KB6 | CMPREF<br>/ KB5 | CIN1A/<br>KB4 |            | CIN2A/<br>KB2 |              |           | <u>[1]</u>          |           |
|        |                                | Bit address | 97                          | 96           | 95              | 94            | 93         | 92            | 91           | 90        |                     |           |
| P1*    | Port 1                         | 90H         |                             |              | RST             |               |            |               | RXD          | TXD       | [1]                 |           |
|        |                                | Bit address | A7                          | A6           | A5              | A4            | A3         | A2            | A1           | <b>A0</b> |                     |           |
| P2*    | Port 2                         | A0H         |                             |              | SPICLK          |               | MISO       | MOSI          |              |           | [1]                 |           |
|        |                                | Bit address | B7                          | <b>B6</b>    | B5              | <b>B</b> 4    | <b>B</b> 3 | <b>B2</b>     | <b>B1</b>    | <b>B0</b> |                     |           |
| P3*    | Port 3                         | B0H         |                             |              |                 |               |            |               | XTAL1        | XTAL2     | [1]                 |           |
| P0M1   | Port 0 output mode 1           | 84H         |                             | (P0M1.6)     | (P0M1.5)        | (P0M1.4)      |            | (P0M1.2)      |              |           | FF                  | 1111 111  |
| P0M2   | Port 0 output mode 2           | 85H         |                             | (P0M2.6)     | (P0M2.5)        | (P0M2.4)      |            | (P0M2.2)      |              |           | 00                  | 000 000   |
| P1M1   | Port 1 output mode 1           | 91H         |                             |              |                 |               |            |               | (P1M1.1)     | (P1M1.0)  | D3[1]               | 11x1 xx11 |
| P1M2   | Port 1 output mode 2           | 92H         |                             |              |                 |               |            |               | (P1M2.1)     | (P1M2.0)  | 00[1]               | 00x0 xx00 |
| P2M1   | Port 2 output mode 1           | A4H         |                             |              | (P2M1.5)        |               | (P2M1.3)   | (P2M1.2)      |              |           | FF                  | 1111 111  |
| P2M2   | Port 2 output mode 2           | A5H         |                             |              | (P2M2.5)        |               | (P2M2.3)   | (P2M2.2)      |              |           | 00                  | 0000 000  |
| P3M1   | Port 3 output mode 1           | B1H         |                             |              |                 |               |            |               | (P3M1.1)     | (P3M1.0)  | 03 <mark>[1]</mark> | xxxx xx11 |
| P3M2   | Port 3 output mode 2           | B2H         |                             |              |                 |               |            |               | (P3M2.1)     | (P3M2.0)  | 00[1]               | xxxx xx00 |
| PCON   | Power control register         | 87H         | SMOD1                       | SMOD0        | BOPD            | BOI           | GF1        | GF0           | PMOD1        | PMOD0     | 00                  | 0000 000  |
| PCONA  | Power control register A       | B5H         | RTCPD                       | -            | VCPD            | -             | -          | SPPD          | SPD          | -         | 00 <u>[1]</u>       | 0000 000  |

2007. All rights reserved. 21 of 66

Product data sheet

Rev. 05 Т

- 28 September 2007

# **NXP Semiconductors**

#### Table 8. P89LPC913 Special function registers ...continued

\* indicates SFRs that are bit addressable.

| 12_910 | Name   | Description     | -     | Bit functions and addresses | Reset value |           |  |
|--------|--------|-----------------|-------|-----------------------------|-------------|-----------|--|
| 3_914_ |        |                 | addr. | MSB LSB                     | Hex         | Binary    |  |
| Ċŋ.    | WDL    | Watchdog load   | C1H   |                             | FF          | 1111 1111 |  |
|        | WFEED1 | Watchdog feed 1 | C2H   |                             |             |           |  |
|        | WFEED2 | Watchdog feed 2 | СЗН   |                             |             |           |  |

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

[2] BRGR1 and BRGR0 must only be written if BRGEN in BRGCON SFR is logic 0. If any of them is written if BRGEN = 1, result is unpredictable.

[3] The RSTSRC register reflects the cause of the P89LPC912 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] 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. Other resets will not affect WDTOF.

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

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

Product data

1 sheet

PC

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

| Name   | Description                          | SFR    | Bit function | ons and ad | ddresses |         |        |           |        |           | Reset                  | /alue    |
|--------|--------------------------------------|--------|--------------|------------|----------|---------|--------|-----------|--------|-----------|------------------------|----------|
|        |                                      | addr.  | MSB          |            |          |         |        |           |        | LSB       | Hex                    | Binary   |
|        | Bit a                                | ddress | D7           | <b>D6</b>  | D5       | D4      | D3     | D2        | D1     | <b>D0</b> |                        |          |
| PSW*   | Program status word                  | D0H    | CY           | AC         | F0       | RS1     | RS0    | OV        | F1     | Р         | 00                     | 0000 00  |
| PT0AD  | Port 0 digital input disable         | F6H    | -            | -          | PT0AD.5  | PT0AD.4 | -      | PT0AD.2   | -      | -         | 00                     | xx00 00  |
| RSTSRC | Reset source register                | DFH    | -            | -          | BOF      | POF     | R_BK   | R_WD      | R_SF   | R_EX      | [3]                    |          |
| RTCCON | Real-time clock control              | D1H    | RTCF         | RTCS1      | RTCS0    | -       | -      | -         | ERTC   | RTCEN     | 60 <mark>[1][6]</mark> | 011x xx( |
| RTCH   | Real-time clock register high        | D2H    |              |            |          |         |        |           |        |           | 00[6]                  | 0000 00  |
| RTCL   | Real-time clock register low         | D3H    |              |            |          |         |        |           |        |           | 00[6]                  | 0000 00  |
| SADDR  | Serial port address register         | A9H    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| SADEN  | Serial port address enable           | B9H    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| SBUF   | Serial port data buffer<br>register  | 99H    |              |            |          |         |        |           |        |           | xx                     | 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       | TI     | RI        | 00                     | 0000 00  |
| SSTAT  | Serial port extended status register | BAH    | DBMOD        | INTLO      | CIDIS    | DBISEL  | FE     | BR        | OE     | STINT     | 00                     | 0000 00  |
| SP     | Stack pointer                        | 81H    |              |            |          |         |        |           |        |           | 07                     | 0000 01  |
| SPCTL  | SPI control register                 | E2H    | SSIG         | SPEN       | DORD     | MSTR    | CPOL   | CPHA      | SPR1   | SPR0      | 04                     | 0000 01  |
| SPSTAT | SPI status register                  | E1H    | SPIF         | WCOL       | -        | -       | -      | -         | -      | -         | 00                     | 00xx xx) |
| SPDAT  | SPI data register                    | E3H    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| TAMOD  | Timer 0 and 1 auxiliary mode         | 8FH    | -            | -          | -        | -       | -      | -         | -      | T0M2      | 00                     | xxx0 xxx |
|        | 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 00  |
| TH0    | Timer 0 high                         | 8CH    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| TH1    | Timer 1 high                         | 8DH    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| TL0    | Timer 0 low                          | 8AH    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| TL1    | Timer 1 low                          | 8BH    |              |            |          |         |        |           |        |           | 00                     | 0000 00  |
| TMOD   | Timer 0 and 1 mode                   | 89H    | -            | -          | T1M1     | T1M0    | TOGATE | T0C/T     | T0M1   | T0M0      | 00                     | 0000 00  |
| TRIM   | Internal oscillator trim registe     | r 96H  |              | -          | TRIM.5   | TRIM.4  | TRIM.3 | TRIM.2    | TRIM.1 | TRIM.0    | [5] [6]                |          |

8-bit microcontrollers with two-clock 80C51 core P89LPC912/913/914

26 of 66

8-bit microcontrollers with two-clock 80C51 core

#### 8.3.6 Clock output (P89LPC912, P89LPC913)

The P89LPC912 supports a user selectable clock output function on the XTAL2/CLKOUT pin when crystal oscillator is not being used. This condition occurs if another clock source has been selected (on-chip RC oscillator, watchdog oscillator, external clock input on X1) and if the Real-Time clock is not using the crystal oscillator as its clock source. This allows external devices to synchronize to the P89LPC912. 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.

#### 8.4 On-chip RC oscillator option

The P89LPC912/913/914 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.

#### 8.5 Watchdog oscillator option

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

#### 8.6 External clock input option (P89LPC912, P89LPC913)

In this configuration, the processor clock is derived from an external source driving the XTAL1/P3.1 pin. The rate may be from 0 Hz up to 12 MHz. The XTAL2/P3.0 pin may be used as a standard port pin or a clock output. When using an oscillator frequency above 12 MHz, the reset input function of P1.5 must be enabled. An external circuit is required to hold the device in reset at power-up until V<sub>DD</sub> has reached its specified level. When system power is removed, V<sub>DD</sub> will fall below the minimum specified operating voltage. When using an oscillator frequency above 12 MHz, in some applications, an external brownout detect circuit may be required to hold the device in reset when V<sub>DD</sub> falls below the minimum specified operating voltage.

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

• DATA

128 B 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.

SFR

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

CODE

64 kB of Code memory space, accessed as part of program execution and via the MOVC instruction. The P89LPC912/913/914 has 1 kB of on-chip Code memory.

#### 8.11 Interrupts

The P89LPC912/913/914 uses a four priority level interrupt structure. This allows great flexibility in controlling the handling of the many interrupt sources.

The P89LPC912 supports 7 interrupt sources: timers 0 and 1, brownout detect, Watchdog/Real-Time clock, keyboard, comparators 1 and 2, and SPI.

The P89LPC913 and P89LPC914 devices support 10 interrupt sources: timers 0 and 1, serial port TX, serial port RX, combined serial port RX/TX, brownout detect, Watchdog/Real-Time clock, keyboard, comparators 1 and 2, and SPI.

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.

Each interrupt source can be individually programmed to one of four priority levels by setting or clearing bits in the interrupt priority registers IPO, IPOH, 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.

#### 8.11.1 External interrupt inputs

The P89LPC912/913/914 has a Keypad Interrupt function. This can be used as an external interrupt input.

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

#### 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 (P89LPC912, P89LPC914)

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

#### 8.16.6 Timer overflow toggle output (P89LPC912, P89LPC914)

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

#### 8.17 RTC/system timer

The P89LPC912/913/914 devices have a simple RTC that allows a user to continue running an accurate timer while the rest of the device is powered-down. The RTC can be a wake-up or an interrupt source. The RTC is a 23-bit down counter comprised of a 7-bit prescaler and a 16-bit loadable down counter. When it reaches all logic 0s, the counter will be reloaded again and the RTCF flag will be set.

On the P89LPC914 the clock source for this counter is the CPU clock (CCLK). On the P89LPC912 and P89LPC913 devices, the clock source for this counter can either be the CPU clock (CCLK) or the XTAL oscillator, provided that the XTAL oscillator is not being used as the CPU clock. If the XTAL oscillator is used as the CPU clock, then the RTC will use CCLK as its clock source.

Only power-on reset will reset the RTC and its associated SFRs to the default state.

#### 8.18 UART (P89LPC913, P89LPC914)

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

#### 8.18.1 Mode 0

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

#### 8.18.7 Break detect

Break detect is reported in the status register (SSTAT). A break is detected when 11 consecutive bits are sensed LOW. The break detect can be used to reset the device.

#### 8.18.8 Double buffering

The UART has a transmit double buffer that allows buffering of the next character to be written to SBUF while the first character is being transmitted. Double buffering allows transmission of a string of characters with only one stop bit between any two characters, as long as the next character is written between the start bit and the stop bit of the previous character.

Double buffering can be disabled. If disabled (DBMOD, i.e., SSTAT.7 = 0), the UART is compatible with the conventional 80C51 UART. If enabled, the UART allows writing to SnBUF while the previous data is being shifted out. Double buffering is only allowed in Modes 1, 2 and 3. When operated in Mode 0, double buffering must be disabled (DBMOD = 0).

#### 8.18.9 Transmit interrupts with double buffering enabled (modes 1, 2 and 3)

Unlike the conventional UART, in double buffering mode, the TX interrupt is generated when the double buffer is ready to receive new data.

#### 8.18.10 The 9<sup>th</sup> bit (bit 8) in double buffering (modes 1, 2 and 3)

If double buffering is disabled TB8 can be written before or after SBUF is written, as long as TB8 is updated some time before that bit is shifted out. TB8 must not be changed until the bit is shifted out, as indicated by the TX interrupt.

If double buffering is enabled, TB8 **must** be updated before SBUF is written, as TB8 will be double-buffered together with SBUF data.

#### 8.19 Serial Peripheral Interface (SPI)

P89LPC912/913/914 provides another high-speed serial communication interface—the SPI interface. SPI is a full-duplex, high-speed, synchronous communication bus with two operation modes: Master mode and Slave mode. Up to 4.5 Mbit/s can be supported in Master mode or 3 Mbit/s in Slave mode. It has a Transfer Completion Flag and Write Collision Flag Protection.

P89LPC912\_913\_914\_5

8-bit microcontrollers with two-clock 80C51 core





8-bit microcontrollers with two-clock 80C51 core



#### 8.23 Comparators and power reduction modes

Either or both comparators may remain enabled when Power-down or Idle mode is activated, but both comparators are disabled automatically in Total Power-down mode.

If a 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.

Comparators consume power in Power-down and Idle modes, 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 comparators via PCONA.5, or put the device in Total Power-down mode.

#### 8.24 Keypad interrupt

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.

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

#### 8.27.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 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.27.5 In-circuit programming

ICP is performed without removing the microcontroller from the system. The ICP facility consists of internal hardware resources to facilitate remote programming of the P89LPC912/913/914 through a two-wire serial interface. The NXP ICP facility has made in-circuit programming in an embedded application, using commercially available programmers, possible with a minimum of additional expense in components and circuit board area. The ICP function uses five pins. Only a small connector (with  $V_{DD}$ ,  $V_{SS}$ ,  $\overline{RST}$ , clock, and data signals) needs to be available to interface your application to a commercial programmer in order to use this feature. Additional details may be found in the P89LPC912/913/914 *User manual*.

#### 8.27.6 In-application programming (IAP-Lite)

In-Application Programming is performed in the application under the control of the microcontroller's firmware. The IAP-Lite facility consists of internal hardware resources to facilitate programming and erasing. The NXP In-Application Programming Lite has made in-application programming in an embedded application possible without additional components. This is accomplished through the use of four SFRs consisting of a control/status register, a data register, and two address registers. Additional details may be found in the P89LPC912/913/914 *User manual*.

#### 8.27.7 Using flash as data storage

The flash code memory array of this device supports **individual** byte erasing and programming. Any byte in the code memory array may be read using the MOVC instruction, provided that the sector containing the byte has not been secured (a MOVC instruction is not allowed to read code memory contents of a secured sector). Thus any byte in a non-secured sector may be used for non-volatile data storage.

#### 8.27.8 User configuration bytes

Some user-configurable features of the P89LPC912/913/914 must be defined at power-up and therefore cannot be set by the program after start of execution. These features are configured through the use of the flash byte UCFG1. Please see the P89LPC912/913/914 *User manual* for additional details.

#### 8.27.9 User sector security bytes

There are four User Sector Security Bytes, each corresponding to one sector. Please see the P89LPC912/913/914 *User manual* for additional details.

8-bit microcontrollers with two-clock 80C51 core

## **10. Static characteristics**

#### Table 13. Static characteristics

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

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

| Symbol                  | Parameter                               | Conditions                                                       |               | Min                   | Typ <mark>[1]</mark> | Max         | Unit  |
|-------------------------|-----------------------------------------|------------------------------------------------------------------|---------------|-----------------------|----------------------|-------------|-------|
| I <sub>DD(oper)</sub>   | operating supply current                |                                                                  |               |                       |                      |             |       |
|                         | P89LPC912, P89LPC913                    | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 12 MHz            | [2]           | -                     | 7                    | 13          | mA    |
|                         |                                         | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 18 MHz            | [2]           | -                     | 11                   | 16          | mA    |
|                         | P89LPC914                               | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 7.373 MHz         | [3]           | -                     | 4                    | 8           | mA    |
| I <sub>DD(idle)</sub>   | Idle mode supply current                |                                                                  |               |                       |                      |             |       |
|                         | P89LPC912, P89LPC913                    | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 12 MHz            | [2]           | -                     | 1.5                  | 5.6         | mA    |
|                         |                                         | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 18 MHz            | [2]           | -                     | 4                    | 6           | mA    |
|                         | P89LPC914                               | V <sub>DD</sub> = 3.6 V;<br>f <sub>osc</sub> = 7.373 MHz         | <u>[3]</u>    | -                     | 1                    | 3           | mA    |
| I <sub>DD(pd)</sub>     | Power-down mode supply<br>current       | V <sub>DD</sub> = 3.6 V                                          | [2][3]        |                       | -                    | 70          | μΑ    |
| I <sub>DD(tpd)</sub>    | total Power-down mode<br>supply current | V <sub>DD</sub> = 3.6 V                                          | <u>[2][3]</u> | -                     | 0.5                  | 5           | μΑ    |
| (dV/dt) <sub>r</sub>    | rise rate                               | of $V_{DD}$                                                      |               | -                     | -                    | 2           | mV/μs |
| (dV/dt) <sub>f</sub>    | fall rate                               | of $V_{DD}$                                                      |               | -                     | -                    | 50          | mV/μs |
| V <sub>DDR</sub>        | data retention supply voltage           |                                                                  |               | 1.5                   | -                    | -           | V     |
| V <sub>th(HL)</sub>     | HIGH-LOW threshold voltage              | except SCL, SDA                                                  |               | $0.22V_{DD}$          | $0.4V_{DD}$          | -           | V     |
| V <sub>th(LH)</sub>     | LOW-HIGH threshold voltage              | except SCL, SDA                                                  |               | -                     | $0.6V_{DD}$          | $0.7V_{DD}$ | V     |
| V <sub>hys</sub>        | hysteresis voltage                      |                                                                  |               | -                     | $0.2V_{DD}$          | -           | V     |
| V <sub>OL</sub>         | LOW-level output voltage                | I <sub>OL</sub> = 20 mA; all ports                               |               | -                     | 0.6                  | 1.0         | V     |
|                         |                                         | I <sub>OL</sub> = 10 mA; all ports                               |               | -                     | 0.3                  | 0.5         | V     |
|                         |                                         | I <sub>OL</sub> = 3.2 mA; all ports                              |               | -                     | 0.2                  | 0.3         | V     |
| V <sub>OH</sub>         | HIGH-level output voltage               | I <sub>OH</sub> = -8 mA; all ports,<br>push-pull mode            |               | V <sub>DD</sub> - 1.0 | -                    | -           | V     |
|                         |                                         | I <sub>OH</sub> = -3.2 mA; all ports,<br>push-pull mode          |               | $V_{DD}-0.7$          | $V_{DD}-0.4$         | -           | V     |
|                         |                                         | I <sub>OH</sub> = –20 μA; all ports,<br>quasi-bidirectional mode |               | $V_{DD}-0.3$          | $V_{DD}-0.2$         | -           | V     |
| C <sub>iss</sub>        | input capacitance                       |                                                                  | <u>[4]</u>    | -                     | -                    | 15          | pF    |
| IIL                     | LOW-state input current                 | $V_I = 0.4 V$ ; all ports                                        | [5]           | -                     | -                    | -80         | μΑ    |
| ILI                     | input leakage current                   | $V_I = V_{IL}$ or $V_{IH}$ ; all ports                           | [6]           | -                     | -                    | ±1          | μΑ    |
| I <sub>THL</sub>        | HIGH-LOW transition current             | $V_1 = 2.0 \text{ V at } V_{DD} = 3.6 \text{ V};$ all ports      | <u>[7][8]</u> | -30                   | -                    | -450        | μΑ    |
| R <sub>RST_N(int)</sub> | internal pull-up resistance on pin RST  |                                                                  |               | 10                    | -                    | 30          | kΩ    |

P89LPC912\_913\_914\_5

8-bit microcontrollers with two-clock 80C51 core

## 11. Dynamic characteristics

#### Table 14. Dynamic characteristics

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

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

| Symbol               | Parameter                                 | Conditions                                                                        | Varia                  | ble clock                | f <sub>osc</sub> = 1 | Unit  |     |
|----------------------|-------------------------------------------|-----------------------------------------------------------------------------------|------------------------|--------------------------|----------------------|-------|-----|
|                      |                                           |                                                                                   | Min                    | Max                      | Min                  | Max   |     |
| f <sub>osc(RC)</sub> | internal RC oscillator frequency          | nominal<br>f = 7.3728 MHz;<br>trimmed to $\pm$ 1 %<br>at T <sub>amb</sub> = 25 °C | 7.189                  | 7.557                    | 7.189                | 7.557 | MHz |
| f <sub>osc(WD)</sub> | internal watchdog oscillator<br>frequency | nominal<br>f = 400 kHz                                                            | 320                    | 520                      | 320                  | 520   | kHz |
| Crystal os           | cillator (P89LPC912, P89LPC913)           |                                                                                   |                        |                          |                      |       |     |
| f <sub>osc</sub>     | oscillator frequency                      |                                                                                   | 0                      | 12                       | -                    | -     | MHz |
| T <sub>cy(clk)</sub> | clock cycle time                          | see Figure 25                                                                     | 83                     | -                        | -                    | -     | ns  |
| f <sub>CLKLP</sub>   | low-power select clock frequency          |                                                                                   | 0                      | 8                        | -                    | -     | MHz |
| Glitch filte         | r                                         |                                                                                   |                        |                          |                      |       |     |
| t <sub>gr</sub>      | glitch rejection                          | P1.5/RST pin                                                                      | -                      | 50                       | -                    | 50    | ns  |
|                      |                                           | any pin except<br>P1.5/RST                                                        | -                      | 15                       | -                    | 15    | ns  |
| t <sub>sa</sub>      | signal acceptance                         | P1.5/RST pin                                                                      | 125                    | -                        | 125                  | -     | ns  |
|                      |                                           | any pin except<br>P1.5/RST                                                        | 50                     | -                        | 50                   | -     | ns  |
| External cl          | lock (P89LPC912, P89LPC913)               |                                                                                   |                        |                          |                      |       |     |
| t <sub>CHCX</sub>    | clock HIGH time                           | see Figure 25                                                                     | 33                     | $T_{cy(clk)} - t_{CLCX}$ | 33                   | -     | ns  |
| t <sub>CLCX</sub>    | clock LOW time                            | see Figure 25                                                                     | 33                     | $T_{cy(clk)} - t_{CHCX}$ | 33                   | -     | ns  |
| t <sub>CLCH</sub>    | clock rise time                           | see Figure 25                                                                     | -                      | 8                        | -                    | 8     | ns  |
| t <sub>CHCL</sub>    | clock fall time                           | see Figure 25                                                                     | -                      | 8                        | -                    | 8     | ns  |
| Shift regis          | ter (UART mode 0 - P89LPC913, F           | 89LPC914)                                                                         |                        |                          |                      |       |     |
| T <sub>XLXL</sub>    | serial port clock cycle time              | see Figure 24                                                                     | 16T <sub>cy(clk)</sub> | -                        | 1333                 | -     | ns  |
| t <sub>QVXH</sub>    | output data set-up to clock rising edge   | see Figure 24                                                                     | 13T <sub>cy(clk)</sub> | -                        | 1083                 | -     | ns  |
| t <sub>XHQX</sub>    | output data hold after clock rising edge  | see Figure 24                                                                     | -                      | $T_{cy(clk)}$ + 20       | -                    | 103   | ns  |
| t <sub>XHDX</sub>    | input data hold after clock rising edge   | see Figure 24                                                                     | -                      | 0                        | -                    | 0     | ns  |
| t <sub>XHDV</sub>    | input data valid to clock rising edge     | see Figure 24                                                                     | 150                    | -                        | 150                  | -     | ns  |
| SPI interfa          | се                                        |                                                                                   |                        |                          |                      |       |     |
| f <sub>SPI</sub>     | SPI operating frequency                   |                                                                                   |                        |                          |                      |       |     |
|                      | 2.0 MHz (slave)                           |                                                                                   | 0                      | CCLK/6                   | 0                    | 2.0   | MHz |
|                      | 3.0 MHz (master)                          |                                                                                   | -                      | CCLK/4                   | -                    | 3.0   | MHz |
| T <sub>SPICYC</sub>  | SPI cycle time                            | see Figure 26,                                                                    |                        |                          |                      |       |     |
|                      | slave                                     | <u>27, 28, 29</u>                                                                 | <sup>6</sup> /CCLK     | -                        | 500                  | -     | ns  |
|                      | master                                    |                                                                                   | 4/CCLK                 | -                        | 333                  | -     | ns  |
|                      |                                           |                                                                                   |                        |                          |                      |       |     |

#### **NXP Semiconductors**

## P89LPC912/913/914

8-bit microcontrollers with two-clock 80C51 core





P89LPC912\_913\_914\_5

8-bit microcontrollers with two-clock 80C51 core

## 15. Revision history

| Table 18. Revision histo | ory             |                                                                                                     |               |                      |
|--------------------------|-----------------|-----------------------------------------------------------------------------------------------------|---------------|----------------------|
| Document ID              | Release date    | Data sheet status                                                                                   | Change notice | Supersedes           |
| P89LPC912_913_914_5      | 20070928        | Product data sheet                                                                                  | -             | P89LPC912_913_914_4  |
| Modifications:           | • Figure 10, 11 | and 12: changed incorrect ch                                                                        | aracter font  |                      |
| P89LPC912_913_914_4      | 20070830        | Product data sheet                                                                                  | -             | P89LPC912_913_914-03 |
| Modifications:           | guidelines of   | f this data sheet has been rede<br>NXP Semiconductors.<br>ave been adapted to the new o<br>PC912HDH |               |                      |
| P89LPC912_913_914-03     | 20041217        | Product data                                                                                        | -             | P89LPC912_913_914-02 |
| P89LPC912_913_914-02     | 20031212        | Product data                                                                                        | 01-A14930     | P89LPC912_913_914-01 |
| P89LPC912_913_914-01     | 20030711        | Objective data                                                                                      | -             | -                    |

8-bit microcontrollers with two-clock 80C51 core

## **18. Contents**

| 1      | General description 1                                 | 8.1                  |
|--------|-------------------------------------------------------|----------------------|
| 2      | Features 1                                            | 8.1                  |
| 2.1    | Principal features 1                                  | 8.1                  |
| 2.2    | Additional features 1                                 | 8.1                  |
| 3      | Product comparison 3                                  | 8.′<br>8.′           |
| 4      | Ordering information 3                                | 8. <sup>-</sup>      |
| 4.1    | Ordering options                                      | 8. <sup>-</sup>      |
| 5      | Block diagram 4                                       | 8. <sup>-</sup>      |
| 6      | Functional diagram 7                                  | 8.1                  |
| 7      | Pinning information                                   | 8.1                  |
| 7.1    | Pinning                                               | 8.1                  |
| 7.2    | Pin description 10                                    | -                    |
| 8      | Functional description                                | 8. <sup>-</sup><br>8 |
| 8.1    | Special function registers                            | o.<br>8.′            |
| 8.2    | Enhanced CPU                                          | o.<br>8.′            |
| 8.3    | Clocks                                                | o.<br>8.             |
| 8.3.1  | Clock definitions 28                                  | 8. <sup>-</sup>      |
| 8.3.2  | CPU clock (OSCCLK)                                    | 8. <sup>-</sup>      |
| 8.3.3  | Low-speed oscillator option (P89LPC912,               | 8. <sup>-</sup>      |
|        | P89LPC913) 28                                         | 8. <sup>-</sup>      |
| 8.3.4  | Medium-speed oscillator option (P89LPC912, P89LPC913) | 8.1                  |
| 8.3.5  | High-speed oscillator option (P89LPC912,              | 8.1                  |
| 0.0.0  | P89LPC913)                                            | _                    |
| 8.3.6  | Clock output (P89LPC912, P89LPC913) 29                | 8.1                  |
| 8.4    | On-chip RC oscillator option                          | 0.                   |
| 8.5    | Watchdog oscillator option                            | 8.1                  |
| 8.6    | External clock input option (P89LPC912,               | 8.1<br>8.2           |
|        | P89LPC913)                                            |                      |
| 8.7    | CCLK wake-up delay 31                                 | 8.2<br>8.2           |
| 8.8    | CCLK modification: DIVM register                      | 0.4<br>8.2           |
| 8.9    | Low power select 31                                   | 8.2                  |
| 8.10   | Memory organization                                   | 8.2                  |
| 8.11   | Interrupts                                            | 8.2                  |
| 8.11.1 | External interrupt inputs                             | 8.2                  |
| 8.12   | I/O ports                                             | 8.2                  |
| 8.12.1 | Port configurations 34                                | 8.2                  |
| 8.12.2 | Quasi-bidirectional output configuration 34           | 8.2                  |
| 8.12.3 | Open-drain output configuration                       | 8.2                  |
| 8.12.4 | Input-only configuration                              | 8.2                  |
| 8.12.5 | Push-pull output configuration                        | 8.2                  |
| 8.12.6 | Port 0 analog functions                               | 8.2                  |
| 8.12.7 | Additional port features                              | 8.2                  |
| 8.13   | Power monitoring functions                            | 8.2                  |
| 8.13.1 | Brownout detection                                    | 8.2                  |
| 8.13.2 | Power-on detection                                    | 8.2                  |

| 8.14    | Power reduction modes                               |      |
|---------|-----------------------------------------------------|------|
| 8.14.1  | Idle mode                                           |      |
| 8.14.2  | Power-down mode                                     |      |
| 8.14.3  | Total Power-down mode                               |      |
| 8.15    | Reset                                               |      |
| 8.16    | Timers/counters 0 and 1                             |      |
| 8.16.1  | Mode 0                                              |      |
| 8.16.2  | Mode 1                                              |      |
| 8.16.3  | Mode 2                                              |      |
| 8.16.4  | Mode 3                                              |      |
| 8.16.5  | Mode 6 (P89LPC912, P89LPC914)                       | . 39 |
| 8.16.6  | Timer overflow toggle output (P89LPC912,            |      |
|         | P89LPC914)                                          |      |
| 8.17    | RTC/system timer.                                   |      |
| 8.18    | UART (P89LPC913, P89LPC914)                         |      |
| 8.18.1  | Mode 0                                              |      |
| 8.18.2  | Mode 1                                              |      |
| 8.18.3  | Mode 2                                              |      |
| 8.18.4  | Mode 3                                              |      |
| 8.18.5  | Baud rate generator and selection                   |      |
| 8.18.6  | Framing error                                       |      |
| 8.18.7  | Break detect                                        |      |
| 8.18.8  | Double buffering                                    | . 41 |
| 8.18.9  | Transmit interrupts with double                     |      |
|         | buffering enabled (modes 1, 2 and 3)                | . 41 |
| 8.18.10 | The 9 <sup>th</sup> bit (bit 8) in double buffering |      |
|         | (modes 1, 2 and 3)                                  | . 41 |
| 8.19    | Serial Peripheral Interface (SPI)                   |      |
| 8.19.1  | Typical SPI configurations                          |      |
| 8.20    | Analog comparators                                  |      |
| 8.21    | Internal reference voltage.                         |      |
| 8.22    | Comparator interrupt                                |      |
| 8.23    | Comparators and power reduction modes               |      |
| 8.24    | Keypad interrupt                                    |      |
| 8.25    | Watchdog timer                                      |      |
| 8.26    | Additional features                                 |      |
| 8.26.1  | Software reset                                      |      |
| 8.26.2  | Dual data pointers                                  |      |
| 8.27    | Flash program memory                                |      |
| 8.27.1  | General description                                 |      |
| 8.27.2  | Features                                            |      |
| 8.27.3  | Flash organization                                  |      |
| 8.27.4  | Flash programming and erasing.                      |      |
| 8.27.5  | In-circuit programming                              | . 49 |
| 8.27.6  | In-application programming (IAP-Lite)               | . 49 |
| 8.27.7  | Using flash as data storage                         |      |
| 8.27.8  | User configuration bytes.                           |      |
| 8.27.9  | User sector security bytes                          | . 49 |

#### continued >>