# E·XFL



#### Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | 8051                                                                     |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 18MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, LED, POR, PWM, WDT                               |
| Number of I/O              | 26                                                                       |
| Program Memory Size        | 4KB (4K x 8)                                                             |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 256 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2.4V ~ 3.6V                                                              |
| Data Converters            | A/D 8x10b                                                                |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 28-LCC (J-Lead)                                                          |
| Supplier Device Package    | 28-PLCC (11.48x11.48)                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89lpc9381fa-112 |

Email: info@E-XFL.COM

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

8-bit microcontroller with 10-bit ADC

### 5. Functional diagram



### **Philips Semiconductors**

## **P89LPC9381**

8-bit microcontroller with 10-bit ADC

| Symbol                                                                       | Pin            | Туре                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------|----------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0[2]/CIN2A/                                                                 | 25             | I/O                                            | <b>P0[2]</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| KBI2/AD01                                                                    | -              | 1                                              | <b>CIN2A</b> — Comparator 2 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                              |                | I                                              | KBI2 — Keyboard input 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                              |                | 1                                              | AD01 — ADC0 channel 1 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P0[3]/CIN1B/                                                                 | 24             | I/O                                            | <b>P0[3]</b> — Port 0 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| KBI3/AD02                                                                    |                | 1                                              | <b>CIN1B</b> — Comparator 1 positive input B.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                              |                | 1                                              | <b>KBI3</b> — Keyboard input 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                              |                | 1                                              | AD02 — ADC0 channel 2 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P0[4]/CIN1A/                                                                 | 23             | I/O                                            | <b>P0[4]</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| KBI4/AD03                                                                    | 20             | ", C                                           | <b>CIN1A</b> — Comparator 1 positive input A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                              |                | I                                              | KBI4 — Keyboard input 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                              |                | 1                                              | AD03 — ADC0 channel 3 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P0[5]/CMPREF/                                                                | 22             | I/O                                            | <b>P0[5]</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| KBI5                                                                         | 22             | I/O                                            | <b>CMPREF</b> — Comparator reference (negative) input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                              |                | 1                                              | <b>KBI5</b> — Keyboard input 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| P0[6]/CMP1/                                                                  | 20             | I/O                                            | <b>P0[6]</b> — Port 0 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <bi6< td=""><td>20</td><td>0</td><td>CMP1 — Comparator 1 output.</td></bi6<> | 20             | 0                                              | CMP1 — Comparator 1 output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                              |                |                                                | <b>KBI6</b> — Keyboard input 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                              | 19             | I/O                                            | <b>P0[7]</b> — Port 0 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| P0[7]/T1/KBI7                                                                | 19             | 1/O<br>1/O                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                              |                | 1/O                                            | T1 — Timer/counter 1 external count input or overflow output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2417-01                                                                      |                |                                                | <b>KBI7</b> — Keyboard input 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| P1[7:0]                                                                      |                | I/O, I<br>[1]                                  | <b>Port 1:</b> Port 1 is an 8-bit I/O port with a user-configurable output type, except for three pins as noted below. During reset Port 1 latches are configured in the input only mode with the internal pull-up disabled. The operation of the configurable Port 1 pins as inputs and outputs depends upon the port configuration selected. Each of the configurable port pins are programmed independently. Refer to <u>Section 7.13.1 "Port configurations"</u> and <u>Table 10 "Static characteristics"</u> for details. P1[2] to P1[3] are open-drain when used as outputs. P1[5] is input only. All pins have Schmitt triggered inputs. |
|                                                                              |                |                                                | Port 1 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                              | 10             | I/O                                            | <b>P1[0]</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| P1[0]/TXD                                                                    | 18             | 1/0                                            | <b>F I [0]</b> — Port T bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| P1[0]/TXD                                                                    | 18             | 0                                              | <b>TXD</b> — Transmitter output for the serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                              | 18<br>17       |                                                | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                              |                | 0                                              | <b>TXD</b> — Transmitter output for the serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| P1[1]/RXD                                                                    |                | 0<br>I/O                                       | TXD — Transmitter output for the serial port.      P1[1] — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 91[1]/RXD                                                                    | 17             | O<br>I/O<br>I                                  | TXD — Transmitter output for the serial port.         P1[1] — Port 1 bit 1.         RXD — Receiver input for the serial port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 91[1]/RXD                                                                    | 17             | 0<br>I/O<br>I<br>I/O                           | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when</li> </ul>                                                                                                                                                                                                                                                                                                                                      |
| P1[1]/RXD<br>P1[2]/T0/SCL                                                    | 17             | 0<br>I/O<br>I/O<br>I/O                         | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when used as output).</li> </ul>                                                                                                                                                                                                                                                                                                                     |
| P1[1]/RXD<br>P1[2]/T0/SCL                                                    | 17<br>12       | 0<br>1/0<br>1<br>1/0<br>1/0                    | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when used as output).</li> <li>SCL — I<sup>2</sup>C-bus serial clock input/output.</li> </ul>                                                                                                                                                                                                                                                        |
| P1[1]/RXD<br>P1[2]/T0/SCL                                                    | 17<br>12       | 0<br>1/0<br>1<br>1/0<br>1/0<br>1/0<br>1/0      | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when used as output).</li> <li>SCL — I<sup>2</sup>C-bus serial clock input/output.</li> <li>P1[3] — Port 1 bit 3 (open-drain when used as output).</li> </ul>                                                                                                                                                                                        |
| P1[0]/TXD<br>P1[1]/RXD<br>P1[2]/T0/SCL<br>P1[3]/INT0/SDA                     | 17<br>12       | 0<br>1/0<br>1<br>1/0<br>1/0<br>1/0<br>1        | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when used as output).</li> <li>SCL — I<sup>2</sup>C-bus serial clock input/output.</li> <li>P1[3] — Port 1 bit 3 (open-drain when used as output).</li> <li>INTO — External interrupt 0 input.</li> </ul>                                                                                                                                            |
| P1[1]/RXD<br>P1[2]/T0/SCL<br>P1[3]/INT0/SDA                                  | 17<br>12<br>11 | 0<br>1/0<br>1<br>1/0<br>1/0<br>1/0<br>1<br>1/0 | <ul> <li>TXD — Transmitter output for the serial port.</li> <li>P1[1] — Port 1 bit 1.</li> <li>RXD — Receiver input for the serial port.</li> <li>P1[2] — Port 1 bit 2 (open-drain when used as output).</li> <li>T0 — Timer/counter 0 external count input or overflow output (open-drain when used as output).</li> <li>SCL — I<sup>2</sup>C-bus serial clock input/output.</li> <li>P1[3] — Port 1 bit 3 (open-drain when used as output).</li> <li>INTO — External interrupt 0 input.</li> <li>SDA — I<sup>2</sup>C-bus serial data input/output.</li> </ul>                                                                                |

### **Philips Semiconductors**

## P89LPC9381

8-bit microcontroller with 10-bit ADC

| Table 3. Pin c | description | continued |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|-------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol         | Pin         | Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P1[5]/RST      | 6           | I         | P1[5] — Port 1 bit 5 (input only).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |             | I         | $\overline{RST}$ — External Reset input during power-on or if selected via UCFG1. When functioning as a reset input, a LOW on this pin resets the microcontroller, causing I/O ports and peripherals to take on their default states, and the processor begins execution at address 0. Also used during a power-on sequence to force In-System Programming mode. 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 range. |
| P1[6]          | 5           | I/O       | P1[6] — Port 1 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| P1[7]/AD04     | 4           | I/O       | <b>P1[7]</b> — Port 1 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I         | AD04 — ADC0 channel 4 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P2[0] to P2[7] |             | I/O       | <b>Port 2:</b> Port 2 is an 8-bit I/O port with a user-configurable output type. During reset Port 2 latches are configured in the input only mode with the internal pull-up disabled. The operation of Port 2 pins as inputs and outputs depends upon the port configuration selected. Each port pin is configured independently. Refer to <u>Section 7.13.1 "Port configurations"</u> and <u>Table 10 "Static characteristics"</u> for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |             |           | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |             |           | Port 2 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| P2[0]/AD07     | 1           | I/O       | <b>P2[0]</b> — Port 2 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I         | AD07 — ADC0 channel 7 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P2[1]/AD06     | 2           | I/O       | <b>P2[1]</b> — Port 2 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I         | AD06 — ADC0 channel 6 analog input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P2[2]/MOSI     | 13          | I/O       | <b>P2[2]</b> — Port 2 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I/O       | <b>MOSI</b> — SPI master out slave in. When configured as master, this pin is output; when configured as slave, this pin is input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| P2[3]/MISO     | 14          | I/O       | <b>P2[3]</b> — Port 2 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I/O       | <b>MISO</b> — When configured as master, this pin is input, when configured as slave, this pin is output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P2[4]/SS       | 15          | I/O       | <b>P2[4]</b> — Port 2 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I         | <b>SS</b> — SPI Slave select.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| P2[5]/SPICLK   | 16          | I/O       | <b>P2[5]</b> — Port 2 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |             | I/O       | <b>SPICLK</b> — SPI clock. When configured as master, this pin is output; when configured as slave, this pin is input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P2[6]          | 27          | I/O       | <b>P2[6]</b> — Port 2 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P2[7]          | 28          | I/O       | <b>P2[7]</b> — Port 2 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### Table 3. Pin description ...continued

#### 8-bit microcontroller with 10-bit ADC

| Table 3.        | Pin description | continued |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Pin             | Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P3[1:0]         |                 | 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 7.13.1 "Port configurations"</u> and <u>Table 10 "Static characteristics"</u> for details. |
|                 |                 |           | All pins have Schmitt triggered inputs.                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 |                 |           | Port 3 also provides various special functions as described below:                                                                                                                                                                                                                                                                                                                                                                               |
| P3[0]/XTAL      | .2/ 9           | I/O       | <b>P3[0]</b> — Port 3 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CLKOUT          |                 | 0         | <b>XTAL2</b> — Output from the oscillator amplifier (when a crystal oscillator option is selected via the flash configuration.                                                                                                                                                                                                                                                                                                                   |
|                 |                 | 0         | <b>CLKOUT</b> — CPU clock divided by 2 when enabled via SFR bit (ENCLK -TRIM.6).<br>It can be used if the CPU clock is the internal RC oscillator, watchdog oscillator or<br>external clock input, except when XTAL1/XTAL2 are used to generate clock source<br>for the RTC/system timer.                                                                                                                                                        |
| P3[1]/XTAL      | .1 8            | I/O       | <b>P3[1]</b> — Port 3 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                 |                 | I         | <b>XTAL1</b> — Input to the oscillator circuit and internal clock generator circuits (when selected via the flash configuration). It can be a port pin if internal RC oscillator or watchdog oscillator is used as the CPU clock source, <b>and</b> if XTAL1/XTAL2 are not used to generate the clock for the RTC/system timer.                                                                                                                  |
| V <sub>SS</sub> | 7               | I         | ground: 0 V reference.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V <sub>DD</sub> | 21              | Ι         | <b>power supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                                                                                                                                 |

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

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

| Name   | Description                    | SFR     | Bit function | ons and ad   | dresses        |               |               |               |               |              | Reset               | value    |
|--------|--------------------------------|---------|--------------|--------------|----------------|---------------|---------------|---------------|---------------|--------------|---------------------|----------|
|        |                                | addr.   | MSB          |              |                |               |               |               |               | LSB          | Hex                 | Binary   |
| IP0H   | Interrupt priority 0 high      | B7H     | -            | PWDRT<br>H   | PBOH           | PSH/<br>PSRH  | PT1H          | PX1H          | PT0H          | PX0H         | 00 <mark>[2]</mark> | x000 00  |
|        | Bit                            | address | FF           | FE           | FD             | FC            | FB            | FA            | <b>F9</b>     | <b>F8</b>    |                     |          |
| IP1*   | Interrupt priority 1           | F8H     | -            | PST          | -              | -             | PSPI          | PC            | PKBI          | PI2C         | 00[2]               | 00x0 00  |
| IP1H   | Interrupt priority 1 high      | F7H     | -            | PSTH         | -              | -             | PSPIH         | PCH           | PKBIH         | PI2CH        | 00[2]               | 00x0 00  |
| IP2    | Interrupt priority 2           | D6H     | -            | -            | -              | -             | -             | -             | PADC          | -            | 00[2]               | 00x0 00  |
| IP2H   | Interrupt priority 2 high      | D7H     | -            | -            | -              | -             | -             | -             | PADCH         | -            | 00[2]               | 00x0 00  |
| KBCON  | Keypad control register        | 94H     | -            | -            | -              | -             | -             | -             | PATN<br>_SEL  | KBIF         | 00[2]               | XXXX XX( |
| KBMASK | Keypad interrupt mask register | 86H     |              |              |                |               |               |               |               |              | 00                  | 0000 00  |
| KBPATN | Keypad pattern register        |         |              |              |                |               |               |               |               |              | FF                  | 1111 11  |
|        | Bit                            | address | 87           | 86           | 85             | 84            | 83            | 82            | 81            | 80           |                     |          |
| P0*    | Port 0                         | 80H     | T1/KB7       | CMP1<br>/KB6 | CMPREF<br>/KB5 | CIN1A<br>/KB4 | CIN1B<br>/KB3 | CIN2A<br>/KB2 | CIN2B<br>/KB1 | CMP2<br>/KB0 |                     | [2]      |
|        | Bit                            | address | 97           | 96           | 95             | 94            | 93            | 92            | 91            | 90           |                     |          |
| P1*    | Port 1                         | 90H     | -            | -            | RST            | INT1          | INT0/<br>SDA  | T0/SCL        | RXD           | TXD          |                     | [2]      |
|        | Bit                            | address | 97           | 96           | 95             | 94            | 93            | 92            | 91            | 90           |                     |          |
| P2*    | Port 2                         | A0H     | -            | -            | SPICLK         | SS            | MISO          | MOSI          | -             | -            |                     | [2]      |
|        | Bit                            | address | B7           | <b>B6</b>    | <b>B5</b>      | <b>B4</b>     | <b>B3</b>     | <b>B2</b>     | B1            | <b>B0</b>    |                     |          |
| P3*    | Port 3                         | B0H     | -            | -            | -              | -             | -             | -             | XTAL1         | XTAL2        |                     | [2]      |
| P0M1   | Port 0 output mode 1           | 84H     | (P0M1.7)     | (P0M1.6)     | (P0M1.5)       | (P0M1.4)      | (P0M1.3)      | (P0M1.2)      | (P0M1.1)      | (P0M1.0)     | FF[2]               | 1111 11  |
| P0M2   | Port 0 output mode 2           | 85H     | (P0M2.7)     | (P0M2.6)     | (P0M2.5)       | (P0M2.4)      | (P0M2.3)      | (P0M2.2)      | (P0M2.1)      | (P0M2.0)     | 00[2]               | 0000 00  |
| P1M1   | Port 1 output mode 1           | 91H     | (P1M1.7)     | (P1M1.6)     | -              | (P1M1.4)      | (P1M1.3)      | (P1M1.2)      | (P1M1.1)      | (P1M1.0)     | D3[2]               | 11x1 xx  |
| P1M2   | Port 1 output mode 2           | 92H     | (P1M2.7)     | (P1M2.6)     | -              | (P1M2.4)      | (P1M2.3)      | (P1M2.2)      | (P1M2.1)      | (P1M2.0)     | 00[2]               | 00x0 xx  |
| P2M1   | Port 2 output mode 1           | A4H     | (P2M1.7)     | (P2M1.6)     | (P2M1.5)       | (P2M1.4)      | (P2M1.3)      | (P2M1.2)      | (P2M1.1)      | (P2M1.0)     | FF[2]               | 1111 11  |
| P2M2   | Port 2 output mode 2           | A5H     | (P2M2.7)     | (P2M2.6)     | (P2M2.5)       | (P2M2.4)      | (P2M2.3)      | (P2M2.2)      | (P2M2.1)      | (P2M2.0)     | 00[2]               | 0000 00  |
| P3M1   | Port 3 output mode 1           | B1H     | -            | -            | -              | -             | -             | -             | (P3M1.1)      | (P3M1.0)     | 03 <mark>[2]</mark> | xxxx xx1 |
| P3M2   | Port 3 output mode 2           | B2H     | -            | -            | -              | -             | -             | -             | (P3M2.1)      | (P3M2.0)     | 00[2]               | xxxx xx( |

8-bit microcontroller with 10-bit ADC P89LPC9381

13 of 60

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

| Name   | Description                          | SFR    | Bit function | ons and ad | dresses   |           |         |           |         |           | Reset                  | /alue    |
|--------|--------------------------------------|--------|--------------|------------|-----------|-----------|---------|-----------|---------|-----------|------------------------|----------|
|        |                                      | addr.  | MSB          |            |           |           |         |           |         | LSB       | Hex                    | Binary   |
| PCON   | Power control register               | 87H    | SMOD1        | SMOD0      | BOPD      | BOI       | GF1     | GF0       | PMOD1   | PMOD0     | 00                     | 0000 000 |
| PCONA  | Power control register A             | B5H    | RTCPD        | -          | VCPD      | ADPD      | I2PD    | SPPD      | SPD     | -         | 00[2]                  | 0000 000 |
|        | Bit a                                | ddress | D7           | <b>D6</b>  | <b>D5</b> | <b>D4</b> | D3      | <b>D2</b> | D1      | <b>D0</b> |                        |          |
| PSW*   | Program status word                  | D0H    | CY           | AC         | F0        | RS1       | RS0     | OV        | F1      | Р         | 00                     | 0000 000 |
| PT0AD  | Port 0 digital input disable         | F6H    | -            | -          | PT0AD.5   | PT0AD.4   | PT0AD.3 | PT0AD.2   | PT0AD.1 | -         | 00                     | xx00 000 |
| RSTSRC | Reset source register                | DFH    | -            | -          | BOF       | POF       | R_BK    | R_WD      | R_SF    | R_EX      |                        | [3]      |
| RTCCON | RTC control                          | D1H    | RTCF         | RTCS1      | RTCS0     | -         | -       | -         | ERTC    | RTCEN     | 60 <mark>[2][4]</mark> | 011x xx0 |
| RTCH   | RTC register high                    | D2H    |              |            |           |           |         |           |         |           | 00[4]                  | 0000 000 |
| RTCL   | RTC register low                     | D3H    |              |            |           |           |         |           |         |           | 00[4]                  | 0000 000 |
| SADDR  | Serial port address<br>register      | A9H    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| SADEN  | Serial port address enable           | B9H    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| SBUF   | Serial Port data buffer register     | 99H    |              |            |           |           |         |           |         |           | xx                     | XXXX XXX |
|        | Bit a                                | ddress | 9F           | 9E         | 9D        | 9C        | 9B      | <b>9A</b> | 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 xxx |
| SPDAT  | SPI data register                    | E3H    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| TAMOD  | Timer 0 and 1 auxiliary mode         | 8FH    | -            | -          | -         | T1M2      | -       | -         | -       | T0M2      | 00                     | xxx0 xxx |
|        | Bit ac                               | ddress | 8F           | 8E         | 8D        | 8C        | 8B      | <b>8A</b> | 89      | 88        |                        |          |
| TCON*  | Timer 0 and 1 control                | 88H    | TF1          | TR1        | TF0       | TR0       | IE1     | IT1       | IE0     | IT0       | 00                     | 0000 000 |
| TH0    | Timer 0 high                         | 8CH    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| TH1    | Timer 1 high                         | 8DH    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| TL0    | Timer 0 low                          | 8AH    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |
| TL1    | Timer 1 low                          | 8BH    |              |            |           |           |         |           |         |           | 00                     | 0000 000 |

8-bit microcontroller with 10-bit ADC P89LPC9381

Product data sheet

#### Table 4. P89LPC9381 Special function registers ...continued P89LPC

\* indicates SFRs that are bit addressable.

| Name   | Description                        | SFR   | Bit functions and addresses |       |        |        |               |        |          | Reset value |     |               |
|--------|------------------------------------|-------|-----------------------------|-------|--------|--------|---------------|--------|----------|-------------|-----|---------------|
|        |                                    | addr. | MSB                         |       |        |        |               |        |          | LSB         | Hex | Binary        |
| TMOD   | Timer 0 and 1 mode                 | 89H   | T1GATE                      | T1C/T | T1M1   | T1M0   | <b>T0GATE</b> | T0C/T  | T0M1     | T0M0        | 00  | 0000 0000     |
| TPCR2H | Prescaler control register<br>high | CBH   | -                           | -     | -      | -      | -             | -      | TPCR2H.1 | TPCR2H.0    | 00  | xxxx xx00     |
| TPCR2L | Prescaler control register low     | CAH   |                             |       |        |        |               |        |          |             | 00  | 0000 0000     |
| TRIM   | Internal oscillator trim register  | 96H   | RCCLK                       | ENCLK | TRIM.5 | TRIM.4 | TRIM.3        | TRIM.2 | TRIM.1   | TRIM.0      |     | <u>[4][5]</u> |
| 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] BRGR1 and BRGR0 must only be written if BRGEN in BRGCON SFR is logic 0. If any are written while BRGEN = 1, the result is unpredictable.

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

[3] The RSTSRC register reflects the cause of the P89LPC9381 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 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.

υ

Rev.

Product data

sheet

#### 7.2 Enhanced CPU

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

#### 7.3 Clocks

#### 7.3.1 Clock definitions

The P89LPC9381 device has several internal clocks as defined below:

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

Note: fosc is defined as the OSCCLK frequency.

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

RCCLK — The internal 7.373 MHz RC oscillator output.

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

#### 7.3.2 CPU clock (OSCCLK)

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

#### 7.3.3 Low speed oscillator option

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

#### 7.3.4 Medium speed oscillator option

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

#### 7.3.5 High speed oscillator option

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

#### 7.3.6 Clock output

The P89LPC9381 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 RTC is not using the crystal oscillator as its clock source. This allows external devices to synchronize to the P89LPC9381. This output is enabled by the ENCLK bit in the TRIM register.

#### 7.13 I/O ports

The P89LPC9381 has four I/O ports: Port 0, Port 1, Port 2, and Port 3. Ports 0, 1 and 2 are 8-bit ports, and Port 3 is a 2-bit port. The exact number of I/O pins available depends upon the clock and reset options chosen, as shown in Table 7.

| 1                                          |                                                                                                                                                                                                                                                    |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset option                               | Number of I/O pins<br>(28-pin package)                                                                                                                                                                                                             |
| No external reset (except during power-up) | 26                                                                                                                                                                                                                                                 |
| External RST pin supported                 | 25                                                                                                                                                                                                                                                 |
| No external reset (except during power-up) | 25                                                                                                                                                                                                                                                 |
| External RST pin supported <sup>[1]</sup>  | 24                                                                                                                                                                                                                                                 |
| No external reset (except during power-up) | 24                                                                                                                                                                                                                                                 |
| External RST pin supported <sup>[1]</sup>  | 23                                                                                                                                                                                                                                                 |
|                                            | Reset option         No external reset (except during power-up)         External RST pin supported         No external reset (except during power-up)         External RST pin supported <sup>[1]</sup> No external reset (except during power-up) |

[1] Required for operation above 12 MHz.

#### 7.13.1 Port configurations

All but three I/O port pins on the P89LPC9381 may be configured by software to one of four types on a bit-by-bit basis. These are: quasi-bidirectional (standard 80C51 port outputs), push-pull, open-drain, and input-only. Two configuration registers for each port select the output type for each port pin.

- 1. P1[5] (RST) can only be an input and cannot be configured.
- 2. P1[2] (SCL/T0) and P1[3] (SDA/INT0) may only be configured to be either input-only or open-drain.

#### 7.13.1.1 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 P89LPC9381 is a 3 V device, but the pins are 5 V tolerant. In quasi-bidirectional mode, if a user applies 5 V on the pin, there will be a current flowing from the pin to  $V_{DD}$ , causing extra power consumption. Therefore, applying 5 V in quasi-bidirectional mode is discouraged.

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

#### 7.13.1.2 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.

#### 7.13.1.3 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.

#### 7.13.1.4 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.

#### 7.13.2 Port 0 analog functions

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

Digital outputs are disabled by putting the port output into the Input-Only (high-impedance) mode.

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

#### 7.13.3 Additional port features

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

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

Every output on the P89LPC9381 has been designed to sink typical LED drive current. However, there is a maximum total output current for all ports which must not be exceeded. Please refer to <u>Table 10 "Static characteristics</u>" for detailed specifications.

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

#### 7.14 Power monitoring functions

The P89LPC9381 incorporates power monitoring functions designed to prevent incorrect operation during initial power-up and power loss or reduction during operation. This is accomplished with two hardware functions: Power-on detect and brownout detect.

#### 7.14.1 Brownout detection

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

#### 7.16 Reset

The P1[5]/RST pin can function as either an active-LOW reset input or as a digital input, P1[5]. The RPE (Reset Pin Enable) bit in UCFG1, when set to '1', enables the external reset input function on P1[5]. When cleared, P1[5] may be used as an input pin.

**Remark:** During a power-up sequence, The RPE selection is overridden and this pin will always functions as a reset input. **An external circuit connected to this pin should not hold this pin LOW during a power-on sequence as this will keep the device in reset.** After power-up this input will function either as an external reset input or as a digital input as defined by the RPE bit. Only a power-up reset will temporarily override the selection defined by RPE bit. Other sources of reset will not override the RPE bit.

Reset can be triggered from the following sources:

- External reset pin (during power-up or if user configured via UCFG1);
- Power-on detect;
- Brownout detect;
- Watchdog timer;
- Software reset;
- UART break character detect reset.

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 '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.

#### 7.16.1 Reset vector

Following reset, the P89LPC9381 will fetch instructions from either address 0000H or the Boot address. The Boot address is formed by using the Boot Vector as the high byte of the address and the low byte of the address = 00H.

The Boot address will be used if a UART break reset occurs, or the non-volatile Boot Status bit (BOOTSTAT.0) = 1, or the device is forced into ISP mode during power-on (see P89LPC9381 *User's Manual*). Otherwise, instructions will be fetched from address 0000H.

#### 7.17 Timers/counters 0 and 1

The P89LPC9381 has two general purpose counter/timers which are upward compatible with the standard 80C51 Timer 0 and Timer 1. Both can be configured to operate either as timers or event counter. An option to automatically toggle the T0 and/or T1 pins upon timer overflow has been added.

In the 'Timer' function, the register is incremented every machine cycle.

In the 'Counter' function, the register is incremented in response to a 1-to-0 transition at its corresponding external input pin, T0 or T1. In this function, the external input is sampled once during every machine cycle.

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.

#### 7.23 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 or Power-down modes. 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.

providing an input signal to one of two comparator inputs. The control logic in combination with the 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.

#### 8.2 Features

- 10-bit, 8-channel multiplexed input, successive approximation ADC.
- Eight result register pairs.
- 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
- Three conversion start modes
  - Timer triggered start
  - Start immediately
  - Edge triggered
- 10-bit conversion time of 4 μs at an ADC clock of 9 MHz
- Interrupt or polled operation
- High and Low Boundary limits interrupt; selectable in or out-of-range
- Clock divider
- Power-down mode

#### 8.3 Block diagram



#### 8.4 ADC operating modes

#### 8.4.1 Fixed channel, single conversion mode

A single input channel can be selected for conversion. A single conversion will be performed and the result placed in the result register pair which corresponds to the selected input channel. An interrupt, if enabled, will be generated after the conversion completes.

#### 8.4.2 Fixed channel, continuous conversion mode

A single input channel can be selected for continuous conversion. The results of the conversions will be sequentially placed in the eight result register pairs. The user may select whether an interrupt can be generated after every four or every eight conversions. Additional conversion results will again cycle through the result register pairs, overwriting the previous results. Continuous conversions continue until terminated by the user.

#### 8.4.3 Auto scan, single conversion mode

Any combination of the eight input channels can be selected for conversion. A single conversion of each selected input will be performed and the result placed in the result register pair which corresponds to the selected input channel. The user may select whether an interrupt, if enabled, will be generated after either the first four conversions have occurred or all selected channels have been converted. If the user selects to generate an interrupt after the four input channels have been converted, a second interrupt will be generated after the remaining input channels have been converted. If only a single channel is selected this is equivalent to single channel, single conversion mode.

#### 8.4.4 Auto scan, continuous conversion mode

Any combination of the eight input channels can be selected for conversion. A conversion of each selected input will be performed and the result placed in the result register pair which corresponds to the selected input channel. The user may select whether an interrupt, if enabled, will be generated after either the first four conversions have occurred or all selected channels have been converted. If the user selects to generate an interrupt after the four input channels have been converted, a second interrupt will be generated after the remaining input channels have been converted. After all selected channels have been converted, the process will repeat starting with the first selected channel. Additional conversion results will again cycle through the eight result register pairs, overwriting the previous results. Continous conversions continue until terminated by the user.

#### 8.4.5 Dual channel, continuous conversion mode

This is a variation of the auto scan continuous conversion mode where conversion occurs on two user-selectable inputs. The result of the conversion of the first channel is placed in the result register pair, AD0DAT0R and AD0DAT0L. The result of the conversion of the second channel is placed in result register pair, AD0DAT1R and AD0DAT1L. The first channel is again converted and its result stored in AD0DAT2R and AD0DAT2L. The second channel is again converted and its result placed in AD0DAT3R and AD0DAT3L, etc. An interrupt is generated, if enabled, after every set of four or eight conversions (user selectable).

41 of 60

#### Table 10. 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   |
|----------------------|------------------------------------------------------------|------------------------------------------------------------|------|----------------------|------|--------|
| $R_{RST_N(int)}$     | internal pull-up resistance on pin $\overline{\text{RST}}$ |                                                            | 10   | -                    | 30   | kΩ     |
| V <sub>bo</sub>      | brownout trip voltage                                      | 2.4 V < V <sub>DD</sub> < 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 <sub>bg</sub>     | band gap temperature<br>coefficient                        |                                                            | -    | 10                   | 20   | ppm/°C |

[1] Typical ratings are not guaranteed. The values listed are at room temperature,  $V_{DD} = 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(tpd)</sub> specification is measured using an external clock with the following functions disabled: comparators, real-time clock, brownout detect, and watchdog timer.

[4] See Section 9 "Limiting values" on page 43 for steady state (non-transient) limits on  $I_{OL}$  or  $I_{OH}$ . If  $I_{OL}/I_{OH}$  exceeds the test condition,  $V_{OL}/V_{OH}$  may exceed the related specification.

[5] Pin capacitance is characterized but not tested.

[6] Measured with port in quasi-bidirectional mode.

[7] Measured with port in high-impedance mode.

[8] 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 microcontroller with 10-bit ADC

#### Table 11. Dynamic characteristics (12 MHz) ... continued

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

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

| Symbol               | Parameter                                                             | Conditions                                           | Varia              | ble clock | f <sub>osc</sub> = 1 | 2 MHz | Unit |
|----------------------|-----------------------------------------------------------------------|------------------------------------------------------|--------------------|-----------|----------------------|-------|------|
|                      |                                                                       |                                                      | Min                | Max       | Min                  | Max   |      |
| t <sub>SPILAG</sub>  | SPI enable lag time                                                   | see Figure 20                                        |                    |           |                      |       |      |
|                      | slave                                                                 | and <u>21</u>                                        | 250                | -         | 250                  | -     | ns   |
| t <sub>SPICLKH</sub> | SPICLK HIGH time                                                      | see Figure 18,                                       |                    |           |                      |       |      |
|                      | master                                                                | 19, 20 and 21                                        | <sup>2</sup> /CCLK | -         | 165                  | -     | ns   |
|                      | slave                                                                 |                                                      | <sup>3</sup> /CCLK | -         | 250                  | -     | ns   |
| t <sub>SPICLKL</sub> | SPICLK LOW time                                                       | see Figure 18,                                       |                    |           |                      |       |      |
|                      | master                                                                | <u>19, 20</u> and <u>21</u>                          | <sup>2</sup> /CCLK | -         | 165                  | -     | ns   |
|                      | slave                                                                 |                                                      | <sup>3</sup> /CCLK | -         | 250                  | -     | ns   |
| t <sub>SPIDSU</sub>  | SPI data set-up time                                                  | see Figure 18,<br><u>19, 20</u> and <u>21</u>        | 100                | -         | 100                  | -     | ns   |
| t <sub>SPIDH</sub>   | SPI data hold time                                                    | see Figure 18,<br>19, 20 and 21                      | 100                | -         | 100                  | -     | ns   |
| t <sub>SPIA</sub>    | SPI access time                                                       | see Figure 20                                        |                    |           |                      |       |      |
|                      | slave                                                                 | and <u>21</u>                                        | 0                  | 120       | 0                    | 120   | ns   |
| t <sub>SPIDIS</sub>  | SPI disable time                                                      | see Figure 20                                        |                    |           |                      |       |      |
|                      | slave                                                                 | and <u>21</u>                                        | 0                  | 240       | -                    | 240   | ns   |
| t <sub>SPIDV</sub>   | SPI enable to output data valid time                                  | see Figure 18,                                       |                    |           |                      |       |      |
|                      | slave                                                                 | <u>19, 20</u> and <u>21</u>                          | -                  | 240       | -                    | 240   | ns   |
|                      | master                                                                |                                                      | -                  | 167       | -                    | 167   | ns   |
| t <sub>SPIOH</sub>   | SPI output data hold time                                             | see <u>Figure 18,</u><br><u>19, 20</u> and <u>21</u> | 0                  | -         | 0                    | -     | ns   |
| t <sub>SPIR</sub>    | SPI rise time                                                         | see Figure 18,                                       |                    |           |                      |       |      |
|                      | SPI outputs (SPICLK, MOSI, MISO)                                      | <u>19, 20</u> and <u>21</u>                          | -                  | 100       | -                    | 100   | ns   |
|                      | $\frac{\text{SPI inputs (SPICLK, MOSI, MISO,}}{\overline{\text{SS}}}$ |                                                      | -                  | 2000      | -                    | 2000  | ns   |
| t <sub>SPIF</sub>    | SPI fall time                                                         | see Figure 18,                                       |                    |           |                      |       |      |
|                      | SPI outputs (SPICLK, MOSI,<br>MISO)                                   | <u>19, 20</u> and <u>21</u>                          | -                  | 100       | -                    | 100   | ns   |
|                      | SPI inputs (SPICLK, MOSI, MISO, SS)                                   |                                                      | -                  | 2000      | -                    | 2000  | ns   |

[1] Parameters are valid over operating temperature range unless otherwise specified.

[2] Parts are tested to 2 MHz, but are guaranteed to operate down to 0 Hz.

8-bit microcontroller with 10-bit ADC

#### Table 12. Dynamic characteristics (18 MHz)

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

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

| Symbol               | Parameter                                     | Conditions                  | Varia                  | able clock               | f <sub>osc</sub> = 1 | 8 MHz | Unit |
|----------------------|-----------------------------------------------|-----------------------------|------------------------|--------------------------|----------------------|-------|------|
|                      |                                               |                             | Min                    | Max                      | Min                  | Max   |      |
| f <sub>osc(RC)</sub> | internal RC oscillator frequency              |                             | 7.189                  | 7.557                    | 7.189                | 7.557 | MHz  |
| f <sub>osc(WD)</sub> | internal watchdog oscillator frequency        |                             | 320                    | 520                      | 320                  | 520   | kHz  |
| f <sub>osc</sub>     | oscillator frequency                          |                             | 0                      | 18                       | -                    | -     | MHz  |
| T <sub>cy(clk)</sub> | clock cycle time                              | see Figure 17               | 55                     | -                        | -                    | -     | ns   |
| f <sub>CLKLP</sub>   | low-power select clock frequency              |                             | 0                      | 8                        | -                    | -     | MHz  |
| Glitch filte         | r                                             |                             |                        |                          |                      |       |      |
| t <sub>gr</sub>      | glitch rejection time                         | P1[5]/RST pin               | -                      | 50                       | -                    | 50    | ns   |
|                      |                                               | any pin except<br>P1[5]/RST | -                      | 15                       | -                    | 15    | ns   |
| t <sub>sa</sub>      | signal acceptance time                        | P1[5]/RST pin               | 125                    | -                        | 125                  | -     | ns   |
|                      |                                               | any pin except<br>P1[5]/RST | 50                     | -                        | 50                   | -     | ns   |
| External c           | lock                                          |                             |                        |                          |                      |       |      |
| t <sub>CHCX</sub>    | clock HIGH time                               | see Figure 17               | 22                     | $T_{cy(clk)} - t_{CLCX}$ | 22                   | -     | ns   |
| t <sub>CLCX</sub>    | clock LOW time                                | see Figure 17               | 22                     | $T_{cy(clk)} - t_{CHCX}$ | 22                   | -     | ns   |
| t <sub>CLCH</sub>    | clock rise time                               | see Figure 17               | -                      | 5                        | -                    | 5     | ns   |
| t <sub>CHCL</sub>    | clock fall time                               | see Figure 17               | -                      | 5                        | -                    | 5     | ns   |
| Shift regis          | ter (UART mode 0)                             |                             |                        |                          |                      |       |      |
| T <sub>XLXL</sub>    | serial port clock cycle time                  | see Figure 16               | 16T <sub>cy(clk)</sub> | -                        | 888                  | -     | ns   |
| t <sub>QVXH</sub>    | output data setup to clock rising edge time   | see Figure 16               | 13T <sub>cy(clk)</sub> | -                        | 722                  | -     | ns   |
| t <sub>XHQX</sub>    | output data hold after clock rising edge time | see Figure 16               | -                      | $T_{cy(clk)}$ + 20       | -                    | 75    | ns   |
| t <sub>XHDX</sub>    | input data hold after clock rising edge time  | see Figure 16               | -                      | 0                        | -                    | 0     | ns   |
| t <sub>XHDV</sub>    | input data valid to clock rising edge time    | see Figure 16               | 150                    | -                        | 150                  | -     | ns   |
| SPI interfa          | ice                                           |                             |                        |                          |                      |       |      |
| f <sub>SPI</sub>     | SPI operating frequency                       |                             |                        |                          |                      |       |      |
|                      | slave                                         |                             | 0                      | CCLK/6                   | 0                    | 3.0   | MHz  |
|                      | master                                        |                             | -                      | CCLK/4                   | -                    | 4.5   | MHz  |
| T <sub>SPICYC</sub>  | SPI cycle time                                | see Figure 18,              |                        |                          |                      |       |      |
|                      | slave                                         | <u>19, 20, 21</u>           | <sup>6</sup> /CCLK     | -                        | 333                  | -     | ns   |
|                      | master                                        |                             | <sup>4</sup> /CCLK     | -                        | 222                  | -     | ns   |
| t <sub>SPILEAD</sub> | SPI enable lead time                          | see Figure 20,              |                        |                          |                      |       |      |
|                      | slave                                         | <u>21</u>                   | 250                    | -                        | 250                  | -     | ns   |
| t <sub>SPILAG</sub>  | SPI enable lag time                           | see Figure 20,              |                        |                          |                      |       |      |
|                      | slave                                         | 21                          | 250                    | -                        | 250                  | -     | ns   |

8-bit microcontroller with 10-bit ADC

#### Table 12. Dynamic characteristics (18 MHz) ... continued

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

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

| Symbol               | Parameter                            | Conditions                                            | Variat             | ole clock | $f_{osc} = 1$ | 8 MHz | Unit |
|----------------------|--------------------------------------|-------------------------------------------------------|--------------------|-----------|---------------|-------|------|
|                      |                                      |                                                       | Min                | Мах       | Min           | Max   |      |
| t <sub>SPICLKH</sub> | SPICLK HIGH time                     | see Figure 18,                                        |                    |           |               |       |      |
|                      | master                               | <u>19, 20</u> and <u>21</u>                           | <sup>2</sup> /CCLK | -         | 111           | -     | ns   |
|                      | slave                                |                                                       | <sup>3</sup> /CCLK | -         | 167           | -     | ns   |
| t <sub>SPICLKL</sub> | SPICLK LOW time                      | see Figure 18,                                        |                    |           |               |       |      |
|                      | master                               | <u>19, 20</u> and <u>21</u>                           | <sup>2</sup> /CCLK | -         | 111           | -     | ns   |
|                      | slave                                |                                                       | <sup>3</sup> /CCLK | -         | 167           | -     | ns   |
| t <sub>SPIDSU</sub>  | SPI data set-up time                 | see <u>Figure 18,</u><br><u>19, 20</u> and <u>21</u>  | 100                | -         | 100           | -     | ns   |
| t <sub>SPIDH</sub>   | SPI data hold time                   | see <u>Figure 18,</u><br><u>19, 20</u> and <u>21</u>  | 100                | -         | 100           | -     | ns   |
| <sup>t</sup> SPIA    | SPI access time                      | see Figure 20                                         | 0                  | 80        | 0             | 80    | ns   |
|                      | slave                                | and <u>21</u>                                         |                    |           |               |       |      |
| t <sub>SPIDIS</sub>  | SPI disable time                     | see Figure 20                                         | 0                  | 160       | -             | 160   | ns   |
|                      | slave                                | and <u>21</u>                                         |                    |           |               |       |      |
| t <sub>SPIDV</sub>   | SPI enable to output data valid time | see Figure 18,                                        |                    |           |               |       |      |
|                      | slave                                | <u>19, 20</u> and <u>21</u>                           | -                  | 160       | -             | 160   | ns   |
|                      | master                               |                                                       | -                  | 111       | -             | 111   | ns   |
| t <sub>SPIOH</sub>   | SPI output data hold time            | see Figure 18,<br><u>19</u> , <u>20</u> and <u>21</u> | 0                  | -         | 0             | -     | ns   |
| SPIR                 | SPI rise time                        | see Figure 18,                                        |                    |           |               |       |      |
|                      | SPI outputs (SPICLK, MOSI,<br>MISO)  | <u>19, 20</u> and <u>21</u>                           | -                  | 100       | -             | 100   | ns   |
|                      | SPI inputs (SPICLK, MOSI, MISO, SS)  |                                                       | -                  | 2000      | -             | 2000  | ns   |
| SPIF                 | SPI fall time                        | see Figure 18,                                        |                    |           |               |       |      |
|                      | SPI outputs (SPICLK, MOSI,<br>MISO)  | <u>19, 20</u> and <u>21</u>                           | -                  | 100       | -             | 100   | ns   |
|                      | SPI inputs (SPICLK, MOSI, MISO, SS)  |                                                       | -                  | 2000      | -             | 2000  | ns   |

[1] Parameters are valid over operating temperature range unless otherwise specified.

[2] Parts are tested to 2 MHz, but are guaranteed to operate down to 0 Hz.

### **Philips Semiconductors**

## P89LPC9381

#### 8-bit microcontroller with 10-bit ADC





P89LPC9381\_1 Product data sheet

#### **Philips Semiconductors**

### P89LPC9381

8-bit microcontroller with 10-bit ADC

### 13. Package outline



#### Fig 23. Package outline SOT361-1 (TSSOP28)