# 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, 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 8x8b; D/A 2x8b                                                        |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-TSSOP (0.173", 4.40mm Width)                                           |
| Supplier Device Package    | 28-TSSOP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89lpc9331fdh-512 |

Email: info@E-XFL.COM

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

## 2.2 Additional features

- A high performance 80C51 CPU provides instruction cycle times of 111 ns to 222 ns for all instructions except multiply and divide when executing at 18 MHz. This is six times the performance of the standard 80C51 running at the same clock frequency. A lower clock frequency for the same performance results in power savings and reduced EMI.
- Serial flash In-Circuit Programming (ICP) allows simple production coding with commercial EPROM programmers. Flash security bits prevent reading of sensitive application programs.
- Serial flash In-System Programming (ISP) allows coding while the device is mounted in the end application.
- In-Application Programming (IAP) of the flash code memory. This allows changing the code in a running application.
- Watchdog timer with separate on-chip oscillator, nominal 400 kHz, calibrated to ±5 %, requiring no external components. The watchdog prescaler is selectable from eight values.
- High-accuracy internal RC oscillator option, with clock doubler option, allows operation without external oscillator components. The RC oscillator option is selectable and fine tunable.
- Clock switching on the fly among internal RC oscillator, watchdog oscillator, external clock source provides optimal support of minimal power active mode with fast switching to maximum performance.
- Idle and two different power-down reduced power modes. Improved wake-up from Power-down mode (a LOW interrupt input starts execution). Typical power-down current is 1 µA (total power-down with voltage comparators disabled).
- Active-LOW reset. On-chip power-on reset allows operation without external reset components. A software reset function is also available.
- Configurable on-chip oscillator with frequency range options selected by user programmed flash configuration bits. Oscillator options support frequencies from 20 kHz to the maximum operating frequency of 18 MHz.
- Oscillator fail detect. The watchdog timer has a separate fully on-chip oscillator allowing it to perform an oscillator fail detect function.
- Programmable port output configuration options: quasi-bidirectional, open drain, push-pull, input-only.
- High current sourcing/sinking (20 mA) on eight I/O pins (P0.3 to P0.7, P1.4, P1.6, P1.7). All other port pins have high sinking capability (20 mA). A maximum limit is specified for the entire chip.
- Port 'input pattern match' detect. Port 0 may generate an interrupt when the value of the pins match or do not match a programmable pattern.
- Controlled slew rate port outputs to reduce EMI. Outputs have approximately 10 ns minimum ramp times.
- Only power and ground connections are required to operate the P89LPC9331/9341/9351/9361 when internal reset option is selected.
- Four interrupt priority levels.
- Eight keypad interrupt inputs, plus two additional external interrupt inputs.
- Schmitt trigger port inputs.
- Second data pointer.
- Emulation support.

## **NXP Semiconductors**

## P89LPC9331/9341/9351/9361

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



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

| Symbol          | Pin                | Туре | Description                                                                                                                                                                                                                                                                                                                     |
|-----------------|--------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | PLCC28,<br>TSSOP28 |      |                                                                                                                                                                                                                                                                                                                                 |
| P3.1/XTAL1      | 8                  | I/O  | <b>P3.1</b> — Port 3 bit 1.                                                                                                                                                                                                                                                                                                     |
|                 |                    | Ι    | <b>XTAL1</b> — Input to the oscillator circuit and internal clock generator circuits (when selected via the flash configuration). It can be a port pin if internal RC oscillator or watchdog oscillator is used as the CPU clock source, <b>and</b> if XTAL1/XTAL2 are not used to generate the clock for the RTC/system timer. |
| V <sub>SS</sub> | 7                  | I    | Ground: 0 V reference.                                                                                                                                                                                                                                                                                                          |
| V <sub>DD</sub> | 21                 | I    | <b>Power supply:</b> This is the power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                                                                                                |

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

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

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

| Name   | Description                                | SFR    | Bit function | Bit functions and addresses |        |        |        |        |        |        | Reset value |           |
|--------|--------------------------------------------|--------|--------------|-----------------------------|--------|--------|--------|--------|--------|--------|-------------|-----------|
|        |                                            | addr.  | MSB          |                             |        |        |        |        |        | LSB    | Hex         | Binary    |
| SBUF   | Serial Port data<br>buffer register        | 99H    |              |                             |        |        |        |        |        |        | хх          | xxxx xxxx |
|        | Bit a                                      | ddress | 9F           | 9E                          | 9D     | 9C     | 9B     | 9A     | 99     | 98     |             |           |
| SCON*  | Serial port<br>control                     | 98H    | SM0/FE       | SM1                         | SM2    | REN    | TB8    | RB8    | ΤI     | RI     | 00          | 0000 000  |
| SSTAT  | Serial port<br>extended<br>status register | BAH    | DBMOD        | INTLO                       | CIDIS  | DBISEL | FE     | BR     | OE     | STINT  | 00          | 0000 000  |
| SP     | Stack pointer                              | 81H    |              |                             |        |        |        |        |        |        | 07          | 0000 011  |
| SPCTL  | SPI control register                       | E2H    | SSIG         | SPEN                        | DORD   | MSTR   | CPOL   | CPHA   | SPR1   | SPR0   | 04          | 0000 010  |
| SPSTAT | SPI status<br>register                     | E1H    | SPIF         | WCOL                        | -      | -      | -      | -      | -      | -      | 00          | 00xx xxx  |
| SPDAT  | SPI data register                          | E3H    |              |                             |        |        |        |        |        |        | 00          | 0000 000  |
| TAMOD  | Timer 0 and 1 auxiliary mode               | 8FH    | -            | -                           | -      | T1M2   | -      | -      | -      | T0M2   | 00          | xxx0 xxx0 |
|        | Bit a                                      | ddress | 8F           | 8E                          | 8D     | 8C     | 8B     | 8A     | 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          | 000 000   |
| TL0    | Timer 0 low                                | 8AH    |              |                             |        |        |        |        |        |        | 00          | 0000 0000 |
| TL1    | Timer 1 low                                | 8BH    |              |                             |        |        |        |        |        |        | 00          | 0000 000  |
| TMOD   | Timer 0 and 1<br>mode                      | 89H    | T1GATE       | T1C/T                       | T1M1   | T1M0   | TOGATE | T0C/T  | T0M1   | T0M0   | 00          | 0000 000  |
| TRIM   | Internal<br>oscillator trim<br>register    | 96H    | RCCLK        | ENCLK                       | TRIM.5 | TRIM.4 | TRIM.3 | TRIM.2 | TRIM.1 | TRIM.0 | [5][6]      |           |
| WDCON  | Watchdog control register                  | A7H    | PRE2         | PRE1                        | PRE0   | -      | -      | WDRUN  | WDTOF  | WDCLK  | [4][6]      |           |

NXP Semiconductors

8-bit microcontroller with accelerated two-clock 80C51 core P89LPC9331/9341/9351/9361

ights reserved. 18 of 94

## Table 6.Special function registers - P89LPC9351/9361\* indicates SFRs that are bit addressable. P89LPC93

| Name | ame    | Description                     | SFR         | Bit functions and addresses |         |       |        |        |        |        | Reset value |     |          |
|------|--------|---------------------------------|-------------|-----------------------------|---------|-------|--------|--------|--------|--------|-------------|-----|----------|
| 140  |        |                                 | addr.       | MSB                         |         |       |        |        |        |        | LSB         | Hex | Binary   |
|      |        | E                               | Bit address | E7                          | E6      | E5    | E4     | E3     | E2     | E1     | E0          |     |          |
| AC   | CC*    | Accumulator                     | E0H         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |
| AE   | DCON0  | A/D control register 0          | 8EH         | ENBI0                       | ENADCI0 | TMM0  | EDGE0  | ADCI0  | ENADC0 | ADCS01 | ADCS00      | 00  | 000 000  |
| AE   | DCON1  | A/D control register 1          | 97H         | ENBI1                       | ENADCI1 | TMM1  | EDGE1  | ADCI1  | ENADC1 | ADCS11 | ADCS10      | 00  | 000 000  |
| AD   | DINS   | A/D input select                | A3H         | ADI13                       | ADI12   | ADI11 | ADI10  | ADI03  | ADI02  | ADI01  | ADI00       | 00  | 0000 000 |
| AE   | OMODA  | A/D mode<br>register A          | C0H         | BNDI1                       | BURST1  | SCC1  | SCAN1  | BNDI0  | BURST0 | SCC0   | SCAN0       | 00  | 000 000  |
| AE   | DMODB  | A/D mode<br>register B          | A1H         | CLK2                        | CLK1    | CLK0  | INBND0 | ENDAC1 | ENDAC0 | BSA1   | BSA0        | 00  | 000x 000 |
| AE   | D0BH   | A/D_0 boundary<br>high register | BBH         |                             |         |       |        |        |        |        |             | FF  | 1111 111 |
| AE   | D0BL   | A/D_0 boundary<br>low register  | A6H         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |
| AE   | D0DAT0 | A/D_0 data<br>register 0        | C5H         |                             |         |       |        |        |        |        |             | 00  | 000 000  |
| AE   | D0DAT1 | A/D_0 data<br>register 1        | C6H         |                             |         |       |        |        |        |        |             | 00  | 000 000  |
| AE   | D0DAT2 | A/D_0 data<br>register 2        | C7H         |                             |         |       |        |        |        |        |             | 00  | 000 000  |
| AE   | D0DAT3 | A/D_0 data<br>register 3        | F4H         |                             |         |       |        |        |        |        |             | 00  | 000 000  |
| AE   | D1BH   | A/D_1 boundary<br>high register | C4H         |                             |         |       |        |        |        |        |             | FF  | 1111 111 |
| AD   | D1BL   | A/D_1 boundary low register     | BCH         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |
| AD   | D1DAT0 | A/D_1 data register 0           | D5H         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |
| AE   | D1DAT1 | A/D_1 data<br>register 1        | D6H         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |
| A    | D1DAT2 | A/D_1 data<br>register 2        | D7H         |                             |         |       |        |        |        |        |             | 00  | 0000 000 |

**NXP Semiconductors** 

## 7.2 Enhanced CPU

The P89LPC9331/9341/9351/9361 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 P89LPC9331/9341/9351/9361 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 <u>Figure 7</u>) and can also be optionally divided to a slower frequency (see <u>Section 7.11 "CCLK modification: DIVM register"</u>).

Remark: fosc is defined as the OSCCLK frequency.

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

**RCCLK** — The internal 7.373 MHz RC oscillator output. The clock doubler option, when enabled, provides an output frequency of 14.746 MHz.

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

## 7.3.2 CPU clock (OSCCLK)

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

## 7.4 Crystal oscillator option

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

## 7.4.1 Low speed oscillator option

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

## 7.4.2 Medium speed oscillator option

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

## 7.4.3 High speed oscillator option

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

Some chip functions continue to operate and draw power during Power-down mode, increasing the total power used during power-down. These include: Brownout detect, watchdog timer, comparators (note that comparators can be powered down separately), and RTC/system timer. The internal RC oscillator is disabled unless both the RC oscillator has been selected as the system clock and the RTC is enabled.

## 7.18.3 Total Power-down mode

This is the same as Power-down mode except that the brownout detection circuitry and the voltage comparators are also disabled to conserve additional power. The internal RC oscillator is disabled unless both the RC oscillator has been selected as the system clock **and** the RTC is enabled. If the internal RC oscillator is used to clock the RTC during power-down, there will be high power consumption. Please use an external low frequency clock to achieve low power with the RTC running during power-down.

## 7.19 Reset

The P1.5/RST pin can function as either a LOW-active reset input or as a digital input, P1.5. The Reset Pin Enable (RPE) bit in UCFG1, when set to logic 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 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 pin will function 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. When this pin functions as a reset input, an internal pull-up resistance is connected (see <u>Table 12 "Static characteristics"</u>).

**Note:** During a power cycle,  $V_{DD}$  must fall below  $V_{POR}$  before power is reapplied, in order to ensure a power-on reset (see <u>Table 12</u> "Static characteristics").

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 logic 0 to the corresponding bit. More than one flag bit may be set:

- During a power-on reset, both POF and BOF are set but the other flag bits are cleared.
- A Watchdog reset is similar to 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.19.1 Reset vector

Following reset, the P89LPC9331/9341/9351/9361 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 *P89LPC9331/9341/9351/9361 User manual*). Otherwise, instructions will be fetched from address 0000H.

## 7.20 Timers/counters 0 and 1

The P89LPC9331/9341/9351/9361 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 counters. 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.

Timer 0 and Timer 1 have five operating modes (Modes 0, 1, 2, 3 and 6). Modes 0, 1, 2 and 6 are the same for both Timers/Counters. Mode 3 is different.

### 7.20.1 Mode 0

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

### 7.20.2 Mode 1

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

### 7.20.3 Mode 2

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

## 7.20.4 Mode 3

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

### 7.20.5 Mode 6

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

## 7.20.6 Timer overflow toggle output

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

## 7.21 RTC/system timer

The P89LPC9331/9341/9351/9361 has a simple RTC that allows a user to continue running an accurate timer while the rest of the device is powered down. The RTC can be a wake-up or an interrupt source. The RTC is a 23-bit down counter comprised of a 7-bit prescaler and a 16-bit loadable down counter. When it reaches all logic 0s, the counter will be reloaded again and the RTCF flag will be set. The clock source for this counter can be either the CPU clock (CCLK) or the XTAL oscillator. Only power-on reset and watchdog reset will reset the RTC and its associated SFRs to the default state.

The 16-bit loadable counter portion of the RTC is readable by reading the RTCDATL and RTCDATH registers.

## 7.22 CCU (P89LPC9351/9361)

This unit features:

- A 16-bit timer with 16-bit reload on overflow.
- Selectable clock, with prescaler to divide clock source by any integral number between 1 and 1024.
- · Four compare/PWM outputs with selectable polarity
- Symmetrical/asymmetrical PWM selection
- Two capture inputs with event counter and digital noise rejection filter
- Seven interrupts with common interrupt vector (one overflow, two capture, four compare)
- Safe 16-bit read/write via shadow registers.

## 7.22.1 CCU clock

The CCU runs on the CCUCLK, which is either PCLK in basic timer mode, or the output of a PLL. The PLL is designed to use a clock source between 0.5 MHz to 1 MHz that is multiplied by 32 to produce a CCUCLK between 16 MHz and 32 MHz in PWM mode (asymmetrical or symmetrical). The PLL contains a 4-bit divider to help divide PCLK into a frequency between 0.5 MHz and 1 MHz.

### 7.22.2 CCUCLK prescaling

This CCUCLK can further be divided down by a prescaler. The prescaler is implemented as a 10-bit free-running counter with programmable reload at overflow.

### 7.22.3 Basic timer operation

The timer is a free-running up/down counter with a direction control bit. If the timer counting direction is changed while the counter is running, the count sequence will be reversed. The timer can be written or read at any time.

When a reload occurs, the CCU Timer Overflow Interrupt Flag will be set, and an interrupt generated if enabled. The 16-bit CCU timer may also be used as an 8-bit up/down timer.

## 7.22.4 Output compare

There are four output compare channels: A, B, C and D. Each output compare channel needs to be enabled in order to operate and the user will have to set the associated I/O pin to the desired output mode to connect the pin. When the contents of the timer matches that of a capture compare control register, the Timer Output Compare Interrupt Flag (TOCFx) becomes set. An interrupt will occur if enabled.

## 7.22.5 Input capture

Input capture is always enabled. Each time a capture event occurs on one of the two input capture pins, the contents of the timer is transferred to the corresponding 16-bit input capture register. The capture event can be programmed to be either rising or falling edge triggered. A simple noise filter can be enabled on the input capture by enabling the Input Capture Noise Filter bit. If set, the capture logic needs to see four consecutive samples of the same value in order to recognize an edge as a capture event. An event counter can be set to delay a capture by a number of capture events.

## 7.22.6 PWM operation

PWM operation has two main modes, symmetrical and asymmetrical.

In asymmetrical PWM operation the CCU timer operates in down-counting mode regardless of the direction control bit.

In symmetrical mode, the timer counts up/down alternately. The main difference from basic timer operation is the operation of the compare module, which in PWM mode is used for PWM waveform generation.

As with basic timer operation, when the PWM (compare) pins are connected to the compare logic, their logic state remains unchanged. However, since bit FCO is used to hold the halt value, only a compare event can change the state of the pin.



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



## 7.22.7 Alternating output mode

In asymmetrical mode, the user can set up PWM channels A/B and C/D as alternating pairs for bridge drive control. In this mode the output of these PWM channels are alternately gated on every counter cycle.



## 7.22.8 PLL operation

The PWM module features a Phase Locked Loop that can be used to generate a CCUCLK frequency between 16 MHz and 32 MHz. At this frequency the PWM module provides ultrasonic PWM frequency with 10-bit resolution provided that the crystal frequency is 1 MHz or higher. The PLL is fed an input signal from 0.5 MHz to 1 MHz and generates an output signal of 32 times the input frequency. This signal is used to clock the timer. The user will have to set a divider that scales PCLK by a factor from 1 to 16. This divider is found in the SFR register TCR21. The PLL frequency can be expressed as shown in Equation 1:

PLL frequency = 
$$\frac{\text{PCLK}}{(N+1)}$$

Where: N is the value of PLLDV3:0.

(1)

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



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



8.3 Block diagram

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

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

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

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

| anno                    |                                           |                                                |                 |                |      |            |
|-------------------------|-------------------------------------------|------------------------------------------------|-----------------|----------------|------|------------|
| Symbol                  | Parameter                                 | Conditions                                     | Min             | Typ <u>[1]</u> | Max  | Unit       |
| I <sub>IL</sub>         | LOW-level input current                   | $V_1 = 0.4 V$                                  | <u>[9]</u> _    | -              | -80  | μΑ         |
| ILI                     | input leakage current                     | $V_I = V_{IL}, V_{IH}, \text{ or } V_{th(HL)}$ | <u>[10]</u>     | -              | ±1   | μΑ         |
| I <sub>THL</sub>        | HIGH-LOW transition<br>current            | all ports; $V_I = 1.5 V$ at $V_{DD} = 3.6 V$   | <u>[11]</u> –30 | -              | -450 | μΑ         |
| R <sub>RST_N(int)</sub> | internal pull-up resistance<br>on pin RST | pin RST                                        | 10              | -              | 30   | kΩ         |
| V <sub>ref(bg)</sub>    | band gap reference voltage                |                                                | 1.19            | 1.23           | 1.27 | V          |
| TC <sub>bg</sub>        | band gap temperature coefficient          |                                                | -               | 10             | 20   | ppm/<br>°C |

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

[2] The I<sub>DD(oper)</sub> specification is measured using an external clock with code while(1) {} executed from on-chip flash.

[3] The I<sub>DD(idle)</sub> specification is measured using an external clock with no active peripherals, with the following functions disabled: real-time clock and watchdog timer.

[4] The I<sub>DD(pd)</sub> specification is measured using internal RC oscillator with the following functions disabled: comparators, real-time clock, and watchdog timer.

[5] 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.

[6] See Section 9 "Limiting values" for steady state (non-transient) limits on I<sub>OL</sub> or I<sub>OH</sub>. If I<sub>OL</sub>/I<sub>OH</sub> exceeds the test condition, V<sub>OL</sub>/V<sub>OH</sub> may exceed the related specification.

[7] This specification can be applied to pins which have A/D input or analog comparator input functions when the pin is not being used for those analog functions. When the pin is being used as an analog input pin, the maximum voltage on the pin must be limited to 4.0 V with respect to V<sub>SS</sub>.

[8] Pin capacitance is characterized but not tested.

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

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

[11] 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 accelerated two-clock 80C51 core





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

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

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

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

| Symbol             | Parameter                              | Conditions                                               | Variab                         | ole clock | f <sub>osc</sub> = 1 | Unit |    |
|--------------------|----------------------------------------|----------------------------------------------------------|--------------------------------|-----------|----------------------|------|----|
|                    |                                        |                                                          | Min                            | Max       | Min                  | Max  |    |
| SPILEAD            | SPI enable lead time                   | see <u>Figure 45, 46</u>                                 |                                |           | ·                    |      |    |
|                    | slave                                  |                                                          | 250                            | -         | 250                  | -    | ns |
| SPILAG             | SPI enable lag time                    | see <u>Figure 45, 46</u>                                 |                                |           |                      |      |    |
|                    | slave                                  |                                                          | 250                            | -         | 250                  | -    | ns |
| SPICLKH            | SPICLK HIGH time                       | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | slave                                  |                                                          | <sup>3</sup> /CCLK             | -         | 167                  | -    | ns |
|                    | master                                 |                                                          | <sup>2</sup> /CCLK             | -         | 111                  | -    | ns |
| SPICLKL            | SPICLK LOW time                        | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | slave                                  |                                                          | <sup>3</sup> /CCLK             | -         | 167                  | -    | ns |
|                    | master                                 |                                                          | <sup>2</sup> / <sub>CCLK</sub> | -         | 111                  | -    | ns |
| SPIDSU             | SPI data set-up time                   | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | master or slave                        |                                                          | 100                            | -         | 100                  | -    | ns |
| SPIDH              | SPI data hold time                     | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | master or slave                        |                                                          | 100                            | -         | 100                  | -    | ns |
| SPIA               | SPI access time                        | see <u>Figure 45</u> , <u>46</u>                         |                                |           |                      |      |    |
|                    | slave                                  |                                                          | 0                              | 80        | 0                    | 80   | ns |
| SPIDIS             | SPI disable time                       | see <u>Figure 45</u> , <u>46</u>                         |                                |           |                      |      |    |
|                    | slave                                  |                                                          | 0                              | 160       | -                    | 160  | ns |
| SPIDV              | SPI enable to output data valid time   | see <u>Figure 43</u> , <u>44</u> , <u>45</u> , <u>46</u> |                                |           |                      |      |    |
|                    | slave                                  |                                                          | -                              | 160       | -                    | 160  | ns |
|                    | master                                 |                                                          | -                              | 111       | -                    | 111  | ns |
| t <sub>SPIOH</sub> | SPI output data hold time              | see <u>Figure 43</u> , <u>44</u> , <u>45</u> , <u>46</u> | 0                              | -         | 0                    | -    | ns |
| SPIR               | SPI rise time                          | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | SPI outputs (SPICLK, MOSI, MISO)       |                                                          | -                              | 100       | -                    | 100  | ns |
|                    | SPI inputs (SPICLK, MOSI, MISO, SS)    |                                                          | -                              | 2000      | -                    | 2000 | ns |
| SPIF               | SPI fall time                          | see <u>Figure 43, 44, 45, 46</u>                         |                                |           |                      |      |    |
|                    | SPI outputs (SPICLK, MOSI, MISO)       |                                                          | -                              | 100       | -                    | 100  | ns |
|                    | SPI inputs (SPICLK,<br>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 accelerated two-clock 80C51 core



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

## 13. Package outline



### Fig 50. PLCC28 package outline (SOT261-2)

All information provided in this document is subject to legal disclaimers.

## 16. Legal information

## 16.1 Data sheet status

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

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

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

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

## 16.2 Definitions

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

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

**Product specification** — The information and data provided in a Product data sheet shall define the specification of the product as agreed between NXP Semiconductors and its customer, unless NXP Semiconductors and customer have explicitly agreed otherwise in writing. In no event however, shall an agreement be valid in which the NXP Semiconductors product is deemed to offer functions and qualities beyond those described in the Product data sheet.

## 16.3 Disclaimers

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the *Terms and conditions of commercial sale* of NXP Semiconductors.

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

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

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

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) will cause permanent damage to the device. Limiting values are stress ratings only and (proper) operation of the device at these or any other conditions above those given in the Recommended operating conditions section (if present) or the Characteristics sections of this document is not warranted. Constant or repeated exposure to limiting values will permanently and irreversibly affect the quality and reliability of the device.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at <a href="http://www.nxp.com/profile/terms">http://www.nxp.com/profile/terms</a>, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

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

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

## 18. Contents

| 1        | General description               | 1  | 7 |
|----------|-----------------------------------|----|---|
| 2        | Features and benefits             | 1  | 7 |
| 2.1      | Principal features                | 1  | 7 |
| 2.2      | Additional features               | 2  | 7 |
| 3        | Ordering information              |    | - |
| 3.1      | Ordering options                  |    | 7 |
| 4        | Block diagram                     |    | 7 |
| 5        | Functional diagram                | 5  | 7 |
| 6        | Pinning information               | 6  | 7 |
| 6.1      | Pinning                           | 6  | 7 |
| 6.2      | Pin description                   | 8  | 7 |
| 7        | Functional description            | 12 | 7 |
| 7.1      | Special function registers        | 12 |   |
| 7.2      | Enhanced CPU                      | 30 | - |
| 7.3      | Clocks                            | 30 | _ |
| 7.3.1    | Clock definitions                 | 30 |   |
| 7.3.2    | CPU clock (OSCCLK)                | 30 | - |
| 7.4      | Crystal oscillator option         |    | - |
| 7.4.1    | Low speed oscillator option       | 30 | - |
| 7.4.2    | Medium speed oscillator option    | 30 | 7 |
| 7.4.3    | High speed oscillator option      | 30 | _ |
| 7.5      | Clock output                      | 31 | - |
| 7.6      | On-chip RC oscillator option      |    | - |
| 7.7      | Watchdog oscillator option        |    | 7 |
| 7.8      | External clock input option       | 31 | 7 |
| 7.9      | Clock source switching on the fly | 31 | 7 |
| 7.10     | CCLK wake-up delay                | 32 | 7 |
| 7.11     | CCLK modification: DIVM register  | 32 | - |
| 7.12     | Low power select                  | 32 | - |
| 7.13     | Memory organization               | 33 |   |
| 7.14     | Data RAM arrangement              | 33 | 7 |
| 7.15     | Interrupts                        | 33 |   |
| 7.15.1   | External interrupt inputs         | 34 | 7 |
| 7.16     | I/O ports                         | 36 | 4 |
| 7.16.1   | Port configurations               | 36 | - |
| 7.16.1.1 |                                   |    | 7 |
| 7.16.1.2 | 2 Open-drain output configuration | 36 | 7 |
| 7.16.1.3 | Input-only configuration          | 37 | 7 |
| 7.16.1.4 | Push-pull output configuration    | 37 | - |
| 7.16.2   | Port 0 analog functions           | 37 | - |
| 7.16.3   | Additional port features          |    | - |
| 7.17     | Power monitoring functions        |    | 7 |
| 7.17.1   | Brownout detection                |    | 7 |
| 7.17.2   | Power-on detection                |    | 7 |
| 7.18     | Power reduction modes             | 38 | 7 |
| 7.18.1   | Idle mode                         | 38 | _ |
| 7.18.2   | Power-down mode                   | 38 |   |

| 7.18.3  | Total Power-down mode                               |      |
|---------|-----------------------------------------------------|------|
| 7.19    | Reset                                               |      |
| 7.19.1  | Reset vector.                                       | -    |
| 7.20    | Timers/counters 0 and 1                             |      |
| 7.20.1  | Mode 0                                              |      |
| 7.20.2  | Mode 1                                              |      |
| 7.20.3  | Mode 2                                              |      |
| 7.20.4  | Mode 3                                              |      |
| 7.20.5  | Mode 6                                              |      |
| 7.20.6  | Timer overflow toggle output                        |      |
| 7.21    | RTC/system timer                                    |      |
| 7.22    | CCU (P89LPC9351/9361)                               |      |
| 7.22.1  | CCU clock                                           |      |
| 7.22.2  | CCUCLK prescaling                                   |      |
| 7.22.3  | Basic timer operation                               |      |
| 7.22.4  | Output compare                                      |      |
| 7.22.5  | Input capture                                       |      |
| 7.22.6  | PWM operation                                       |      |
| 7.22.7  | Alternating output mode                             |      |
| 7.22.8  | PLL operation                                       |      |
| 7.22.9  | CCU interrupts                                      |      |
| 7.23    | UART                                                |      |
| 7.23.1  | Mode 0                                              |      |
| 7.23.2  | Mode 1                                              |      |
| 7.23.3  | Mode 2                                              |      |
| 7.23.4  | Mode 3                                              |      |
| 7.23.5  | Baud rate generator and selection                   |      |
| 7.23.6  | Framing error                                       | . 45 |
| 7.23.7  | Break detect                                        |      |
| 7.23.8  | Double buffering                                    | . 46 |
| 7.23.9  | Transmit interrupts with double buffering           |      |
|         | enabled (modes 1, 2 and 3)                          | . 46 |
| 7.23.10 | The 9 <sup>th</sup> bit (bit 8) in double buffering |      |
|         | (modes 1, 2 and 3)                                  |      |
| 7.24    | I <sup>2</sup> C-bus serial interface               |      |
| 7.25    | SPI                                                 |      |
| 7.25.1  | Typical SPI configurations                          |      |
| 7.26    | Analog comparators                                  | . 51 |
| 7.26.1  | Internal reference voltage                          | . 52 |
| 7.26.2  | Comparator interrupt                                |      |
| 7.26.3  | Comparators and power reduction modes               |      |
| 7.27    | KBI                                                 | . 53 |
| 7.28    | Watchdog timer                                      | . 54 |
| 7.29    | Additional features                                 |      |
| 7.29.1  | Software reset                                      | . 54 |
| 7.29.2  | Dual data pointers                                  |      |
| 7.29.3  | Data EEPROM (P89LPC9351/9361)                       |      |
| 7.30    | Flash program memory                                | . 55 |
|         |                                                     |      |

continued >>