

32-bit ARM Cortex-M0 microcontroller; up to 128 kB flash and 8 kB SRAM

Rev. 1.1 — 21 February 2011

**Objective data sheet** 

## 1. General description

The LPC122x extend NXP's 32-bit ARM microcontroller continuum and target a wide range of industrial applications in the areas of factory and home automation. Benefitting from the ARM Cortex-M0 Thumb instruction set, the LPC122x have up to 50 % higher code density compared to common 8/16-bit microcontroller performing typical tasks. The LPC122x also feature an optimized ROM-based divide library for Cortex-M0, which offers several times the arithmetic performance of software-based libraries, as well as highly deterministic cycle time combined with reduced flash code size. The ARM Cortex-M0 efficiency also helps the LPC122x achieve lower average power for similar applications.

The LPC122x operate at CPU frequencies of up to 45 MHz.They offer a wide range of flash memory options, from 32 kB to 128 kB. The small 512-byte page erase of the flash memory brings multiple design benefits, such as finer EEPROM emulation, boot-load support from any serial interface and ease of in-field programming with reduced on-chip RAM buffer requirements.

The peripheral complement of the LPC122x includes a 10-bit ADC, two comparators with output feedback loop, two UARTs, one SSP/SPI interface, one I<sup>2</sup>C-bus interface with Fast-mode Plus features, a Windowed Watchdog Timer, a DMA controller, a CRC engine, four general purpose timers, a 32-bit RTC, a 1 % internal oscillator for baud rate generation, and up to 55 General Purpose I/O (GPIO) pins.

## 2. Features and benefits

- Processor core
  - ARM Cortex-M0 processor, running at frequencies of up to 45 MHz (one wait state from flash) or 30 MHz (zero wait states from flash). The LPC122x have a high score of over 45 in CoreMark CPU performance benchmark testing, equivalent to 1.51/MHz.
  - ◆ ARM Cortex-M0 built-in Nested Vectored Interrupt Controller (NVIC).
  - Serial Wire Debug (SWD).
  - System tick timer.
- Memory
  - Up to 8 kB SRAM.
  - Up to 128 kB on-chip flash programming memory.
  - In-System Programming (ISP) and In-Application Programming (IAP) via on-chip bootloader software.
  - Includes ROM-based 32-bit integer division routines.
- Clock generation unit



- Crystal oscillator with an operating range of 1 MHz to 25 MHz.
- 12 MHz Internal RC (IRC) oscillator trimmed to 1 % accuracy that can optionally be used as a system clock.
- PLL allows CPU operation up to the maximum CPU rate without the need for a high-frequency crystal. May be run from the system oscillator or the internal RC oscillator.
- Clock output function with divider that can reflect the system oscillator clock, IRC clock, main clock, and Watchdog clock.
- Real-Time Clock (RTC).

- Digital peripherals
  - Micro DMA controller with 21 channels.
  - CRC engine.
  - Two UARTs with fractional baud rate generation and internal FIFO. One UART with RS-485 and modem support and one standard UART with IrDA.
  - SSP/SPI controller with FIFO and multi-protocol capabilities.
  - I<sup>2</sup>C-bus interface supporting full I<sup>2</sup>C-bus specification and Fast-mode Plus with a data rate of 1 Mbit/s with multiple address recognition and monitor mode. I<sup>2</sup>C-bus pins have programmable glitch filter.
  - Up to 55 General Purpose I/O (GPIO) pins with programmable pull-up resistor, open-drain mode, programmable digital input glitch filter, and programmable input inverter.
  - Programmable output drive on all GPIO pins. Four pins support high-current output drivers.
  - All GPIO pins can be used as edge and level sensitive interrupt sources.
  - Four general purpose counter/timers with four capture inputs and four match outputs (32-bit timers) or two capture inputs and two match outputs (16-bit timers).
  - Windowed WatchDog Timer (WWDT).
- Analog peripherals
  - One 8-channel, 10-bit ADC.
  - Two highly flexible analog comparators. Comparator outputs can be programmed to trigger a timer match signal or can be used to emulate 555 timer behavior.
- Power
  - Three reduced power modes: Sleep, Deep-sleep, and Deep power-down.
  - Processor wake-up from Deep-sleep mode via start logic using 12 port pins.
  - Processor wake-up from Deep-power down and Deep-sleep modes via the RTC.
  - Brownout detect with three separate thresholds each for interrupt and forced reset.
  - Power-On Reset (POR).
  - Integrated PMU (Power Management Unit).
- Unique device serial number for identification.
- 3.3 V power supply.
- Available as 64-pin and 48-pin LQFP package.

## 3. Applications

- eMetering
- Lighting
- Industrial networking
- Alarm systems
- White goods

## 4. Ordering information

#### Table 1.Ordering information

| Type number      | Package |                                                                                              |          |  |  |  |  |  |  |  |  |  |
|------------------|---------|----------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|--|--|--|
|                  | Name    | Description                                                                                  | Version  |  |  |  |  |  |  |  |  |  |
| LPC1227FBD64/301 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1226FBD64/301 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1225FBD64/321 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1225FBD64/301 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1224FBD64/121 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1224FBD64/101 | LQFP64  | LQFP64: plastic low profile quad flat package; 64 leads; body 10 $\times$ 10 $\times$ 1.4 mm | SOT314-2 |  |  |  |  |  |  |  |  |  |
| LPC1227FBD48/301 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body 7 $\times$ 7 $\times$ 1.4 mm   | SOT313-2 |  |  |  |  |  |  |  |  |  |
| LPC1226FBD48/301 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body 7 $\times$ 7 $\times$ 1.4 mm   | SOT313-2 |  |  |  |  |  |  |  |  |  |
| LPC1225FBD48/321 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body 7 $\times$ 7 $\times$ 1.4 mm   | SOT313-2 |  |  |  |  |  |  |  |  |  |
| LPC1225FBD48/301 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body 7 $\times$ 7 $\times$ 1.4 mm   | SOT313-2 |  |  |  |  |  |  |  |  |  |
| LPC1224FBD48/121 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body $7 \times 7 \times 1.4$ mm     | SOT313-2 |  |  |  |  |  |  |  |  |  |
| LPC1224FBD48/101 | LQFP48  | LQFP48: plastic low profile quad flat package; 48 leads; body 7 $\times$ 7 $\times$ 1.4 mm   | SOT313-2 |  |  |  |  |  |  |  |  |  |

## 4.1 Ordering options

#### Table 2.Ordering options for LPC122x

| Table 2. Ordering | options |               |      |                          |             |                 |      |         |
|-------------------|---------|---------------|------|--------------------------|-------------|-----------------|------|---------|
| Type number       | Flash   | Total<br>SRAM | UART | I <sup>2</sup> C/<br>FM+ | SSP/<br>SPI | ADC<br>channels | GPIO | Package |
| LPC1227           |         |               |      |                          |             |                 |      |         |
| LPC1227FBD64/301  | 128 kB  | 8 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1227FBD48/301  | 128 kB  | 8 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
| LPC1226           |         |               |      |                          |             |                 |      |         |
| LPC1226FBD64/301  | 96 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1226FBD48/301  | 96 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
| LPC1225           |         |               |      |                          |             |                 |      |         |
| LPC1225FBD64/321  | 80 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1225FBD64/301  | 64 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1225FBD48/321  | 80 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
| LPC1225FBD48/301  | 64 kB   | 8 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
| LPC1224           |         |               |      |                          |             |                 |      |         |
| LPC1224FBD64/121  | 48 kB   | 4 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1224FBD64/101  | 32 kB   | 4 kB          | 2    | 1                        | 1           | 8               | 55   | LQFP64  |
| LPC1224FBD48/121  | 48 kB   | 4 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
| LPC1224FBD48/101  | 32 kB   | 4 kB          | 2    | 1                        | 1           | 8               | 39   | LQFP48  |
|                   |         |               |      |                          |             |                 |      |         |

#### 32-bit ARM Cortex-M0 microcontroller

## 5. Block diagram



## 6. Pinning information

## 6.1 Pinning



#### 32-bit ARM Cortex-M0 microcontroller



Table 3.

#### 32-bit ARM Cortex-M0 microcontroller

### 6.2 Pin description

All pins except the supply pins can have more than one function as shown in Table 3. The pin function is selected through the pin's IOCON register in the IOCONFIG block. The multiplexed functions (see Table 4) include the counter/timer inputs and outputs, the UART receive, transmit, and control functions, and the serial wire debug functions.

For each pin, the default function is listed first together with the pin's reset state.

|  | Symbol | in LQFP48 | in LQFP64 | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] |  |
|--|--------|-----------|-----------|-------------------------|------|-----------------------|--|
|--|--------|-----------|-----------|-------------------------|------|-----------------------|--|

LPC122x pin description

| Symbol                      | Pin LQFP48 | Pin LQFP64 |            | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                                                                                                                                                                  |
|-----------------------------|------------|------------|------------|-------------------------|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIO0_0 to PIO0_31           |            |            |            |                         | I/O  |                       | <b>Port 0</b> — Port 0 is a 32-bit I/O port with individual direction and function controls for each bit. The operation of port 0 pins depends on the function selected through the IOCONFIG register block. |
| PIO0_0/RTS0                 | 15         | 19         | [2]        | yes                     | I/O  | I; PU                 | PIO0_0 — General purpose digital input/output pin.                                                                                                                                                           |
|                             |            |            |            |                         | 0    | -                     | <b>RTS0</b> — Request To Send output for UART0.                                                                                                                                                              |
| PIO0_1/RXD0/                | 16         | 20         | [2]        | yes                     | I/O  | I; PU                 | PIO0_1 — General purpose digital input/output pin.                                                                                                                                                           |
| CT32B0_CAP0/<br>CT32B0_MAT0 |            |            |            |                         | I    | -                     | <b>RXD0</b> — Receiver input for UART0.                                                                                                                                                                      |
| 010200_0010                 |            |            |            |                         | I    | -                     | <b>CT32B0_CAP0</b> — Capture input, channel 0 for 32-bit timer 0.                                                                                                                                            |
|                             |            |            |            |                         | 0    | -                     | CT32B0_MAT0 — Match output, channel 0 for 32-bit timer 0.                                                                                                                                                    |
| PIO0_2/TXD0/                | 17         | 21         | <u>[2]</u> | yes                     | I/O  | I; PU                 | PIO0_2 — General purpose digital input/output pin.                                                                                                                                                           |
| CT32B0_CAP1/<br>CT32B0_MAT1 |            |            |            |                         | 0    | -                     | <b>TXD0</b> — Transmitter output for UART0.                                                                                                                                                                  |
|                             |            |            |            |                         | I    | -                     | <b>CT32B0_CAP1</b> — Capture input, channel 1 for 32-bit timer 0.                                                                                                                                            |
|                             |            |            |            |                         | 0    | -                     | CT32B0_MAT1 — Match output, channel 1 for 32-bit timer 0.                                                                                                                                                    |
| PIO0_3/DTR0/                | 18         | 22         | [2]        | yes                     | I/O  | I; PU                 | PIO0_3 — General purpose digital input/output pin.                                                                                                                                                           |
| CT32B0_CAP2/<br>CT32B0_MAT2 |            |            |            |                         | 0    | -                     | <b>DTR0</b> — Data Terminal Ready output for UART0.                                                                                                                                                          |
| 010200_111/112              |            |            |            |                         | I    | -                     | <b>CT32B0_CAP2</b> — Capture input, channel 2 for 32-bit timer 0.                                                                                                                                            |
|                             |            |            |            |                         | 0    | -                     | CT32B0_MAT2 — Match output, channel 2 for 32-bit timer 0.                                                                                                                                                    |
| PIO0_4/DSR0/                | 19         | 23         | [2]        | yes                     | I/O  | I; PU                 | PIO0_4 — General purpose digital input/output pin.                                                                                                                                                           |
| CT32B0_CAP3/<br>CT32B0_MAT3 |            |            |            |                         | I    | -                     | <b>DSR0</b> — Data Set Ready input for UART0.                                                                                                                                                                |
| 010200_111/10               |            |            |            |                         | I    | -                     | <b>CT32B0_CAP3</b> — Capture input, channel 3 for 32-bit timer 0.                                                                                                                                            |
|                             |            |            |            |                         | 0    | -                     | CT32B0_MAT3 — Match output, channel 3 for 32-bit timer 0.                                                                                                                                                    |
| PIO0_5/DCD0                 | 20         | 24         | [2]        | yes                     | I/O  | I; PU                 | <b>PIO0_5</b> — General purpose digital input/output pin.                                                                                                                                                    |
|                             |            |            |            |                         | I    | -                     | <b>DCD0</b> — Data Carrier Detect input for UART0.                                                                                                                                                           |
| PIO0_6/RI0/                 | 21         | 25         | [2]        | yes                     | I/O  | I; PU                 | PIO0_6 — General purpose digital input/output pin.                                                                                                                                                           |
| CT32B1_CAP0/<br>CT32B1_MAT0 |            |            |            |                         | I    | -                     | <b>RI0</b> — Ring Indicator input for UART0.                                                                                                                                                                 |
|                             |            |            |            |                         | I    | -                     | <b>CT32B1_CAP0</b> — Capture input, channel 0 for 32-bit timer 1.                                                                                                                                            |
|                             |            |            |            |                         | 0    | -                     | CT32B1 MAT0 — Match output, channel 0 for 32-bit timer 1.                                                                                                                                                    |

## 32-bit ARM Cortex-M0 microcontroller

| Table 3.         LPC122x pin descriptioncontinued |            |            |            |                         |      |                       |                                                                                                                                                                                             |  |  |  |
|---------------------------------------------------|------------|------------|------------|-------------------------|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Symbol                                            | Pin LQFP48 | Pin LQFP64 |            | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                                                                                                                                                 |  |  |  |
| PIO0_7/CTS0/                                      | 22         | 26         | [2]        | yes                     | I/O  | I; PU                 | PIO0_7 — General purpose digital input/output pin.                                                                                                                                          |  |  |  |
| CT32B1_CAP1/                                      |            |            |            |                         | I    | -                     | CTS0 — Clear To Send input for UART0.                                                                                                                                                       |  |  |  |
| CT32B1_MAT1                                       |            |            |            |                         | I    | -                     | CT32B1_CAP1 — Capture input, channel 1 for 32-bit timer 1.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT32B1_MAT1 — Match output, channel 1 for 32-bit timer 1.                                                                                                                                   |  |  |  |
| PIO0_8/RXD1/                                      | 23         | 27         | [2]        | yes                     | I/O  | I; PU                 | PIO0_8 — General purpose digital input/output pin.                                                                                                                                          |  |  |  |
| CT32B1_CAP2/                                      |            |            |            |                         | I    | -                     | <b>RXD1</b> — Receiver input for UART1.                                                                                                                                                     |  |  |  |
| CT32B1_MAT2                                       |            |            |            |                         | I    | -                     | CT32B1_CAP2 — Capture input, channel 2 for 32-bit timer 1.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT32B1_MAT2 — Match output, channel 2 for 32-bit timer 1.                                                                                                                                   |  |  |  |
| PIO0_9/TXD1/                                      | 24         | 28         | [2]        | yes                     | I/O  | I; PU                 | PIO0_9 — General purpose digital input/output pin.                                                                                                                                          |  |  |  |
| CT32B1_CAP3/<br>CT32B1_MAT3                       |            |            |            |                         | 0    | -                     | <b>TXD1</b> — Transmitter output for UART1.                                                                                                                                                 |  |  |  |
| CT32DT_IMAT5                                      |            |            |            |                         | I    | -                     | CT32B1_CAP3 — Capture input, channel 3 for 32-bit timer 1.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT32B1_MAT3 — Match output, channel 3 for 32-bit timer 1.                                                                                                                                   |  |  |  |
| PIO0_10/SCL                                       | 25         | 37         | [3]        | yes                     | I/O  | I; IA                 | PIO0_10 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
|                                                   |            |            |            |                         | I/O  | -                     | SCL — I <sup>2</sup> C-bus clock input/output.                                                                                                                                              |  |  |  |
| PIO0_11/SDA/                                      | 26         | 38         | [3]        | yes                     | I/O  | I; IA                 | PIO0_11 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
| CT16B0_CAP0/<br>CT16B0_MAT0                       |            |            |            |                         | I/O  | -                     | SDA — I <sup>2</sup> C-bus data input/output.                                                                                                                                               |  |  |  |
|                                                   |            |            |            |                         | I    | -                     | CT16B0_CAP0 — Capture input, channel 0 for 16-bit timer 0.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT16B0_MAT0 — Match output, channel 0 for 16-bit timer 0.                                                                                                                                   |  |  |  |
| PIO0_12/CLKOUT/<br>CT16B0_CAP1/<br>CT16B0_MAT1    | 27         | 39         | [7]        | Iℤ no                   | I/O  | I; PU                 | <b>PIO0_12</b> — General purpose digital input/output pin. A LOW level on this pin during reset starts the ISP command handler. High-current output driver.                                 |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CLKOUT — Clock out pin.                                                                                                                                                                     |  |  |  |
|                                                   |            |            |            |                         | I    | -                     | CT16B0_CAP1 — Capture input, channel 1 for 16-bit timer 0.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT16B0_MAT1 — Match output, channel 1 for 16-bit timer 0.                                                                                                                                   |  |  |  |
| RESET/PIO0_13                                     | 28         | 40         | <u>[4]</u> | no                      | I    | I; PU                 | <b>RESET</b> — External reset input: A LOW on this pin resets the device, causing I/O ports and peripherals to take on their default states, and processor execution to begin at address 0. |  |  |  |
|                                                   |            |            |            |                         | I/O  | -                     | PIO0_13 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
| PIO0_14/SCK                                       | 29         | 41         | [2]        | no                      | I/O  | I; PU                 | PIO0_14 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
|                                                   |            |            |            |                         | I/O  | -                     | SCK — Serial clock for SSP/SPI.                                                                                                                                                             |  |  |  |
| PIO0_15/SSEL/                                     | 30         | 42         | [2]        | no                      | I/O  | I; PU                 | PIO0_15 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
| CT16B1_CAP0/<br>CT16B1_MAT0                       |            |            |            |                         | I/O  | -                     | <b>SSEL</b> — Slave select for SSP/SPI.                                                                                                                                                     |  |  |  |
|                                                   |            |            |            |                         | Ι    | -                     | CT16B1_CAP0 — Capture input, channel 0 for 16-bit timer 1.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT16B1_MAT0 — Match output, channel 0 for 16-bit timer 1.                                                                                                                                   |  |  |  |
| PIO0_16/MISO/                                     | 31         | 43         | [2]        | no                      | I/O  | I; PU                 | PIO0_16 — General purpose digital input/output pin.                                                                                                                                         |  |  |  |
| CT16B1_CAP1/<br>CT16B1_MAT1                       |            |            |            |                         | I/O  | -                     | MISO — Master In Slave Out for SSP/SPI.                                                                                                                                                     |  |  |  |
|                                                   |            |            |            |                         | Ι    | -                     | CT16B1_CAP1 — Capture input, channel 1 for 16-bit timer 1.                                                                                                                                  |  |  |  |
|                                                   |            |            |            |                         | 0    | -                     | CT16B1_MAT1 — Match output, channel 1 for 16-bit timer 1.                                                                                                                                   |  |  |  |

#### Table 3. LPC122x pin description ...continued

| LPC122X |  |
|---------|--|
|         |  |

## 32-bit ARM Cortex-M0 microcontroller

| Table 3. LPC122x p           | Table 3.         LPC122x pin descriptioncontinued |            |     |                         |      |                       |                                                                   |  |  |  |
|------------------------------|---------------------------------------------------|------------|-----|-------------------------|------|-----------------------|-------------------------------------------------------------------|--|--|--|
| Symbol                       | Pin LQFP48                                        | Pin LQFP64 |     | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                       |  |  |  |
| PIO0_17/MOSI                 | 32                                                | 44         | [2] | no                      | I/O  | I; PU                 | PIO0_17 — General purpose digital input/output pin.               |  |  |  |
|                              |                                                   |            |     |                         | I/O  | -                     | MOSI — Master Out Slave In for SSP/SPI.                           |  |  |  |
| PIO0_18/SWCLK/               | 33                                                | 45         | [2] | no                      | I/O  | I; PU                 | PIO0_18 — General purpose digital input/output pin.               |  |  |  |
| CT32B0_CAP0/<br>CT32B0_MAT0  |                                                   |            |     |                         | 1    | -                     | <b>SWCLK</b> — Serial wire clock, alternate location.             |  |  |  |
| 010200_111110                |                                                   |            |     |                         | I    | -                     | <b>CT32B0_CAP0</b> — Capture input, channel 0 for 32-bit timer 0. |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B0_MAT0 — Match output, channel 0 for 32-bit timer 0.         |  |  |  |
| PIO0_19/ACMP0_I0/            | 4                                                 | 4          | [5] | no                      | I/O  | I; PU                 | <b>PIO0_19</b> — General purpose digital input/output pin.        |  |  |  |
| CT32B0_CAP1/<br>CT32B0_MAT1  |                                                   |            |     |                         | I    | -                     | ACMP0_I0 — Input 0 for comparator 0.                              |  |  |  |
| 010200_0001                  |                                                   |            |     |                         | 1    | -                     | <b>CT32B0_CAP1</b> — Capture input, channel 1 for 32-bit timer 0. |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B0_MAT1 — Match output, channel 1 for 32-bit timer 0          |  |  |  |
| PIO0_20/ACMP0_I1/            | 5                                                 | 5          | [5] | no                      | I/O  | I; PU                 | PIO0_20 — General purpose digital input/output pin.               |  |  |  |
| CT32B0_CAP2/<br>CT32B0_MAT2  |                                                   |            |     |                         | 1    | -                     | ACMP0_I1 — Input 1 for comparator 0.                              |  |  |  |
| 010200_111112                |                                                   |            |     |                         | 1    | -                     | <b>CT32B0_CAP2</b> — Capture input, channel 2 for 32-bit timer 0. |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B0_MAT2 — Match output, channel 2 for 32-bit timer 0.         |  |  |  |
| PIO0_21/ACMP0_I2/            | 6                                                 | 6          | [5] |                         | I/O  | I; PU                 | PIO0_21 — General purpose digital input/output pin.               |  |  |  |
| CT32B0_CAP3/<br>CT32B0_MAT3  |                                                   |            |     |                         | I    | -                     | ACMP0_I2 — Input 2 for comparator 0.                              |  |  |  |
| 010200_10/010                |                                                   |            |     |                         | I    | -                     | CT32B0_CAP3 — Capture input, channel 3 for 32-bit timer 0.        |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B0_MAT3 — Match output, channel 3 for 32-bit timer 0.         |  |  |  |
| PIO0_22/ACMP0_I3             | 7                                                 | 7          | [5] | no                      | I/O  | I; PU                 | PIO0_22 — General purpose digital input/output pin.               |  |  |  |
|                              |                                                   |            |     |                         | I    | -                     | ACMP0_I3 — Input 3 for comparator 0.                              |  |  |  |
| PIO0_23/                     | 8                                                 | 8          | [5] | no                      | I/O  | I; PU                 | PIO0_23 — General purpose digital input/output pin.               |  |  |  |
| ACMP1_I0/<br>CT32B1_CAP0/    |                                                   |            |     |                         | I    | -                     | ACMP1_I0 — Input 0 for comparator 1.                              |  |  |  |
| CT32B1_MAT0                  |                                                   |            |     |                         | I    | -                     | <b>CT32B1_CAP0</b> — Capture input, channel 0 for 32-bit timer 1. |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B1_MAT0 — Match output, channel 0 for 32-bit timer 1.         |  |  |  |
| PIO0_24/ACMP1_I1/            | 9                                                 | 9          | [5] | no                      | I/O  | I; PU                 | PIO0_24 — General purpose digital input/output pin.               |  |  |  |
| CT32B1_CAP1/<br>CT32B1_MAT1  |                                                   |            |     |                         | I    | -                     | ACMP1_I1 — Input 1 for comparator 1.                              |  |  |  |
|                              |                                                   |            |     |                         | I    | -                     | CT32B1_CAP1 — Capture input, channel 1 for 32-bit timer 1.        |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B1_MAT1 — Match output, channel 1 for 32-bit timer 1.         |  |  |  |
| SWDIO/ACMP1_I2/              | 10                                                | 10         | [5] | no                      | I/O  | I; PU                 | <b>SWDIO</b> — Serial wire debug input/output, default location.  |  |  |  |
| CT32B1_CAP2/<br>CT32B1_MAT2/ |                                                   |            |     |                         | I    | -                     | ACMP1_I2 — Input 2 for comparator 1.                              |  |  |  |
| PIO0_25                      |                                                   |            |     |                         | I    | -                     | <b>CT32B1_CAP2</b> — Capture input, channel 2 for 32-bit timer 1. |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B1_MAT2 — Match output, channel 2 for 32-bit timer 1.         |  |  |  |
|                              |                                                   |            |     |                         | I/O  | -                     | PIO0_25 — General purpose digital input/output pin.               |  |  |  |
| SWCLK/ACMP1_I3/              | 11                                                | 11         | [5] | no                      | I    | I; PU                 | SWCLK — Serial wire clock, default location.                      |  |  |  |
| CT32B1_CAP3/<br>CT32B1_MAT3/ |                                                   |            |     |                         | I    | -                     | ACMP1_I3 — Input 3 for comparator 1.                              |  |  |  |
| PIO0_26                      |                                                   |            |     |                         | I    | -                     | CT32B1_CAP3 — Capture input, channel 3 or 32-bit timer 1.         |  |  |  |
|                              |                                                   |            |     |                         | 0    | -                     | CT32B1_MAT3 — Match output, channel 3 for 32-bit timer 1.         |  |  |  |
|                              |                                                   |            |     |                         | I/O  |                       | PIO0_26 — General purpose digital input/output pin.               |  |  |  |

### Table 3. LPC122x pin description ...continued

## **NXP Semiconductors**

## 32-bit ARM Cortex-M0 microcontroller

LPC122x

| Table 3. LPC122x p               | Table 3.         LPC122x pin descriptioncontinued                                                              |            |                                                                                         |                         |            |                       |                                                                                                                                                                                                                                                             |  |  |  |
|----------------------------------|----------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------|-------------------------|------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Symbol                           | Pin LQFP48                                                                                                     | Pin LQFP64 |                                                                                         | Start<br>logic<br>input | Туре       | Reset<br>state<br>[1] | Description                                                                                                                                                                                                                                                 |  |  |  |
| PIO0_27/ACMP0_O                  | ACMP0_O 12 12 12 1 no I/O I; PU <b>PIO0_27</b> — General purpose digital input/o (high-current output driver). |            | <b>PIO0_27</b> — General purpose digital input/output pin (high-current output driver). |                         |            |                       |                                                                                                                                                                                                                                                             |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | 0          | -                     | ACMP0_O — Output for comparator 0.                                                                                                                                                                                                                          |  |  |  |
| PIO0_28/ACMP1_O/<br>CT16B0_CAP0/ | 13                                                                                                             | 17         | <u>[7]</u>                                                                              | no                      | I/O        | I; PU                 | <b>PIO0_28</b> — General purpose digital input/output pin (high-current output driver).                                                                                                                                                                     |  |  |  |
| CT16B0_MAT0                      |                                                                                                                |            |                                                                                         |                         | 0          | -                     | ACMP1_O — Output for comparator 1.                                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | CT16B0_CAP0 — Capture input, channel 0 for 16-bit timer 0.                                                                                                                                                                                                  |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | 0          | -                     | CT16B0_MAT0 — Match output, channel 0 for 16-bit timer 0.                                                                                                                                                                                                   |  |  |  |
| PIO0_29/ROSC/<br>CT16B0_CAP1/    | 14                                                                                                             | 18         | <u>[7]</u>                                                                              | no                      | I/O        | I; PU                 | <b>PIO0_29</b> — General purpose digital input/output pin (high-current output driver).                                                                                                                                                                     |  |  |  |
| CT16B0_MAT1                      |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | <b>ROSC</b> — Relaxation oscillator for 555 timer applications.                                                                                                                                                                                             |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | <b>CT16B0_CAP1</b> — Capture input, channel 1 for 16-bit timer 0.                                                                                                                                                                                           |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | 0          | -                     | CT16B0_MAT1 — Match output, channel 1 for 16-bit timer 0.                                                                                                                                                                                                   |  |  |  |
| R/PIO0_30/AD0                    |                                                                                                                | 46         | ; <u>[5]</u>                                                                            | no                      | I          | I; PU                 | <b>R</b> — Reserved. Configure for an alternate function in the IOCONFIG block.                                                                                                                                                                             |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | PIO0_30 — General purpose digital input/output pin.                                                                                                                                                                                                         |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD0 — A/D converter, input 0.                                                                                                                                                                                                                               |  |  |  |
| R/PIO0_31/AD1                    | 35                                                                                                             | 47         | .7 <u>[5]</u>                                                                           | no                      | I          | I; PU                 | <b>R</b> — Reserved. Configure for an alternate function in the IOCONFIG block.                                                                                                                                                                             |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | PIO0_31 — General purpose digital input/output pin.                                                                                                                                                                                                         |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD1 — A/D converter, input 1.                                                                                                                                                                                                                               |  |  |  |
| PIO1_0 to PIO1_6                 |                                                                                                                |            |                                                                                         |                         | I/O        |                       | <b>Port 1</b> — Port 1 is a 32-bit I/O port with individual direction and function controls for each bit. The operation of port 1 pins depends on the function selected through the IOCONFIG register block. Pins PIO1_7 through PIO1_31 are not available. |  |  |  |
| R/PIO1_0/AD2                     | 36                                                                                                             | 48         | [5]                                                                                     | no                      | 0          | I; PU                 | R — Reserved. Configure for an alternate function in the IOCONFIG block.                                                                                                                                                                                    |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | PIO1_0 — General purpose digital input/output pin.                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD2 — A/D converter, input 2.                                                                                                                                                                                                                               |  |  |  |
| R/PIO1_1/AD3                     | 37                                                                                                             | 49         | [5]                                                                                     | no                      | I          | I; PU                 | R — Reserved. Configure for an alternate function in the IOCONFIG block.                                                                                                                                                                                    |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | PIO1_1 — General purpose digital input/output pin.                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD3 — A/D converter, input 3.                                                                                                                                                                                                                               |  |  |  |
| PIO1_2/SWDIO/AD4                 | 38                                                                                                             | 50         | [5]                                                                                     | no                      | I/O        | I; PU                 | PIO1_2 — General purpose digital input/output pin.                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I/O        | -                     | <b>SWDIO</b> — Serial wire debug input/output, alternate location.                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD4 — A/D converter, input 4.                                                                                                                                                                                                                               |  |  |  |
| PIO1_3/AD5/WAKEUP                | 39                                                                                                             | 51         | [6]                                                                                     | no                      | I/O        | I; PU                 | PIO1_3 — General purpose digital input/output pin.                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD5 — A/D converter, input 5.                                                                                                                                                                                                                               |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | WAKEUP — Deep power-down mode wake-up pin.                                                                                                                                                                                                                  |  |  |  |
| PIO1_4/AD6                       | 40                                                                                                             | 52         | [5]                                                                                     | no                      | I/O        | I; PU                 | PIO1_4 — General purpose digital input/output pin.                                                                                                                                                                                                          |  |  |  |
|                                  |                                                                                                                |            |                                                                                         |                         | I          | -                     | AD6 — A/D converter, input 6.                                                                                                                                                                                                                               |  |  |  |
| LPC122X                          |                                                                                                                |            |                                                                                         | All ii                  | nformation | rovided in this       | document is subject to legal disclaimers. © NXP B.V. 2011. All rights reserved.                                                                                                                                                                             |  |  |  |
| Objective data abaat             |                                                                                                                |            |                                                                                         |                         | Do         |                       | 21 Eobruory 2011                                                                                                                                                                                                                                            |  |  |  |

## Table 3. LPC122x pin description ...continued

Objective data sheet

## 32-bit ARM Cortex-M0 microcontroller

| Symbol                                        | Pin LQFP48 | Pin LQFP64 |       | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                                                                                                                                                                                                                  |
|-----------------------------------------------|------------|------------|-------|-------------------------|------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIO1_5/AD7/                                   | 41         | 53         | [5]   | no                      | I/O  | I; PU                 | PIO1_5 — General purpose digital input/output pin.                                                                                                                                                                                                           |
| CT16B1_CAP0/                                  |            |            |       |                         | I    | -                     | AD7 — A/D converter, input 7.                                                                                                                                                                                                                                |
| CT16B1_MAT0                                   |            |            |       |                         | I    | -                     | CT16B1_CAP0 — Capture input, channel 0 for 16-bit timer 1.                                                                                                                                                                                                   |
|                                               |            |            |       |                         | 0    | -                     | CT16B1_MAT0 — Match output, channel 0 for 16-bit timer 1.                                                                                                                                                                                                    |
| PIO1_6/                                       | 42         | 54         | [2]   | no                      | I/O  | I; PU                 | PIO1_6 — General purpose digital input/output pin.                                                                                                                                                                                                           |
| CT16B1_CAP1/<br>CT16B1_MAT1                   |            |            |       |                         | I    | -                     | <b>CT16B1_CAP1</b> — Capture input, channel 1 for 16-bit timer 1.                                                                                                                                                                                            |
|                                               |            |            |       |                         | 0    | -                     | CT16B1_MAT1 — Match output, channel 1 for 16-bit timer 1.                                                                                                                                                                                                    |
| PIO2_0 to PIO2_15                             |            |            |       |                         | I/O  |                       | <b>Port 2</b> — Port 2 is a 32-bit I/O port with individual direction and function controls for each bit. The operation of port 2 pins depends on the function selected through the IOCONFIG register block. Pins PIO2_16 through PIO2_31 are not available. |
| PIO2_0/                                       | -          | 29         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_0</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
| CT16B0_CAP0/<br>CT16B0_MAT0/<br>RTS0          |            |            |       |                         | 1    | -                     | <b>CT16B0_CAP0</b> — Capture input, channel 0 for 16-bit timer 0.                                                                                                                                                                                            |
|                                               |            |            |       |                         | 0    | -                     | <b>CT16B0_MAT0</b> — Match output, channel 0 for 16-bit timer 0.                                                                                                                                                                                             |
|                                               |            |            |       |                         | 0    | -                     | <b>RTS0</b> — Request To Send output for UART0.                                                                                                                                                                                                              |
| PIO2_1/ -<br>CT16B0_CAP1/<br>CT16B0_MAT1/RXD0 | -          | 30         | ) [2] | no                      | I/O  | I; PU                 | <b>PIO2_1</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
|                                               |            |            |       |                         | I    | -                     | <b>CT16B0_CAP1</b> — Capture input, channel 1 for 16-bit timer 0.                                                                                                                                                                                            |
| _                                             |            |            |       |                         | 0    | -                     | <b>CT16B0_MAT1</b> — Match output, channel 1 for 16-bit timer 0.                                                                                                                                                                                             |
|                                               |            |            |       |                         | I    | -                     | <b>RXD0</b> — Receiver input for UART0.                                                                                                                                                                                                                      |
| PIO2_2/<br>CT16B1_CAP0/                       | -          | 31         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_2</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
| CT16B1_CAP0/<br>CT16B1_MAT0/TXD0              |            |            |       |                         |      | -                     | <b>CT16B1_CAP0</b> — Capture input, channel 0 for 16-bit timer 1.                                                                                                                                                                                            |
|                                               |            |            |       |                         | 0    | -                     | <b>CT16B1_MAT0</b> — Match output, channel 0 for 16-bit timer 1.                                                                                                                                                                                             |
|                                               |            |            | 101   |                         | 0    | -                     | <b>TXD0</b> — Transmitter output for UART0.                                                                                                                                                                                                                  |
| PIO2_3/<br>CT16B1_CAP1/                       | -          | 32         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_3</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
| CT16B1_CAF1/<br>CT16B1_MAT1/DTR0              |            |            |       |                         |      | -                     | <b>CT16B1_CAP1</b> — Capture input, channel 1 for 16-bit timer 1.                                                                                                                                                                                            |
|                                               |            |            |       |                         | 0    | -                     | <b>CT16B1_MAT1</b> — Match output, channel 1 for 16-bit timer 1.                                                                                                                                                                                             |
|                                               |            |            |       |                         | 0    | -                     | <b>DTR0</b> — Data Terminal Ready output for UART0.                                                                                                                                                                                                          |
| PIO2_4/                                       | -          | 33         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_4</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
| CT32B0_CAP0/<br>CT32B0_MAT0/CTS0              |            |            |       |                         | I    | -                     | <b>CT32B0_CAP0</b> — Capture input, channel 0 for 32-bit timer 0.                                                                                                                                                                                            |
| _                                             |            |            |       |                         | 0    | -                     | <b>CT32B0_MAT0</b> — Match output, channel 0 for 32-bit timer 0.                                                                                                                                                                                             |
|                                               |            |            |       |                         | Ι    | -                     | <b>CTS0</b> — Clear To Send input for UART0.                                                                                                                                                                                                                 |
| PIO2_5/                                       | -          | 34         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_5</b> — General purpose digital input/output pin.                                                                                                                                                                                                    |
| CT32B0_CAP1/<br>CT32B0_MAT1/RI0               |            |            |       |                         | I    | -                     | <b>CT32B0_CAP1</b> — Capture input, channel 1 for 32-bit timer 0.                                                                                                                                                                                            |
| UTSZDU_IMATT/RIU                              |            |            |       |                         | 0    | -                     | CT32B0_MAT1 — Match output, channel 1 for 32-bit timer 0.                                                                                                                                                                                                    |

### Table 3. LPC122x pin description ...continued

## 32-bit ARM Cortex-M0 microcontroller

| Table 3.         LPC122x pin description        continued |            |            |       |                         |      |                       |                                                                               |  |  |
|-----------------------------------------------------------|------------|------------|-------|-------------------------|------|-----------------------|-------------------------------------------------------------------------------|--|--|
| Symbol                                                    | Pin LQFP48 | Pin LQFP64 |       | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                                   |  |  |
| PIO2_6/                                                   | -          | 35         | [2]   | no                      | I/O  | I; PU                 | PIO2_6 — General purpose digital input/output pin.                            |  |  |
| CT32B0_CAP2/<br>CT32B0_MAT2/DCD0                          |            |            |       |                         | I    | -                     | <b>CT32B0_CAP2</b> — Capture input, channel 2 for 32-bit timer 0.             |  |  |
| 010200_000000                                             |            |            |       |                         | 0    | -                     | CT32B0_MAT2 — Match output, channel 2 for 32-bit timer 0.                     |  |  |
|                                                           |            |            |       |                         | I    | -                     | <b>DCD0</b> — Data Carrier Detect input for UART0.                            |  |  |
| PIO2_7/                                                   | -          | 36         | [2]   | no                      | I/O  | I; PU                 | PIO2_7 — General purpose digital input/output pin.                            |  |  |
| CT32B0_CAP3/<br>CT32B0_MAT3/DSR0                          |            |            |       |                         | I    | -                     | <b>CT32B0_CAP3</b> — Capture input, channel 3 for 32-bit timer 0.             |  |  |
|                                                           |            |            |       |                         | 0    | -                     | CT32B0_MAT3 — Match output, channel 3 for 32-bit timer 0.                     |  |  |
|                                                           |            |            |       |                         | I    | -                     | <b>DSR0</b> — Data Set Ready input for UART0.                                 |  |  |
| PIO2_8/                                                   | -          | 59         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_8</b> — General purpose digital input/output pin.                     |  |  |
| CT32B1_CAP0/<br>CT32B1_MAT0                               |            |            |       |                         | I    | -                     | <b>CT32B1_CAP0</b> — Capture input, channel 0 for 32-bit timer 1.             |  |  |
|                                                           |            |            |       |                         | 0    | -                     | CT32B1_MAT0 — Match output, channel 0 for 32-bit timer 1.                     |  |  |
| PIO2_9/<br>CT32B1_CAP1/<br>CT32B1_MAT1                    | -          | 60         | ) [2] | no                      | I/O  | I; PU                 | <b>PIO2_9</b> — General purpose digital input/output pin.                     |  |  |
|                                                           |            |            |       |                         | I    | -                     | <b>CT32B1_CAP1</b> — Capture input, channel 1 for 32-bit timer 1.             |  |  |
|                                                           |            |            | 101   |                         | 0    | -                     | CT32B1_MAT1 — Match output, channel 1 for 32-bit timer 1.                     |  |  |
| PIO2_10/<br>CT32B1_CAP2/<br>CT32B1_MAT2/TXD1              | -          | 61         | [2]   | 2] no                   | I/O  | I; PU                 | <b>PIO2_10</b> — General purpose digital input/output pin.                    |  |  |
|                                                           |            |            |       |                         | I    | -                     | <b>CT32B1_CAP2</b> — Capture input, channel 2 for 32-bit timer 1.             |  |  |
|                                                           |            |            |       |                         | 0    | -                     | CT32B1_MAT2 — Match output, channel 2 for 32-bit timer 1.                     |  |  |
|                                                           |            |            |       |                         | 0    | -                     | <b>TXD1</b> — Transmitter output for UART1.                                   |  |  |
| PIO2_11/                                                  | -          | 62         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_11</b> — General purpose digital input/output pin.                    |  |  |
| CT32B1_CAP3/<br>CT32B1_MAT3/RXD1                          |            |            |       |                         | I    | -                     | <b>CT32B1_CAP3</b> — Capture input, channel 3 for 32-bit timer 1.             |  |  |
|                                                           |            |            |       |                         | 0    | -                     | CT32B1_MAT3 — Match output, channel 3 for 32-bit timer 1.                     |  |  |
|                                                           |            |            |       |                         | Ι    | -                     | <b>RXD1</b> — Receiver input for UART1.                                       |  |  |
| PIO2_12/RXD1                                              | -          | 13         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_12</b> — General purpose digital input/output pin.                    |  |  |
|                                                           |            |            |       |                         | I    | -                     | <b>RXD1</b> — Receiver input for UART1.                                       |  |  |
| PIO2_13/TXD1                                              | -          | 14         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_13</b> — General purpose digital input/output pin.                    |  |  |
|                                                           |            |            |       |                         | 0    | -                     | <b>TXD1</b> — Transmitter output for UART1.                                   |  |  |
| PIO2_14                                                   | -          | 15         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_14</b> — General purpose digital input/output pin.                    |  |  |
| PIO2_15                                                   | -          | 16         | [2]   | no                      | I/O  | I; PU                 | <b>PIO2_15</b> — General purpose digital input/output pin.                    |  |  |
| RTCXIN                                                    |            | 57         |       | -                       | Ι    | -                     | Input to the 32 kHz oscillator circuit.                                       |  |  |
| RTCXOUT                                                   | 45         | 58         |       | -                       | 0    | -                     | Output from the 32 kHz oscillator amplifier.                                  |  |  |
| XTALIN                                                    | 1          | 1          |       | -                       | Ι    | -                     | Input to the system oscillator circuit and internal clock generator circuits. |  |  |
| XTALOUT                                                   | 2          | 2          |       | -                       | 0    | -                     | Output from the system oscillator amplifier.                                  |  |  |
| VREF_CMP                                                  | 3          | 3          |       | -                       | I    | -                     | Reference voltage for comparator.                                             |  |  |

## Table 3. LPC122x pin description ...continued

| Symbol               | Pin LQFP48 | Pin LQFP64 | Start<br>logic<br>input | Туре | Reset<br>state<br>[1] | Description                                                                                         |
|----------------------|------------|------------|-------------------------|------|-----------------------|-----------------------------------------------------------------------------------------------------|
| V <sub>DD(IO)</sub>  | 47         | 63         | -                       | I    | -                     | Input/output supply voltage.                                                                        |
| V <sub>DD(3V3)</sub> | 44         | 56         | -                       | I    | -                     | 3.3 V supply voltage to the internal regulator and the ADC. Also used as the ADC reference voltage. |
| V <sub>SSIO</sub>    | 48         | 64         | -                       | I    | -                     | Ground.                                                                                             |
| V <sub>SS</sub>      | 43         | 55         | -                       | I    | -                     | Ground.                                                                                             |

#### Table 3. LPC122x pin description ...continued

[1] Pin state at reset for default function: I = Input; O = Output; PU = internal pull-up enabled; IA = inactive, no pull-up/down enabled.

[2] 3.3 V tolerant, digital I/O pin; default: pull-up enabled, no hysteresis.

[3] I<sup>2</sup>C-bus pins; 5 V tolerant; open-drain; default: no pull-up/pull-down; no hysteresis.

[4] 3.3 V tolerant, digital I/O pin with RESET function; default: pull-up enabled, no hysteresis. An external pull-up resistor is required on this pin for the Deep power-down mode.

- [5] 3.3 V tolerant, digital I/O pin with analog function; default: pull-up enabled, no hysteresis.
- [6] 3.3 V tolerant, digital I/O pin with analog function and WAKEUP function; default: pull-up enabled, no hysteresis.

[7] 3.3 V tolerant, high-drive digital I/O pin; default: pull-up enabled, no hysteresis.

To enable a peripheral function, find the corresponding port pin, or select a port pin if the function is multiplexed, and program the port pin's IOCONFIG register to enable that function. The primary SWD functions and RESET are the default functions on their pins after reset, all other digital pins default to GPIO.

| Peripheral         | Function | Туре | Available or | n ports: |   |
|--------------------|----------|------|--------------|----------|---|
| Analog comparators | ROSC     | I/O  | PIO0_29      | -        | - |
|                    | ACMP0_I0 | I    | PIO0_19      | -        | - |
|                    | ACMP0_I1 | I    | PIO0_20      | -        | - |
|                    | ACMP0_I2 | I    | PIO0_21      | -        | - |
|                    | ACMP0_I3 | I    | PIO0_22      | -        | - |
|                    | ACMP0_O  | 0    | PIO0_27      | -        | - |
|                    | ACMP1_I0 | I    | PIO0_23      | -        | - |
|                    | ACMP1_I1 | I    | PIO0_24      | -        | - |
|                    | ACMP1_I2 | I    | PIO0_25      | -        | - |
|                    | ACMP1_I3 | I    | PIO0_26      | -        | - |
|                    | ACMP1_O  | 0    | PIO0_28      | -        | - |
| ADC                | AD0      | I    | PIO0_30      | -        | - |
|                    | AD1      | I    | PIO0_31      | -        | - |
|                    | AD2      | I    | PIO1_0       | -        | - |
|                    | AD3      | I    | PIO1_1       | -        | - |
|                    | AD4      | I    | PIO1_2       | -        | - |
|                    | AD5      | I    | PIO1_3       | -        | - |
|                    | AD6      | I    | PIO1_4       | -        | - |
|                    | AD7      | I    | PIO1_5       | -        | - |

#### Table 4.Pin multiplexing

14 of 60

## **NXP Semiconductors**

## LPC122x

## 32-bit ARM Cortex-M0 microcontroller

| Peripheral | Function    | Туре | Available o | on ports: |         |
|------------|-------------|------|-------------|-----------|---------|
| CT16B0     | CT16B0_CAP0 | I    | PIO0_11     | PIO0_28   | PIO2_0  |
|            | CT16B0_CAP1 | I    | PIO0_12     | PIO0_29   | PIO2_1  |
|            | CT16B0_MAT0 | 0    | PIO0_11     | PIO0_28   | PIO2_0  |
|            | CT16B0_MAT1 | 0    | PIO0_12     | PIO0_29   | PIO2_1  |
| CT16B1     | CT16B1_CAP0 | I    | PIO0_15     | PIO1_5    | PIO2_2  |
|            | CT16B1_CAP1 | I    | PIO0_16     | PIO1_6    | PIO2_3  |
|            | CT16B1_MAT0 | 0    | PIO0_15     | PIO1_5    | PIO2_2  |
|            | CT16B1_MAT1 | 0    | PIO0_16     | PIO1_6    | PIO2_3  |
| CT32B0     | CT32B0_CAP0 | I    | PIO0_1      | PIO0_18   | PIO2_4  |
|            | CT32B0_CAP1 | I    | PIO0_2      | PIO0_19   | PIO2_5  |
|            | CT32B0_CAP2 | I    | PIO0_3      | PIO0_20   | PIO2_6  |
|            | CT32B0_CAP3 | I    | PIO0_4      | PIO0_21   | PIO2_7  |
|            | CT32B0_MAT0 | 0    | PIO0_1      | PIO0_18   | PIO2_4  |
|            | CT32B0_MAT1 | 0    | PIO0_2      | PIO0_19   | PIO2_5  |
|            | CT32B0_MAT2 | 0    | PIO0_3      | PIO0_20   | PIO2_6  |
|            | CT32B0_MAT3 | 0    | PIO0_4      | PIO0_21   | PIO2_7  |
| CT32B1     | CT32B1_CAP0 | I    | PIO0_6      | PIO0_23   | PIO2_8  |
|            | CT32B1_CAP1 | I    | PIO0_7      | PIO0_24   | PIO2_9  |
|            | CT32B1_CAP2 | I    | PIO0_8      | PIO0_25   | PIO2_10 |
|            | CT32B1_CAP3 | I    | PIO0_9      | PIO0_26   | PIO2_11 |
|            | CT32B1_MAT0 | 0    | PIO0_6      | PIO0_23   | PIO2_8  |
|            | CT32B1_MAT1 | 0    | PIO0_7      | PIO0_24   | PIO2_9  |
|            | CT32B1_MAT2 | 0    | PIO0_8      | PIO0_25   | PIO2_10 |
|            | CT32B1_MAT3 | 0    | PIO0_9      | PIO0_26   | PIO2_11 |
| JART0      | RXD0        | I    | PIO0_1      | PIO2_1    | -       |
|            | TXD0        | 0    | PIO0_2      | PIO2_2    | -       |
|            | CTS0        | I    | PIO0_7      | PIO2_4    | -       |
|            | DCD0        | I    | PIO0_5      | PIO2_6    | -       |
|            | DSR0        | I    | PIO0_4      | PIO2_7    | -       |
|            | DTR0        | 0    | PIO0_3      | PIO2_3    | -       |
|            | RIO         | I    | PIO0_6      | PIO2_5    | -       |
|            | RTS0        | 0    | PIO0_0      | PIO2_0    | -       |
| JART1      | RXD1        | I    | PIO0_8      | PIO2_11   | PIO2_12 |
|            | TXD1        | 0    | PIO0_9      | PIO2_10   | PIO2_13 |
| SSP/SPI    | SCK         | I/O  | PIO0_14     | -         | -       |
|            | MISO        | I/O  | PIO0_16     | -         | -       |
|            | MOSI        | I/O  | PIO0_17     | -         | -       |
|            | SSEL        | I/O  | PIO0_15     | -         | -       |
| 2C         | SCL         | I/O  | PIO0_10     | -         | -       |
|            | SDA         | I/O  | PIO0_11     | -         | -       |

Dbjective data sheet

| Table 4. Pin mul<br>Peripheral | tiplexing<br>Function | Туре | Available o | on ports: |   |
|--------------------------------|-----------------------|------|-------------|-----------|---|
| SWD                            | SWCLK <sup>[1]</sup>  | I    | PIO0_18     | PIO0_26   | - |
|                                | SWDIO <sup>[1]</sup>  | I/O  | PIO0_25     | PIO1_2    | - |
| Reset                          | RESET                 | Ι    | PIO0_13     | -         | - |
| Clockout pin                   | CLKOUT                | 0    | PIO0_12     | -         | - |

[1] After reset, the SWD functions are selected by default on pins PIO0\_26 and PIO0\_25.

#### **Functional description** 7.

### 7.1 ARM Cortex-M0 processor

The ARM Cortex-M0 is a general purpose, 32-bit microprocessor, which offers high performance and very low power consumption.

#### 7.1.1 System tick timer

The ARM Cortex-M0 includes a System Tick timer (SYSTICK) that is intended to generate a dedicated SYSTICK exception at a 10 ms interval.

### 7.2 On-chip flash program memory

The LPC122x contain up to 128 kB of on-chip flash memory.

### 7.3 On-chip SRAM

The LPC122x contain a total of up to 8 kB on-chip static RAM memory.

### 7.4 Memory map

The LPC122x incorporates several distinct memory regions, shown in the following figures. Figure 4 shows the overall map of the entire address space from the user program viewpoint following reset. The interrupt vector area supports address remapping.

The AHB peripheral area is 2 megabyte in size, and is divided to allow for up to 128 peripherals. The APB peripheral area is 512 kB in size and is divided to allow for up to 32 peripherals. Each peripheral of either type is allocated 16 kilobytes of space. This allows simplifying the address decoding for each peripheral.

## **NXP Semiconductors**

## LPC122x

#### 32-bit ARM Cortex-M0 microcontroller

| 4 GB | LPC122x                            |                            | 7 CRC 0x5007 0                                                                              |
|------|------------------------------------|----------------------------|---------------------------------------------------------------------------------------------|
| 4 GB | reserved                           | OxFFFF FFFF                | 3 - 6 reserved                                                                              |
|      | private peripheral bus             | 0xE010 0000<br>0xE000 0000 | 2 GPIO PIO2 0x5003 0<br>0x5002 0                                                            |
|      | record                             |                            | 1 GPIO PIO1 0x5001 0                                                                        |
| Ľ    | reserved                           | 0x5008 0000                | 0 GPIO PIO0 0x5000 0                                                                        |
|      | AHB peripherals                    | 0x5000 0000                | APB peripherals 0x4008 00                                                                   |
|      | reserved                           |                            | 22 - 31 reserved                                                                            |
|      |                                    | 0x4008 0000                | 0x4005 80                                                                                   |
| 1 GB | APB peripherals                    | 0x4000 0000                | 21 comparator 0/1 0x4005 40                                                                 |
|      |                                    |                            | 20 RTC 0x4005 00                                                                            |
| Î    | reserved                           |                            | 19 micro DMA registers 0x4004 C                                                             |
|      |                                    | 0x1FFF 2000                | 18         system control         0x4004 80           17         IOCONFIG         0x4004 40 |
|      | 8 kB boot ROM                      | 0x1FFF 0000                |                                                                                             |
|      | reserved                           |                            | 0x4004 00                                                                                   |
|      | 8 kB custom ROM                    | 0x1FFE 2000                | 14 PMU 0x4003 C<br>0x4003 80                                                                |
| -    | reserved                           | 0x1FFE 0000                |                                                                                             |
|      | 16 kB NXP library ROM              | 0x1FFC 4000<br>0x1FFC 0000 | 9 - 13 reserved                                                                             |
|      | reserved                           |                            | 8 ADC 0x4002 00<br>0x4002 00                                                                |
|      |                                    | 0x1000 2000                | 8         ADC         0x4002 00           7         32-bit counter/timer 1         0x4001 C |
|      | 8 kB SRAM (LPC1225/6/7)            | 0x1000 1000                | 6 32-bit counter/timer 0 0x4001 80                                                          |
|      | 4 kB SRAM (LPC1224)                | 0x1000 0000                | 5 16-bit counter/timer 1 0x4001 40                                                          |
| 一个   | reserved                           |                            | 4 16-bit counter/timer 0 0x4001 00                                                          |
|      | 128 kB on-chip flash (LPC1227/301) | 0x0002 0000                | 3 UART1 0x4000 C                                                                            |
|      | 96 kB on-chip flash (LPC1226/301)  | 0x0001 4000                | 2 UARTO 0x4000 80                                                                           |
|      | 80 kB on-chip flash (LPC1225/321)  |                            | 1 WDT 0x4000 40                                                                             |
|      | 64 kB on-chip flash (LPC1225/301)  | 0x0001 0000                | 0 I <sup>2</sup> C-bus 0x4000 00                                                            |
|      | 48 kB on-chip flash (LPC1224/121)  | 0x0000 C000                | 0x0000 00C0                                                                                 |
|      | 32 kB on-chip flash (LPC1224/101)  |                            | ox0000 0000 002aa                                                                           |

Fig 4. LPC122x memory map

## 7.5 Nested Vectored Interrupt Controller (NVIC)

The Nested Vectored Interrupt Controller (NVIC) is an integral part of the Cortex-M0. The tight coupling to the CPU allows for low interrupt latency and efficient processing of late arriving interrupts.

### 7.5.1 Features

• Controls system exceptions and peripheral interrupts.

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

- In the LPC122x, the NVIC supports 32 vectored interrupts. In addition, up to 12 of the individual GPIO inputs are NVIC-vector capable.
- Four programmable interrupt priority levels with hardware priority level masking.
- Software interrupt generation.
- Non-maskable Interrupt (NMI) can be programmed to use any of the peripheral interrupts. The NMI is not available on an external pin.

### 7.5.2 Interrupt sources

Each peripheral device has one interrupt line connected to the NVIC but may have several interrupt flags. Individual interrupt flags may also represent more than one interrupt source.

Any GPIO pin (total of up to 55 pins) regardless of the selected function, can be programmed to generate an interrupt on a level, a rising edge or falling edge, or both.

## 7.6 IOCONFIG block

The IOCONFIG block allows selected pins of the microcontroller to have more than one function. Configuration registers control the multiplexers to allow connection between the pin and the on-chip peripherals.

Peripherals should be connected to the appropriate pins prior to being activated and prior to any related interrupt(s) being enabled. Activity of any enabled peripheral function that is not mapped to a related pin should be considered undefined.

### 7.6.1 Features

- Programmable pull-up resistor.
- Programmable digital glitch filter.
- Programmable input inverter.
- Programmable drive current.
- Programmable open-drain mode.

## 7.7 Micro DMA controller

The micro DMA controller enables memory-to-memory, memory-to-peripheral, and peripheral-to-memory data transfers. The supported peripherals are: UART0 (transmit and receive), UART1 (transmit and receive), SSP/SPI (transmit and receive), ADC, RTC, 32-bit counter/timer 0 (match output channels 0 and 1), 32-bit counter/timer 1 (match output channels 0 and 1), 16-bit counter/timer 0 (match output channel 0), 16-bit counter/timer 1 (match output channel 0), comparator 0, comparator 1, GPIO0 to GPIO2.

### 7.7.1 Features

- Single AHB-Lite master for transferring data using a 32-bit address bus and 32-bit data bus.
- 21 DMA channels.
- Handshake signals and priority level programmable for each channel.
- Each priority level arbitrates using a fixed priority that is determined by the DMA channel number.

- Supports memory-to-memory, memory-to-peripheral, and peripheral-to-memory transfers.
- Supports multiple DMA cycle types and multiple DMA transfer widths.
- Performs all DMA transfers using the single AHB-Lite burst type.

### 7.8 CRC engine

The Cyclic Redundancy Check (CRC) engine with programmable polynomial settings supports several CRC standards commonly used. To save system power and bus bandwidth, the CRC engine supports DMA transfers.

#### 7.8.1 Features

- Supports three common polynomials CRC-CCITT, CRC-16, and CRC-32.
  - CRC-CCITT: x<sup>16</sup> + x<sup>12</sup> + x<sup>5</sup> + 1
  - CRC-16:  $x^{16} + x^{15} + x^2 + 1$
  - CRC-32:  $x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^8 + x^7 + x^5 + x^4 + x^2 + x + 1$
- Bit order reverse and 1's complement programmable setting for input data and CRC sum.
- Programmable seed number setting.
- Supports CPU programmed I/O or DMA back-to-back transfer.
- Accept any size of data width per write: 8, 16 or 32-bit.
  - 8-bit write: 1-cycle operation
  - 16-bit write: 2-cycle operation (8-bit × 2-cycle)
  - 32-bit write: 4-cycle operation (8-bit × 4-cycle)

## 7.9 Fast general purpose parallel I/O

Device pins that are not connected to a specific peripheral function are controlled by the GPIO registers. Pins may be dynamically configured as inputs or outputs. Separate registers allow setting or clearing any number of outputs simultaneously. The value of the output register may be read back as well as the current state of the port pins.

### 7.9.1 Features

- Bit level set and clear registers allow a single instruction to set or clear any number of bits in one port.
- Direction control of individual bits.
- All I/O default to inputs after reset.

## 7.10 UARTs

The LPC122x contains two UARTs. UART0 supports full modem control and RS-485/9-bit mode and allows both software address detection and automatic hardware address detection using 9-bit mode.

The UARTs include a fractional baud rate generator. Standard baud rates such as 115200 Bd can be achieved with any crystal frequency above 2 MHz.

#### 7.10.1 Features

- 16-byte Receive and Transmit FIFOs.
- Register locations conform to 16C550 industry standard.
- Receiver FIFO trigger points at 1 B, 4 B, 8 B, and 14 B.
- Built-in fractional baud rate generator covering wide range of baud rates without a need for external crystals of particular values.
- Auto-baud capabilities and FIFO control mechanism that enables software flow control implementation.
- Support for RS-485/9-bit mode (UART0).
- Support for modem control (UART0).

### 7.11 SSP/SPI serial I/O controller

The LPC122x contain one SSP/SPI controller. The SSP/SPI controller is capable of operation on a SSP, 4-wire SSI, or Microwire bus. It can interact with multiple masters and slaves on the bus. Only a single master and a single slave can communicate on the bus during a given data transfer. The SSP supports full duplex transfers, with frames of 4 bits to 16 bits of data flowing from the master to the slave and from the slave to the master. In practice, often only one of these data flows carries meaningful data.

#### 7.11.1 Features

- Compatible with Motorola SPI, 4-wire Texas Instruments SSI, and National Semiconductor Microwire buses
- Synchronous serial communication
- Master or slave operation
- 8-frame FIFOs for both transmit and receive
- 4-bit to 16-bit frame

### 7.12 I<sup>2</sup>C-bus serial I/O controller

The LPC122x contain one I<sup>2</sup>C-bus controller.

The I<sup>2</sup>C-bus is bidirectional for inter-IC control using only two wires: a serial clock line (SCL) and a serial data line (SDA). Each device is recognized by a unique address and can operate as either a receiver-only device (e.g., an LCD driver) or a transmitter with the capability to both receive and send information (such as memory). Transmitters and/or receivers can operate in either master or slave mode, depending on whether the chip has to initiate a data transfer or is only addressed. The I<sup>2</sup>C is a multi-master bus and can be controlled by more than one bus master connected to it.

### 7.12.1 Features

- The I<sup>2</sup>C-interface is a standard I<sup>2</sup>C-compliant bus interface with open-drain pins and supports I<sup>2</sup>C Fast-mode Plus with bit rates of up to 1 Mbit/s.
- Programmable digital glitch filter providing a 60 ns to 1 μs input filter.
- Easy to configure as master, slave, or master/slave.
- Programmable clocks allow versatile rate control.

- Bidirectional data transfer between masters and slaves.
- Multi-master bus (no central master).
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus.
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus.
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer.
- The I<sup>2</sup>C-bus can be used for test and diagnostic purposes.
- The I<sup>2</sup>C-bus controller supports multiple address recognition and a bus monitor mode.

#### 7.13 10-bit ADC

The LPC122x contains one ADC. It is a single 10-bit successive approximation ADC with eight channels.

#### 7.13.1 Features

- 10-bit successive approximation ADC.
- Input multiplexing among 8 pins.
- Power-down mode.
- Measurement range 0 V to V<sub>DD(3V3)</sub>.
- 10-bit conversion time of 257 kHz.
- Burst conversion mode for single or multiple inputs.
- Optional conversion on transition of input pin or counter/timer match signal.
- Individual result registers for each ADC channel to reduce interrupt overhead.

### 7.14 Comparator block

The comparator block consists of two analog comparators.

#### 7.14.1 Features

- Up to six selectable external sources per comparator; fully configurable on either positive or negative comparator input channels.
- BOD 0.9 V internal reference voltage selectable on both comparators; configurable on either positive or negative comparator input channels.
- 32-stage Voltage Ladder internal reference voltage selectable on both comparators; configurable on either positive or negative comparator input channels.
- Voltage ladder source voltage is selectable from an external pin or an internal 3.3 V voltage rail if external power source is not available.
- Voltage ladder can be separately powered down for applications only requiring the comparator function.
- Relaxation oscillator circuitry output for a feedback 555-style timer application.
- Common interrupt connected to NVIC.
- Comparator outputs selectable as synchronous or asynchronous.

• Comparator outputs connect to two timers, allowing for the recording of comparison event time stamps.

#### 7.15 General purpose external event counter/timers

The LPC122x includes two 32-bit counter/timers and two 16-bit counter/timers. The counter/timer is designed to count cycles of the system derived clock. It can optionally generate interrupts or perform other actions at specified timer values, based on four match registers. Each counter/timer also includes up to four capture inputs to trap the timer value when an input signal transitions, optionally generating an interrupt.

#### 7.15.1 Features

- A 32-bit/16-bit timer/counter with a programmable 32-bit/16-bit prescaler.
- Counter or timer operation.
- Up to four capture channels per timer, that can take a snapshot of the timer value when an input signal transitions. A capture event may also generate an interrupt.
- Four match registers per timer that allow:
  - Continuous operation with optional interrupt generation on match.
  - Stop timer on match with optional interrupt generation.
  - Reset timer on match with optional interrupt generation.
- Up to four external outputs corresponding to match registers, with the following capabilities:
  - Set LOW on match.
  - Set HIGH on match.
  - Toggle on match.
  - Do nothing on match.
- The timer and prescaler may be configured to be cleared on a designated capture event. This feature permits easy pulse width measurement by clearing the timer on the leading edge of an input pulse and capturing the timer value on the trailing edge.
- Supports timed DMA requests.

### 7.16 Windowed WatchDog timer (WWDT)

The purpose of the watchdog is to reset the microcontroller within a windowed amount of time if it enters an erroneous state. When enabled, the watchdog will generate a system reset if the user program fails to 'feed' (or reload) the watchdog within a predetermined amount of time.

#### 7.16.1 Features

- Internally resets chip if not periodically reloaded.
- Debug mode.
- Incorrect/Incomplete feed sequence causes reset/interrupt if enabled.
- Safe operation: can be locked by software to be always on.
- Flag to indicate watchdog reset.
- Programmable 24-bit timer with internal prescaler.

- Selectable time period from  $(T_{cy(WDCLK)} \times 256 \times 4)$  to  $(T_{cy(WDCLK)} \times 2^{24} \times 4)$  in multiples of  $T_{cy(WDCLK)} \times 4$ .
- The Watchdog Clock (WDCLK) source can be selected from the Internal RC oscillator (IRC) or the Watchdog oscillator. This gives a wide range of potential timing choices of Watchdog operation under different power reduction conditions. It also provides the ability to run the WDT from an entirely internal source that is not dependent on an external crystal and its associated components and wiring for increased reliability.

## 7.17 Real-time clock (RTC)

The RTC provides a basic alarm function or can be used as a long time base counter. The RTC generates an interrupt after counting for a programmed number of cycles of the RTC clock input.

#### 7.17.1 Features

- Uses dedicated 32 kHz ultra low-power oscillator.
- Selectable clock inputs: RTC oscillator (1 Hz, delayed 1 Hz, or 1 kHz clock) or main clock with programmable clock divider.
- 32-bit counter.
- Programmable 32-bit match/compare register.
- Software maskable interrupt when counter and compare registers are identical.
- Generates wake-up from Deep-sleep and Deep power-down modes.

## 7.18 Clocking and power control

#### 7.18.1 Crystal oscillators

The LPC122x include four independent oscillators. These are the system oscillator, the Internal RC oscillator (IRC), the RTC 32 kHz oscillator (for the RTC only), and the Watchdog oscillator. Except for the RTC oscillator, each oscillator can be used for more than one purpose as required in a particular application.

Following reset, the LPC122x will operate from the Internal RC oscillator until switched by software. This allows systems to operate without any external crystal and the bootloader code to operate at a known frequency.

See Figure 5 for an overview of the LPC122x clock generation.

## **NXP Semiconductors**

## LPC122x

#### 32-bit ARM Cortex-M0 microcontroller



#### 7.18.1.1 Internal RC oscillator

The IRC may be used as the clock source for the WDT, and/or as the clock that drives the PLL and subsequently the CPU. The nominal IRC frequency is 12 MHz. The IRC is trimmed to 1 % accuracy over the entire voltage and temperature range.

Upon power-up or any chip reset, the LPC122x use the IRC as the clock source. Software may later switch to one of the other available clock sources.

#### 7.18.1.2 System oscillator

The system oscillator can be used as the clock source for the CPU, with or without using the PLL.

The system oscillator operates at frequencies of 1 MHz to 25 MHz. This frequency can be boosted to a higher frequency, up to the maximum CPU operating frequency, by the system PLL. The ARM processor clock frequency is referred to as CCLK elsewhere in this document.

#### 7.18.1.3 Watchdog oscillator

The watchdog oscillator can be used as a clock source that directly drives the CPU, the watchdog timer, or the CLKOUT pin. The watchdog oscillator nominal frequency is programmable between 7.8 kHz and 1.7 MHz. The frequency spread over processing and temperature is  $\pm 40$  %.

#### 7.18.2 System PLL

The PLL accepts an input clock frequency in the range of 10 MHz to 25 MHz. The input frequency is multiplied up to a high frequency with a Current Controlled Oscillator (CCO). The multiplier can be an integer value from 1 to 32. The CCO operates in the range of 156 MHz to 320 MHz, so there is an additional divider in the loop to keep the CCO within its frequency range while the PLL is providing the desired output frequency. The output divider may be set to divide by 2, 4, 8, or 16 to produce the output clock. The PLL output frequency must be lower than 100 MHz. Since the minimum output divider value is 2, it is insured that the PLL output has a 50 % duty cycle. The PLL is turned off and bypassed following a chip reset and may be enabled by software. The program must configure and activate the PLL, wait for the PLL to lock, and then connect to the PLL as a clock source. The PLL settling time is 100  $\mu$ s.

#### 7.18.3 Clock output

The LPC122x features a clock output function that routes the IRC oscillator, the system oscillator, the watchdog oscillator, or the main clock to an output pin.

#### 7.18.4 Wake-up process

The LPC122x begin operation at power-up and when awakened from Deep power-down mode by using the 12 MHz IRC oscillator as the clock source. This allows chip operation to resume quickly. If the main oscillator or the PLL is needed by the application, software will need to enable these features and wait for them to stabilize before they are used as a clock source.

#### 7.18.5 Power control

The LPC122x support a variety of power control features. There are three special modes of processor power reduction: Sleep mode, Deep-sleep mode, and Deep power-down mode. The CPU clock rate may also be controlled as needed by changing clock sources, reconfiguring PLL values, and/or altering the CPU clock divider value. This allows a trade-off of power versus processing speed based on application requirements. In addition, a register is provided for shutting down the clocks to individual on-chip peripherals, allowing fine tuning of power consumption by eliminating all dynamic power use in any peripherals that are not required for the application. Selected peripherals have their own clock divider which provides even better power control.

#### 7.18.5.1 Sleep mode

When Sleep mode is entered, the clock to the core is stopped. Resumption from the Sleep mode does not need any special sequence but re-enabling the clock to the ARM core.

25 of 60

In Sleep mode, execution of instructions is suspended until either a reset or interrupt occurs. Peripheral functions continue operation during Sleep mode and may generate interrupts to cause the processor to resume execution. Sleep mode eliminates dynamic power used by the processor itself, memory systems and related controllers, and internal buses.

#### 7.18.5.2 Deep-sleep mode

In Deep-sleep mode, the chip is in Sleep mode, and in addition all analog blocks are shut down. As an exception, the user has the option to keep the watchdog oscillator and the BOD circuit running for self-timed wake-up and BOD protection. Deep-sleep mode allows for additional power savings.

The GPIO pins PIO0\_0 to PIO0\_11 (up to 12 pins total) and the RTC match interrupt can serve as a wake-up input to the start logic to wake up the chip from Deep-sleep mode.

Unless the watchdog oscillator is selected to run in Deep-sleep mode, the clock source should be switched to IRC before entering Deep-sleep mode, because the IRC can be switched on and off glitch-free.

#### 7.18.5.3 Deep power-down mode

In Deep power-down mode, power is shut off to the entire chip with the exception of the Real Time Clock, the four general-purpose registers, and the WAKEUP pin. The LPC122x can wake up from Deep power-down mode via the WAKEUP pin or the RTC match interrupt.

When entering Deep power-down mode, an external pull-up resistor is required on the WAKEUP pin to hold it HIGH. The RESET pin must also be held HIGH to prevent it from floating while in Deep power-down mode.

## 7.19 System control

#### 7.19.1 Start logic

The start logic connects external pins to corresponding interrupts in the NVIC. Each pin shown in <u>Table 3</u> as input to the start logic has an individual interrupt in the NVIC interrupt vector table. The start logic pins can serve as external interrupt pins when the chip is running. In addition, an input signal on the start logic pins can wake up the chip from Deep-sleep mode when all clocks are shut down.

The start logic must be configured in the system configuration block and in the NVIC before being used.

#### 7.19.2 Reset

Reset has four sources on the LPC122x: the RESET pin, the Watchdog reset, power-on reset (POR), and the BrownOut Detection (BOD) circuit. The RESET pin is a Schmitt trigger input pin. Assertion of chip reset by any source, once the operating voltage attains a usable level, starts the IRC and initializes the flash controller.

When the internal Reset is removed, the processor begins executing at address 0, which is initially the Reset vector mapped from the boot block. At that point, all of the processor and peripheral registers have been initialized to predetermined values.

An external pull-up resistor is required on the RESET pin if Deep power-down mode is used.

#### 7.19.3 Brownout detection

The LPC122x includes four levels for monitoring the voltage on the  $V_{DD(3V3)}$  pin. If this voltage falls below one of the four selected levels, the BOD asserts an interrupt signal to the NVIC. This signal can be enabled for interrupt in the Interrupt Enable Register in the NVIC in order to cause a CPU interrupt; if not, software can monitor the signal by reading a dedicated status register. An additional threshold level can be selected to cause a forced reset of the chip.

### 7.19.4 Code security (Code Read Protection - CRP)

This feature of the LPC122x allows user to enable different levels of security in the system so that access to the on-chip flash and use of the SWD and ISP can be restricted. When needed, CRP is invoked by programming a specific pattern into a dedicated flash location. IAP commands are not affected by the CRP.

There are three levels of Code Read Protection:

- 1. CRP1 disables access to chip via the SWD and allows partial flash update (excluding flash sector 0) using a limited set of the ISP commands. This mode is useful when CRP is required and flash field updates are needed but all sectors can not be erased.
- CRP2 disables access to chip via the SWD and only allows full flash erase and update using a reduced set of the ISP commands.
- Running an application with level CRP3 selected fully disables any access to chip via the SWD pins and the ISP. This mode effectively disables ISP override using PIO0\_12 pin, too. It is up to the user's application to provide (if needed) flash update mechanism using IAP calls or call reinvoke ISP command to enable flash update via UART0.

#### CAUTION



If level three Code Read Protection (CRP3) is selected, no future factory testing can be performed on the device.

In addition to the three CRP levels, sampling of pin PIO0\_12 for valid user code can be disabled.

#### 7.19.5 APB interface

The APB peripherals are located on one APB bus.

#### 7.19.6 AHB-Lite

The AHB-Lite connects the CPU bus of the ARM Cortex-M0 to the flash memory, the main static RAM, and the Boot ROM.

#### 7.19.7 External interrupt inputs

All GPIO pins can be level or edge sensitive interrupt inputs.

## 7.20 Emulation and debugging

Debug functions are integrated into the ARM Cortex-M0. Serial wire debug is supported.

## 7.21 Integer division routines

The LPC122x contain performance-optimized integer division routines with support for up to 32-bit width in the numerator and denominator. Routines for signed and unsigned division and division with remainder are available. The integer division routines are ROM-based to reduce code-size.

## 8. Limiting values

#### Table 5. Limiting values

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

| Symbol                 | Parameter                             | Conditions                                                            | Min              | Max         | Unit     |
|------------------------|---------------------------------------|-----------------------------------------------------------------------|------------------|-------------|----------|
| V <sub>DD(3V3)</sub>   | supply voltage (3.3 V)                |                                                                       | 3.0              | 3.6         | V        |
| V <sub>DD(IO)</sub>    | input/output supply voltage           |                                                                       | 3.0              | 3.6         | V        |
| VI                     | input voltage                         | on all digital pins                                                   | 2 -0.5           | +3.6        | V        |
|                        |                                       | on pins PIO0_10<br>and PIO0_11<br>(I <sup>2</sup> C-bus pins)         | <tbd></tbd>      | <tbd></tbd> | V        |
| I <sub>DD</sub>        | supply current                        | per supply pin                                                        | [3]              | 100         | mA       |
| I <sub>SS</sub>        | ground current                        | per ground pin                                                        | <u>[3]</u>       | 100         | mA       |
| I <sub>latch</sub>     | I/O latch-up current                  | –(0.5V <sub>DD</sub> ) < V <sub>I</sub> <<br>(1.5V <sub>DD</sub> );   | -                | 100         | mA       |
| <b>–</b>               |                                       | T <sub>j</sub> < 125 ℃                                                | [4] 05           | 450         | <b>^</b> |
| T <sub>stg</sub>       | storage temperature                   |                                                                       | <u>[4]</u> –65   | +150        | °C       |
| P <sub>tot(pack)</sub> | total power dissipation (per package) | based on package<br>heat transfer, not<br>device power<br>consumption | -                | 1.5         | W        |
| V <sub>ESD</sub>       | electrostatic discharge voltage       | human body<br>model; all pins                                         | <u>[5]</u> –8000 | +8000       | V        |

[1] The following applies to the limiting values:

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

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

[2] Including voltage on outputs in 3-state mode.

[3] The peak current is limited to 25 times the corresponding maximum current.

[4] Dependent on package type.

[5] Human body model: equivalent to discharging a 100 pF capacitor through a 1.5 k $\Omega$  series resistor.

## 9. Thermal characteristics

### 9.1 Thermal characteristics

The average chip junction temperature,  $T_j$  (°C), can be calculated using the following equation:

$$T_j = T_{amb} + (P_D \times R_{th(j-a)}) \tag{1}$$

- T<sub>amb</sub> = ambient temperature (°C),
- R<sub>th(j-a)</sub> = the package junction-to-ambient thermal resistance (°C/W)
- P<sub>D</sub> = sum of internal and I/O power dissipation

The internal power dissipation is the product of  $I_{DD}$  and  $V_{DD}$ . The I/O power dissipation of the I/O pins is often small and many times can be negligible. However it can be significant in some applications.

#### Table 6. Thermal characteristics

 $V_{DD}$  = 3.0 V to 3.6 V;  $T_{amb}$  = -40 °C to +85 °C unless otherwise specified.

| Symbol               | Parameter                                   | Conditions                       | Min | Тур | Мах | Unit |
|----------------------|---------------------------------------------|----------------------------------|-----|-----|-----|------|
| R <sub>th(j-a)</sub> | thermal resistance from junction to ambient | JEDEC test board; no<br>air flow | -   |     |     |      |
|                      |                                             | LQFP64 package                   |     | 61  | -   | °C/W |
|                      |                                             | LQFP48 package                   |     | 86  | -   | °C/W |
| R <sub>th(j-c)</sub> | thermal resistance from junction to case    | JEDEC test board                 | -   |     |     |      |
|                      |                                             | LQFP64 package                   |     | 19  | -   | °C/W |
|                      |                                             | LQFP48 package                   |     | 36  | -   | °C/W |
| T <sub>j(max)</sub>  | maximum junction<br>temperature             |                                  | -   | -   | 150 | °C   |

## **10. Static characteristics**

| Symbol               | Parameter                   | Conditions                                                                              |                  | Min             | Typ <mark>[1]</mark> | Max                 | Unit |
|----------------------|-----------------------------|-----------------------------------------------------------------------------------------|------------------|-----------------|----------------------|---------------------|------|
| V <sub>DD(IO)</sub>  | input/output supply voltage | on pin $V_{DD(IO)}$                                                                     |                  | 3.0             | 3.3                  | 3.6                 | V    |
| V <sub>DD(3V3)</sub> | supply voltage (3.3 V)      |                                                                                         |                  | 3.0             | 3.3                  | 3.6                 | V    |
| I <sub>DD</sub>      | supply current              | Active mode;<br>$V_{DD(3V3)} = 3.3 V;$<br>$T_{amb} = 25 °C; code$                       |                  |                 |                      |                     |      |
|                      |                             | while(1){}                                                                              |                  |                 |                      |                     |      |
|                      |                             | executed from flash                                                                     |                  |                 |                      |                     |      |
|                      |                             | all peripherals disabled:                                                               |                  |                 |                      |                     |      |
|                      |                             | CCLK = 12 MHz                                                                           |                  | -               | 3.1                  | -                   | mA   |
|                      |                             | CCLK = 24 MHz                                                                           |                  | -               | 5.6                  | -                   | mA   |
|                      |                             | CCLK = 33 MHz                                                                           |                  | -               | 8.1                  | -                   | mA   |
|                      |                             | all peripherals enabled:                                                                |                  |                 |                      |                     |      |
|                      |                             | CCLK = 12 MHz                                                                           |                  | -               | 5.3                  | -                   | mA   |
|                      |                             | CCLK = 24 MHz                                                                           |                  | -               | 9.5                  | -                   | mA   |
|                      |                             | CCLK = 33 MHz                                                                           |                  | -               | 13.7                 | -                   | mA   |
|                      |                             | Sleep mode;<br>$V_{DD(3V3)} = 3.3 V;$<br>$T_{amb} = 25 °C;$<br>all peripherals disabled |                  |                 |                      |                     |      |
|                      |                             | CCLK = 12 MHz                                                                           |                  | -               | 2.0                  | -                   | mA   |
|                      |                             | CCLK = 24 MHz                                                                           |                  | -               | 3.5                  | -                   | mA   |
|                      |                             | CCLK = 33 MHz                                                                           |                  | -               | 5.0                  | -                   | mA   |
|                      |                             | Deep-sleep mode;<br>$V_{DD(3V3)} = 3.3 V;$<br>$T_{amb} = 25 \ ^{\circ}C$                |                  | -               | 23.5                 | -                   | μA   |
|                      |                             | Deep power-down mode;<br>$V_{DD(3V3)} = 3.3 V;$<br>$T_{amb} = 25 \ ^{\circ}C$           |                  | -               | 680                  | -                   | nA   |
| Standard po          | ort pins, RESET             |                                                                                         |                  |                 |                      |                     |      |
| I <sub>IL</sub>      | LOW-level input<br>current  | $V_I = 0 V;$                                                                            |                  | -               | -                    | 1                   | μA   |
| I <sub>IH</sub>      | HIGH-level input<br>current | $V_{I} = V_{DD(IO)};$                                                                   |                  | -               | -                    | 1                   | μA   |
| I <sub>OZ</sub>      | OFF-state output<br>current | $V_O = 0 \ V; \ V_O = V_{DD(IO)};$                                                      |                  | -               | -                    | 1                   | μA   |
| VI                   | input voltage               | pin configured to provide a digital function                                            | <u>[2][3][4]</u> | 0               | -                    | V <sub>DD(IO)</sub> | V    |
| Vo                   | output voltage              | output active                                                                           |                  | 0               | -                    | V <sub>DD(IO)</sub> | V    |
| V <sub>IH</sub>      | HIGH-level input            |                                                                                         |                  | $0.7V_{DD(IO)}$ | -                    | -                   | V    |

#### Table 7. Static characteristics

LPC122X Objective data sheet

voltage

| Symbol                    | Parameter                                     | Conditions                                                |            | Min             | Typ <mark>[1]</mark> | Max                    | Unit |
|---------------------------|-----------------------------------------------|-----------------------------------------------------------|------------|-----------------|----------------------|------------------------|------|
| V <sub>IL</sub>           | LOW-level input voltage                       |                                                           |            | -               | -                    | $0.3V_{DD(IO)}$        | V    |
| V <sub>hys</sub>          | hysteresis voltage                            |                                                           |            | -               | 0.4                  | -                      | V    |
| V <sub>OH</sub>           | HIGH-level output voltage                     | $I_{OH} = -4 \text{ mA}$                                  |            | 2.4             | -                    | -                      | V    |
| V <sub>OL</sub>           | LOW-level output voltage                      | $I_{OL} = 4 \text{ mA}$                                   |            | -               | -                    | 0.4                    | V    |
| I <sub>OH</sub>           | HIGH-level output<br>current                  | V <sub>OH</sub> = 2.4 V<br>Normal-drive pins; low<br>mode | <u>[5]</u> | 3.9             | 7.8                  | 12.9                   | mA   |
|                           |                                               | Normal-drive pins; high mode                              | <u>[5]</u> | 7.7             | 15.6                 | 25.8                   | mA   |
|                           |                                               | High-drive pins; low mode                                 | <u>[6]</u> | 17.4            | 35.1                 | 58.1                   | mA   |
|                           |                                               | High-drive pins; high mode                                | <u>[6]</u> | 23.1            | 46.8                 | 77.5                   | mA   |
| I <sub>OL</sub>           | LOW-level output<br>current                   | V <sub>OL</sub> = 0.4 V<br>Normal-drive pins; low<br>mode | <u>[5]</u> | 3.4             | 5.4                  | 7.4                    | mA   |
|                           |                                               | Normal-drive pins; high mode                              | [5]        | 6.7             | 10.7                 | 14.7                   | mA   |
|                           |                                               | High-drive pins; low mode                                 | <u>[6]</u> | 13.4            | 21.5                 | 29.4                   | mA   |
|                           |                                               | High-drive pins; high mode                                | <u>[6]</u> | 20.1            | 32.2                 | 44.1                   | mA   |
| I <sub>OHS</sub>          | HIGH-level<br>short-circuit output<br>current | V <sub>OH</sub> = 0 V                                     | <u>[7]</u> | -               | -                    | -45                    | mA   |
| I <sub>OLS</sub>          | LOW-level<br>short-circuit output<br>current  | $V_{OL} = V_{DDA}$                                        | <u>[7]</u> | -               | -                    | 50                     | mA   |
| I <sub>pu</sub>           | pull-up current                               | $V_I = 0 V$                                               |            | -50             | -80                  | -100                   | μA   |
| l <sup>2</sup> C-bus pins | (PIO0_10 and PIO0_11)                         |                                                           |            |                 |                      |                        |      |
| V <sub>IH</sub>           | HIGH-level input voltage                      |                                                           |            | $0.7V_{DD(IO)}$ | -                    | -                      | V    |
| V <sub>IL</sub>           | LOW-level input<br>voltage                    |                                                           |            | -               | -                    | $0.3V_{\text{DD(IO)}}$ | V    |
| V <sub>hys</sub>          | hysteresis voltage                            |                                                           |            | -               | $0.05V_{DD(IO)}$     | -                      | V    |
| V <sub>OL</sub>           | LOW-level output voltage                      | I <sub>OLS</sub> = 20 mA                                  |            | -               | -                    | 0.4                    | V    |
| I <sub>LI</sub>           | input leakage current                         | $V_{I} = V_{DD(IO)}$                                      | <u>[8]</u> | -               | 2                    | 4                      | μΑ   |
|                           |                                               | V <sub>I</sub> = 5 V                                      |            | -               | 10                   | 22                     | μA   |
| Ci                        | capacitance for each<br>I/O pin               | on pins PIO0_10 and PIO0_11                               |            | -               | -                    | 8                      | pF   |

#### Table 7. Static characteristics ...continued

| $T_{amb} = -40 \text{ °C to } +85 \text{ °C}$ , unless otherwise specified. |                     |            |     |                      |      |      |  |  |
|-----------------------------------------------------------------------------|---------------------|------------|-----|----------------------|------|------|--|--|
| Symbol                                                                      | Parameter           | Conditions | Min | Typ <mark>[1]</mark> | Max  | Unit |  |  |
| Oscillator pi                                                               | ns                  |            |     |                      |      |      |  |  |
| V <sub>i(xtal)</sub>                                                        | crystal input volta | ge         | 0   | 1.8                  | 1.95 | V    |  |  |
| V <sub>o(xtal)</sub>                                                        | crystal output volt | age        | 0   | 1.8                  | 1.95 | V    |  |  |

#### Table 7. Static characteristics ... continued

| [1] | Typical ratings are not guaranteed. | The values listed are at room temperature (25 °C), nominal supply voltages. |
|-----|-------------------------------------|-----------------------------------------------------------------------------|
|-----|-------------------------------------|-----------------------------------------------------------------------------|

[2] Including voltage on outputs in 3-state mode.

[3]  $V_{DD(3V3)}$  and  $V_{DD(IO)}$  supply voltages must be present.

[4] 3-state outputs go into 3-state mode when  $V_{\text{DD}(\text{IO})}$  is grounded.

[5] Normal-drive output mode applies to all GPIO pins except pins PIO0\_12, PIO0\_27, PIO0\_28, PIO0\_29.

[6] High-drive output mode available on pins PIO0\_12, PIO0\_27, PIO0\_28, PIO0\_29.

[7] Allowed as long as the current limit does not exceed the maximum current allowed by the device.

[8] To V<sub>SS</sub>.

### **10.1** Peripheral power consumption

The supply current per peripheral is measured as the difference in supply current between the peripheral block enabled and the peripheral block disabled in the SYSAHBCLKCFG and PDRUNCFG (for analog blocks) registers. All other blocks are disabled in both registers and no code is executed. Measured on a typical sample at  $T_{amb} = 25$  °C. Unless noted otherwise, the system oscillator and PLL are running in both measurements.

The supply currents are shown for system clock frequencies of <tbd>.

| Peripheral Typica mA             |             | I supply current in |             | Notes       |
|----------------------------------|-------------|---------------------|-------------|-------------|
|                                  | n/a         | 12 MHz              | <tbd></tbd> |             |
| IRC                              | <tbd></tbd> | -                   | -           | <tbd></tbd> |
| System oscillator at 12 MHz      | <tbd></tbd> | -                   | -           | <tbd></tbd> |
| Watchdog oscillator at 500 kHz/2 | <tbd></tbd> | -                   | -           | <tbd></tbd> |
| BOD                              | <tbd></tbd> | -                   | -           | <tbd></tbd> |
| Main PLL                         | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| CRC                              | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| 16-bit timer 0 (CT16B0)          | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| 16-bit timer 1 (CT16B1)          | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| 32-bit timer 0 (CT32B0)          | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| 32-bit timer 1 (CT32B1)          | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| SSP/SPI                          | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| UART0                            | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| UART1                            | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| ADC                              | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| WWDT                             | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| DMA                              | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| RTC                              | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| Comparator                       | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |
| SysTick timer                    | -           | <tbd></tbd>         | <tbd></tbd> | <tbd></tbd> |

| Table 8. | Power  | consumpt | ion fo | r individual | analog | and did | gital blocks |
|----------|--------|----------|--------|--------------|--------|---------|--------------|
|          | I OWCI | consumpt |        | i murruuai   | analog | and un  |              |

## **10.2** Power consumption

Power measurements in Active, Sleep, and Deep-sleep modes were performed under the following conditions (see *LPC122x user manual*):

- <tbd>
- <tbd>

#### 32-bit ARM Cortex-M0 microcontroller





Fig 7. Active mode: Typical supply current I<sub>DD</sub> versus temperature for different system clock frequencies (peripherals disabled)

#### 32-bit ARM Cortex-M0 microcontroller





### 32-bit ARM Cortex-M0 microcontroller





Dbjective data sheet

### 32-bit ARM Cortex-M0 microcontroller



### **10.3 Electrical pin characteristics**



### 32-bit ARM Cortex-M0 microcontroller





Fig 15. Typical HIGH-level output voltage V<sub>OH</sub> versus HIGH-level output source current I<sub>OH</sub>

### 32-bit ARM Cortex-M0 microcontroller



### **10.4 ADC characteristics**

#### Table 9. ADC static characteristics

 $T_{amb} = -40$  °C to +85 °C unless otherwise specified; ADC frequency 9 MHz,  $V_{DD(3V3)} = 3.0$  V to 3.6 V.

| Symbol              | Parameter                    | Conditions |                  | Min | Typ <mark>[1]</mark> | Max                  | Unit |
|---------------------|------------------------------|------------|------------------|-----|----------------------|----------------------|------|
| VIA                 | analog input voltage         |            |                  | 0   | -                    | V <sub>DD(3V3)</sub> | V    |
| C <sub>ia</sub>     | analog input capacitance     |            |                  | -   | -                    | 1                    | pF   |
| ED                  | differential linearity error |            | <u>[2][3][4]</u> | -   | -                    | ± 1                  | LSB  |
| E <sub>L(adj)</sub> | integral non-linearity       |            | <u>[2][5]</u>    | -   | -                    | $\pm2.5$             | LSB  |
| Eo                  | offset error                 |            | [2][6]           | -   | -                    | ± 1                  | LSB  |
| E <sub>G</sub>      | gain error                   |            | [2][7]           | -   | -                    | $\pm 3$              | LSB  |
| ET                  | absolute error               |            | [2][8]           | -   | -                    | $\pm 3$              | LSB  |
| $f_{c(ADC)}$        | ADC conversion frequency     |            |                  | -   | -                    | 257                  | kHz  |

[1] Typical ratings are not guaranteed. The values listed are at room temperature (25 °C), nominal supply voltages.

- [2] Conditions:  $V_{SS} = 0 V$ ,  $V_{DD(3V3)} = 3.3 V$ .
- [3] The ADC is monotonic, there are no missing codes.
- [4] The differential linearity error ( $E_D$ ) is the difference between the actual step width and the ideal step width. See Figure 17.
- [5] The integral non-linearity (E<sub>L(adj)</sub>) is the peak difference between the center of the steps of the actual and the ideal transfer curve after appropriate adjustment of gain and offset errors. See Figure 17.
- [6] The offset error ( $E_0$ ) is the absolute difference between the straight line which fits the actual curve and the straight line which fits the ideal curve. See Figure 17.
- [7] The gain error (E<sub>G</sub>) is the relative difference in percent between the straight line fitting the actual transfer curve after removing offset error, and the straight line which fits the ideal transfer curve. See Figure 17.
- [8] The absolute error (E<sub>T</sub>) is the maximum difference between the center of the steps of the actual transfer curve of the non-calibrated ADC and the ideal transfer curve. See Figure 17.

### 32-bit ARM Cortex-M0 microcontroller

**LPC122x** 



### 10.5 BOD static characteristics

### Table 10. BOD static characteristics<sup>[1]</sup>

| Symbol          | Parameter         | Conditions        | Min | Тур  | Мах | Unit |
|-----------------|-------------------|-------------------|-----|------|-----|------|
| V <sub>th</sub> | threshold voltage | interrupt level 1 |     |      |     |      |
|                 |                   | assertion         | -   | 2.25 | -   | V    |
|                 |                   | de-assertion      | -   | 2.39 | -   | V    |
|                 |                   | interrupt level 2 |     |      |     |      |
|                 |                   | assertion         | -   | 2.54 | -   | V    |
|                 |                   | de-assertion      | -   | 2.67 | -   | V    |
|                 |                   | interrupt level 3 |     |      |     |      |
|                 |                   | assertion         | -   | 2.83 | -   | V    |
|                 |                   | de-assertion      | -   | 2.93 | -   | V    |
|                 |                   | reset level 1     |     |      |     |      |
|                 |                   | assertion         | -   | 2.04 | -   | V    |
|                 |                   | de-assertion      | -   | 2.18 | -   | V    |
|                 |                   | reset level 2     |     |      |     |      |
|                 |                   | assertion         | -   | 2.34 | -   | V    |
|                 |                   | de-assertion      | -   | 2.47 | -   | V    |
|                 |                   | reset level 3     |     |      |     |      |
|                 |                   | assertion         | -   | 2.62 | -   | V    |
|                 |                   | de-assertion      | -   | 2.76 | -   | V    |

[1] Interrupt levels are selected by writing the level value to the BOD control register BODCTRL, see *LPC122x* user manual.

### **11. Dynamic characteristics**

### 11.1 Flash memory

### Table 11. Dynamic characteristic: flash memory

 $T_{amb} = -40 \ ^{\circ}C$  to +85  $^{\circ}C$ ;  $V_{DD(3V3)}$  over specified ranges.

| Symbol            | Parameter      | Conditions                      | Min          | Max | Unit   |
|-------------------|----------------|---------------------------------|--------------|-----|--------|
| t <sub>er</sub>   | erase time     | for one page (512 byte)         | <u>[1]</u> - | 20  | ms     |
|                   |                | for one sector (4 kB)           | <u>[1]</u>   | 162 | ms     |
|                   |                | for all sectors; mass erase     | <u>[1]</u> - | 20  | ms     |
| t <sub>prog</sub> | programming    | one word (4 bytes)              | <u>[1]</u> - | 49  | μS     |
|                   | time           | four sequential words           | <u>[1]</u> - | 194 | μS     |
|                   |                | 128 bytes (one row of 32 words) | <u>[1]</u> - | 765 | μS     |
| N <sub>endu</sub> | endurance      |                                 | 20000        | -   | cycles |
| t <sub>ret</sub>  | retention time |                                 | 10           | -   | years  |

[1] Erase and programming times are valid over the lifetime of the device (minimum 20000 cycles).

[2] Number of program/erase cycles.

### 11.2 External clock

#### Table 12. Dynamic characteristic: external clock

 $T_{amb} = -40 \ ^{\circ}C$  to +85  $^{\circ}C$ ;  $V_{DD(3V3)}$  over specified ranges.<sup>[1]</sup>

| Symbol               | Parameter            | Conditions | Min                      | Typ <mark>[2]</mark> | Max  | Unit |
|----------------------|----------------------|------------|--------------------------|----------------------|------|------|
| f <sub>osc</sub>     | oscillator frequency |            | 1                        | -                    | 25   | MHz  |
| T <sub>cy(clk)</sub> | clock cycle time     |            | 40                       | -                    | 1000 | ns   |
| t <sub>CHCX</sub>    | clock HIGH time      |            | $T_{cy(clk)}\times 0.4$  | -                    | -    | ns   |
| t <sub>CLCX</sub>    | clock LOW time       |            | $T_{cy(clk)} \times 0.4$ | -                    | -    | ns   |
| t <sub>CLCH</sub>    | clock rise time      |            | -                        | -                    | 5    | ns   |
| t <sub>CHCL</sub>    | clock fall time      |            | -                        | -                    | 5    | ns   |

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

[2] Typical ratings are not guaranteed. The values listed are at room temperature (25 °C), nominal supply voltages.



### 11.3 Internal oscillators

#### Table 13. Dynamic characteristic: internal oscillators

| $I_{amb} = -40$ | 0 °C to +85 °C; V <sub>DD(3V3)</sub> over speci | fied ranges. |       |                      |       |      |
|-----------------|-------------------------------------------------|--------------|-------|----------------------|-------|------|
| Symbol          | Parameter                                       | Conditions   | Min   | Typ <mark>[2]</mark> | Max   | Unit |
| $f_{osc(RC)}$   | internal RC oscillator frequency                | -            | 11.88 | 12                   | 12.12 | MHz  |

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

[2] Typical ratings are not guaranteed. The values listed are at nominal supply voltages.



#### Table 14. Dynamic characteristics: Watchdog oscillator

| Symbol    | Parameter                        | Conditions                                                  |               | Min | Typ <mark>[1]</mark> | Мах | Unit |
|-----------|----------------------------------|-------------------------------------------------------------|---------------|-----|----------------------|-----|------|
| fosc(int) | internal oscillator<br>frequency | DIVSEL = 0x1F, FREQSEL = 0x1<br>in the WDTOSCCTRL register; | <u>[2][3]</u> | -   | 7.8                  | -   | kHz  |
|           |                                  | DIVSEL = 0x00, FREQSEL = 0xF<br>in the WDTOSCCTRL register  | [2][3]        | -   | 1700                 | -   | kHz  |

 Typical ratings are not guaranteed. The values listed are at room temperature (25 °C), nominal supply voltages.

[2] The typical frequency spread over processing and temperature (T<sub>amb</sub> =  $-40 \degree C$  to +85  $\degree C$ ) is ±40 %.

[3] See the LPC122x user manual.

### 11.4 I<sup>2</sup>C-bus

| Table 15.       | Dynamic  | characteristic: | I <sup>2</sup> C-bus | pins |
|-----------------|----------|-----------------|----------------------|------|
| $T_{amb} = -40$ | ℃ to +85 | °C.[1]          |                      |      |

| Symbol           | Parameter                       | Conditions     | Min | Max | Unit |
|------------------|---------------------------------|----------------|-----|-----|------|
| f <sub>SCL</sub> | SCL clock frequency Standard-mc |                | 0   | 100 | kHz  |
|                  |                                 | Fast-mode      | 0   | 400 | kHz  |
|                  |                                 | Fast-mode Plus | 0   | 1   | MHz  |

32-bit ARM Cortex-M0 microcontroller

| Symbol              | Parameter                    |                     | Conditions                  | Min                            | Max | Unit |
|---------------------|------------------------------|---------------------|-----------------------------|--------------------------------|-----|------|
| t <sub>f</sub>      | fall time                    | <u>[3][4][5][6]</u> | of both SDA and SCL signals | -                              | 300 | ns   |
|                     |                              |                     | Standard-mode               |                                |     |      |
|                     |                              |                     | Fast-mode                   | $20 \textbf{+} 0.1 \times C_b$ | 300 | ns   |
|                     |                              |                     | Fast-mode Plus              | -                              | 120 | ns   |
| t <sub>LOW</sub>    | LOW period of the SCL clock  |                     | Standard-mode               | 4.7                            | -   | μS   |
|                     |                              |                     | Fast-mode                   | 1.3                            | -   | μS   |
|                     |                              |                     | Fast-mode Plus              | 0.5                            | -   | μS   |
| t <sub>HIGH</sub>   | HIGH period of the SCL clock |                     | Standard-mode               | 4.0                            | -   | μS   |
|                     |                              |                     | Fast-mode                   | 0.6                            | -   | μS   |
|                     |                              |                     | Fast-mode Plus              | 0.26                           | -   | μs   |
| t <sub>HD;DAT</sub> | data hold time               | [2][3][7]           | Standard-mode               | 0                              | -   | μs   |
|                     |                              |                     | Fast-mode                   | 0                              | -   | μS   |
|                     |                              |                     | Fast-mode Plus              | 0                              | -   | μS   |
| t <sub>SU;DAT</sub> | data set-up time             | <u>[8][9]</u>       | Standard-mode               | 250                            | -   | ns   |
|                     |                              |                     | Fast-mode                   | 100                            | -   | ns   |
|                     |                              |                     | Fast-mode Plus              | 50                             | -   | ns   |

#### 

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

[2] tHD;DAT is the data hold time that is measured from the falling edge of SCL; applies to data in transmission and the acknowledge.

[3] A device must internally provide a hold time of at least 300 ns for the SDA signal (with respect to the V<sub>IH</sub>(min) of the SCL signal) to bridge the undefined region of the falling edge of SCL.

[4] C<sub>b</sub> = total capacitance of one bus line in pF. If mixed with Hs-mode devices, faster fall times are allowed.

- [5] The maximum t<sub>f</sub> for the SDA and SCL bus lines is specified at 300 ns. The maximum fall time for the SDA output stage t<sub>f</sub> is specified at 250 ns. This allows series protection resistors to be connected in between the SDA and the SCL pins and the SDA/SCL bus lines without exceeding the maximum specified t<sub>f</sub>.
- [6] In Fast-mode Plus, fall time is specified the same for both output stage and bus timing. If series resistors are used, designers should allow for this when considering bus timing.
- [7] The maximum t<sub>HD;DAT</sub> could be 3.45 μs and 0.9 μs for Standard-mode and Fast-mode but must be less than the maximum of t<sub>VD;DAT</sub> or t<sub>VD;ACK</sub> by a transition time. This maximum must only be met if the device does not stretch the LOW period (t<sub>LOW</sub>) of the SCL signal. If the clock stretches the SCL, the data must be valid by the set-up time before it releases the clock.
- [8] tsu; DAT is the data set-up time that is measured with respect to the rising edge of SCL; applies to data in transmission and the acknowledge.
- [9] A Fast-mode l<sup>2</sup>C-bus device can be used in a Standard-mode l<sup>2</sup>C-bus system but the requirement  $t_{SU;DAT}$  = 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line  $t_{r(max)} + t_{SU;DAT} = 1000 + 250 = 1250$  ns (according to the Standard-mode l<sup>2</sup>C-bus specification) before the SCL line is released. Also the acknowledge timing must meet this set-up time.

### 32-bit ARM Cortex-M0 microcontroller

LPC122x



### 11.5 SSP/SPI interface

### Table 16. Dynamic characteristics: SSP pins in SPI mode

| Symbol               | Parameter              | Conditions                |               | Min                         | Max                          | Unit |
|----------------------|------------------------|---------------------------|---------------|-----------------------------|------------------------------|------|
| T <sub>cy(clk)</sub> | clock cycle time       | when only<br>transmitting | <u>[1]</u>    | <tbd></tbd>                 | -                            | ns   |
|                      |                        | when only receiving       |               | <tbd></tbd>                 | -                            |      |
| SSP master           |                        |                           |               |                             |                              |      |
| t <sub>DS</sub>      | data set-up time       | in SPI mode               | [2]           | 15                          | -                            | ns   |
| t <sub>DH</sub>      | data hold time         | in SPI mode               | [2]           | 0                           | -                            | ns   |
| t <sub>v(Q)</sub>    | data output valid time | in SPI mode               | [2]           | -                           | 10                           | ns   |
| t <sub>h(Q)</sub>    | data output hold time  | in SPI mode               | [2]           | 0                           | -                            | ns   |
| SSP slave            |                        |                           |               |                             |                              |      |
| t <sub>DS</sub>      | data set-up time       | in SPI mode               | <u>[3][4]</u> | 0                           | -                            | ns   |
| t <sub>DH</sub>      | data hold time         | in SPI mode               | <u>[3][4]</u> | $3 \times T_{cy(PCLK)}$ + 4 | -                            | ns   |
| t <sub>v(Q)</sub>    | data output valid time | in SPI mode               | <u>[3][4]</u> | -                           | $3 \times T_{cy(PCLK)}$ + 11 | ns   |
| t <sub>h(Q)</sub>    | data output hold time  | in SPI mode               | [3][4]        | -                           | $2 \times T_{cy(PCLK)} + 5$  | ns   |

[1] T<sub>cy(clk)</sub> = (SSPCLKDIV × (1 + SCR) × CPSDVSR) / f<sub>main</sub>. The clock cycle time derived from the SPI bit rate T<sub>cy(clk)</sub> is a function of the main clock frequency f<sub>main</sub>, the SSP peripheral clock divider (SSPCLKDIV), the SSP SCR parameter (specified in the SSP0CR0 register), and the SSP CPSDVSR parameter (specified in the SSP clock prescale register).

 $[3] \quad T_{cy(clk)} = 12 \times T_{cy(PCLK)}.$ 

[4]  $T_{amb} = 25 \text{ °C}; V_{DD(3V3)} = 3.3 \text{ V}; V_{DD(IO)} = 3.3 \text{ V}.$ 

## LPC122x

### 32-bit ARM Cortex-M0 microcontroller



## LPC122x

### 32-bit ARM Cortex-M0 microcontroller



### **12.** Application information

### 12.1 XTAL input

The input voltage to the on-chip oscillators is limited to 1.8 V. If the oscillator is driven by a clock in slave mode, it is recommended that the input be coupled through a capacitor with  $C_i = 100 \text{ pF}$ . To limit the input voltage to the specified range, choose an additional capacitor to ground  $C_g$  which attenuates the input voltage by a factor  $C_i/(C_i + C_g)$ . In slave mode, a minimum of 200 mV(RMS) is needed.



### 12.2 XTAL Printed Circuit Board (PCB) layout guidelines

The crystal should be connected on the PCB as close as possible to the oscillator input and output pins of the chip. Take care that the load capacitors  $C_{x1}$ ,  $C_{x2}$ , and  $C_{x3}$  in case of third overtone crystal usage have a common ground plane. The external components must also be connected to the ground plain. Loops must be made as small as possible in order to keep the noise coupled in via the PCB as small as possible. Also parasitics should stay as small as possible. Values of  $C_{x1}$  and  $C_{x2}$  should be chosen smaller accordingly to the increase in parasitics of the PCB layout.

### 12.3 ElectroMagnetic Compatibility (EMC)

Radiated emission measurements according to the IEC61967-2 standard using the TEM-cell method are shown for the LPC1227FBD64/301 in Table 17.

## Table 17. ElectroMagnetic Compatibility (EMC) for part LPC1227FBD64/301 (TEM-cell method)

 $V_{DD} = 3.3 V$ ;  $T_{amb} = 25$ °C.

| Parameter                | Frequency band         | System clock | System clock = |             |      |
|--------------------------|------------------------|--------------|----------------|-------------|------|
|                          |                        | 12 MHz       | 24 MHz         | 33 MHz      |      |
| Input clock:             | IRC (12 MHz)           |              |                |             |      |
| maximum<br>peak level    | 150 kHz - 30 MHz       | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
|                          | 30 MHz - 150 MHz       | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
|                          | 150 MHz - 1 GHz        | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
| IEC level <sup>[1]</sup> | -                      | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | -    |
| Input clock:             | crystal oscillator (12 | MHz)         |                |             |      |
| maximum<br>peak level    | 150 kHz - 30 MHz       | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
|                          | 30 MHz - 150 MHz       | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
|                          | 150 MHz - 1 GHz        | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | dBμV |
| IEC level <sup>[1]</sup> | -                      | <tbd></tbd>  | <tbd></tbd>    | <tbd></tbd> | -    |
|                          |                        |              |                |             |      |

[1] IEC levels refer to Appendix D in the IEC61967-2 Specification.

## LPC122x

32-bit ARM Cortex-M0 microcontroller

### 13. Package outline



### Fig 24. Package outline SOT314-2 (LQFP64)

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

LPC122X



Fig 25. Package outline SOT313-2 (LQFP48)

LPC122X

### 14. Abbreviations

| Table 18. | Abbreviations                                                  |
|-----------|----------------------------------------------------------------|
| Acronym   | Description                                                    |
| ADC       | Analog-to-Digital-Converter                                    |
| AHB       | Advanced High-performance Bus                                  |
| APB       | Advanced Peripheral Bus                                        |
| BOD       | BrownOut Detection                                             |
| CCITT     | Comité Consultatif International Téléphonique et Télégraphique |
| CRC       | Cyclic Redundancy Check                                        |
| DMA       | Direct Memory Access                                           |
| FIFO      | First-In-First-Out                                             |
| GPIO      | General Purpose Input/Output                                   |
| I/O       | Input/Output                                                   |
| IrDA      | Infrared Data Association                                      |
| IRC       | Internal Resistor-Capacitor                                    |
| JEDEC     | Joint Electron Devices Engineering Council                     |
| PLL       | Phase-Locked Loop                                              |
| SPI       | Serial Peripheral Interface                                    |
| SSI       | Serial Synchronous Interface                                   |
| SSP       | Synchronous Serial Port                                        |
| UART      | Universal Asynchronous Receiver/Transmitter                    |

## **15. Revision history**

| Table 19. Revision histor                                        | y                                |                             |               |             |
|------------------------------------------------------------------|----------------------------------|-----------------------------|---------------|-------------|
| Document ID                                                      | Release date                     | Data sheet status           | Change notice | Supersedes  |
| LPC122X v.1.1                                                    | 20110221                         | Objective data sheet        | -             | LPC122X v.1 |
| Modifications:  • Section 1 "General description": Updated text. |                                  |                             |               |             |
|                                                                  | <ul> <li>Section 2 "F</li> </ul> | Features and benefits": Upd | lated text.   |             |
| LPC122X v.1                                                      | 20110214                         | Objective data sheet        | -             | -           |

### **16. Legal information**

### 16.1 Data sheet status

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

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

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

[3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL <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.

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 accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

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

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.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from national authorities.

LPC122X

### 32-bit ARM Cortex-M0 microcontroller

**Non-automotive qualified products** — Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's

### 17. Contact information

own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

### 16.4 Trademarks

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

I<sup>2</sup>C-bus — logo is a trademark of NXP B.V.

#### For more information, please visit: <u>http://www.nxp.com</u>

For sales office addresses, please send an email to: salesaddresses@nxp.com

### 32-bit ARM Cortex-M0 microcontroller

### **18. Contents**

| 1        | General description 1                            | I        |
|----------|--------------------------------------------------|----------|
| 2        | Features and benefits 1                          |          |
| 3        | Applications 3                                   | 3        |
| 4        | Ordering information 4                           | ł        |
| 4.1      | Ordering options 4                               | ł        |
| 5        | Block diagram 5                                  | ;        |
| 6        | Pinning information                              | 5        |
| 6.1      | Pinning                                          | 3        |
| 6.2      | Pin description                                  | }        |
| 7        | Functional description 16                        |          |
| 7.1      | ARM Cortex-M0 processor                          |          |
| 7.1.1    | System tick timer 16                             | 3        |
| 7.2      | On-chip flash program memory 16                  | 5        |
| 7.3      | On-chip SRAM                                     | 3        |
| 7.4      | Memory map                                       | 3        |
| 7.5      | Nested Vectored Interrupt Controller (NVIC) . 17 | ,        |
| 7.5.1    | Features                                         | ,        |
| 7.5.2    | Interrupt sources                                | }        |
| 7.6      | IOCONFIG block 18                                | }        |
| 7.6.1    | Features                                         | }        |
| 7.7      | Micro DMA controller 18                          | }        |
| 7.7.1    | Features                                         | 3        |
| 7.8      | CRC engine 19                                    | )        |
| 7.8.1    | Features                                         | )        |
| 7.9      | Fast general purpose parallel I/O 19             | ,        |
| 7.9.1    | Features                                         |          |
| 7.10     | UARTs 19                                         | ,        |
| 7.10.1   | Features                                         | )        |
| 7.11     | SSP/SPI serial I/O controller 20                 | )        |
| 7.11.1   | Features                                         |          |
| 7.12     | I <sup>2</sup> C-bus serial I/O controller 20    |          |
| 7.12.1   | Features                                         |          |
| 7.13     | 10-bit ADC 21                                    |          |
| 7.13.1   | Features                                         |          |
| 7.14     | Comparator block 21                              |          |
| 7.14.1   | Features 21                                      |          |
| 7.15     | General purpose external event counter/timers 22 |          |
| 7.15.1   | Features                                         | <u>}</u> |
| 7.16     | Windowed WatchDog timer (WWDT) 22                | 2        |
| 7.16.1   | Features                                         | <u>)</u> |
| 7.17     | Real-time clock (RTC) 23                         | \$       |
| 7.17.1   | Features                                         |          |
| 7.18     | Clocking and power control 23                    |          |
| 7.18.1   | Crystal oscillators 23                           |          |
| 7.18.1.1 |                                                  |          |
| 7.18.1.2 | 2 System oscillator 24                           | ł        |

| 7.18.1.3       | Watchdog oscillator                        | 25       |
|----------------|--------------------------------------------|----------|
| 7.18.2         | System PLL                                 | 25       |
| 7.18.3         | Clock output                               | 25       |
| 7.18.4         | Wake-up process                            | 25       |
| 7.18.5         | Power control                              | 25       |
| 7.18.5.1       |                                            | 25       |
| 7.18.5.2       |                                            | 26       |
| 7.18.5.3       |                                            | 26       |
| 7.19<br>7.19.1 | System control                             | 26<br>26 |
| 7.19.1         | Start logic                                | 20<br>26 |
| 7.19.2         | Brownout detection                         | 20       |
| 7.19.4         | Code security (Code Read Protection - CRP) | 27       |
| 7.19.5         | APB interface                              | 27       |
| 7.19.6         | AHB-Lite                                   | 27       |
| 7.19.7         | External interrupt inputs                  | 27       |
| 7.20           | Emulation and debugging                    | 28       |
| 7.21           | Integer division routines                  | 28       |
| 8              | Limiting values                            | 29       |
| 9              | Thermal characteristics                    | 30       |
| 9.1            | Thermal characteristics                    | 30       |
| 10             | Static characteristics                     | 31       |
| 10.1           | Peripheral power consumption               | 34       |
| 10.2           | Power consumption                          | 34       |
| 10.3           | Electrical pin characteristics             | 38       |
| 10.4           | ADC characteristics                        | 41       |
| 10.5           | BOD static characteristics                 | 43       |
| 11             | Dynamic characteristics                    | 44       |
| 11.1           | Flash memory                               | 44       |
| 11.2           | External clock                             | 44       |
| 11.3           | Internal oscillators                       | 45       |
| 11.4           | I <sup>2</sup> C-bus                       | 45       |
| 11.5           | SSP/SPI interface                          | 48       |
| 12             | Application information                    | 51       |
| 12.1           | XTAL input                                 | 51       |
| 12.2           | XTAL Printed Circuit Board (PCB) layout    |          |
|                | guidelines                                 | 51       |
| 12.3           | ElectroMagnetic Compatibility (EMC)        | 52       |
| 13             | Package outline                            | 53       |
| 14             | Abbreviations                              | 55       |
| 15             | Revision history                           | 56       |
| 16             | Legal information                          | 57       |
| 16.1           | Data sheet status                          | 57       |
| 16.2           | Definitions                                | 57       |
| 16.3           | Disclaimers                                | 57       |
| 16.4           | Trademarks                                 | 58       |
|                |                                            |          |

### continued >>

## LPC122x

32-bit ARM Cortex-M0 microcontroller

| 17 | Contact information | 58 |
|----|---------------------|----|
| 18 | Contents            | 59 |

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

© NXP B.V. 2011.

All rights reserved.

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

Date of release: 21 February 2011 Document identifier: LPC122X

## **X-ON Electronics**

Largest Supplier of Electrical and Electronic Components

Click to view similar products for Microprocessors - MPU category:

Click to view products by NXP manufacturer:

Other Similar products are found below :

MC68302EH20C MC7457RX1000LC MC7457RX1267LC MC7457VG1267LC A2C00010998 A A2C52004004 R5F117BCGNA#20 R5F52106BDLA#U0 ADJ3400IAA5DOE MPC8245TVV266D MPC8245TZU300D MPC8260ACVVMHBB MPC8323ECVRAFDCA MPC8536ECVJAVLA BOXNUC5PGYH0AJ 20-668-0024 P1010NSN5DFB P2010NSN2MHC P2020NXE2HHC P5020NSE7QMB P5020NSE7TNB P5020NSE7VNB LS1020ASN7KQB LS1020AXN7HNB LS1020AXN7KQB A2C00010729 A A2C00039344 T1022NSE7MQB T1022NXN7PQB T1023NSE7MQA T1024NXE7PQA T1042NSE7MQB T1042NSN7MQB T1042NXN7WQB T2080NSE8TTB T2080NSN8PTB T2080NXE8TTB T2081NXN8TTB R5F101AFASP#V0 MC68302CEH20C MPC8260ACVVMIBB MPC8280CZUUPEA MPC8313ECVRAFFC MPC8313ECVRAGDC MPC8313EVRADDC MPC8313EVRAFFC MPC8313VRADDC MPC8314CVRAGDA MPC8314VRAGDA MPC8315VRAGDA