# mail

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





## LPC83x

32-bit ARM<sup>®</sup> Cortex<sup>®</sup>-M0+ microcontroller; up to 32 KB flash and 4 KB SRAM; 12-bit ADC

Rev. 1.2 — 4 April 2018

**Product data sheet** 

## 1. General description

The LPC83x are an ARM Cortex-M0+ based, low-cost 32-bit MCU family operating at CPU frequencies of up to 30 MHz. The LPC83x support up to 32 KB of flash memory and 4 KB of SRAM.

The peripheral complement of the LPC83x includes a CRC engine, one I<sup>2</sup>C-bus interface, one USART, up to two SPI interfaces, one multi-rate timer, self-wake-up timer, and SCTimer/PWM, a DMA, one 12-bit ADC, function-configurable I/O ports through a switch matrix, an input pattern match engine, and up to 29 general-purpose I/O pins.

For additional documentation related to the LPC83x parts, see Section 18.

## 2. Features and benefits

- System:
  - ARM Cortex-M0+ processor (revision r0p1), running at frequencies of up to 30 MHz with single-cycle multiplier and fast single-cycle I/O port.
  - ARM Cortex-M0+ built-in Nested Vectored Interrupt Controller (NVIC).
  - System tick timer.
  - AHB multilayer matrix.
  - Serial Wire Debug (SWD) with four break points and two watch points. JTAG boundary scan (BSDL) supported.
  - Macro Trace Buffer (MTB).
- Memory:
  - Up to 32 KB on-chip flash programming memory with 64 Byte page write and erase. Code Read Protection (CRP) supported.
  - 4 KB SRAM.
- ROM API support:
  - Boot loader.
  - ◆ Flash In-Application Programming (IAP) and In-System Programming (ISP).
- Digital peripherals:
  - High-speed GPIO interface connected to the ARM Cortex-M0+ IO bus with up to 29 General-Purpose I/O (GPIO) pins with configurable pull-up/pull-down resistors, programmable open-drain mode, input inverter, and digital filter. GPIO direction control supports independent set/clear/toggle of individual bits.
  - High-current source output driver (20 mA) on four pins.
  - High-current sink driver (20 mA) on two true open-drain pins.



PC83x

- GPIO interrupt generation capability with boolean pattern-matching feature on eight GPIO inputs.
- Switch matrix for flexible configuration of each I/O pin function.
- CRC engine.
- DMA with 18 channels and 8 trigger inputs.
- Timers:
  - SCTimer/PWM with up to 4 capture inputs and 4 match output functions for timing and PWM applications.
  - Four channel Multi-Rate Timer (MRT) for repetitive interrupt generation at up to four programmable, fixed rates.
  - Self-Wake-up Timer (WKT) clocked from either the IRC, a low-power, low-frequency internal oscillator, or an external clock input in the always-on power domain.
  - Windowed Watchdog timer (WWDT).
- Analog peripherals:
  - One 12-bit ADC with up to 12 input channels with multiple internal and external trigger inputs and with sample rates of up to 1.2 Msamples/s. The ADC supports two independent conversion sequences.
- Serial peripherals:
  - One USART interface with pin functions assigned through the switch matrix and one fractional baud rate generator.
  - Two SPI controllers with pin functions assigned through the switch matrix.
  - One I<sup>2</sup>C-bus interface. Supports Fast-mode Plus with 1 Mbit/s data rates on the open-drain pins and listen mode.
- Clock generation:
  - 12 MHz internal RC oscillator trimmed to 1.5 % accuracy that can optionally be used as a system clock.
  - Crystal oscillator with an operating range of 1 MHz to 25 MHz.
  - Programmable watchdog oscillator with a frequency range of 9.4 kHz to 2.3 MHz.
  - 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, the external clock input, or the internal RC oscillator.
  - Clock output function with divider that can reflect all internal clock sources.
- Power control:
  - Power consumption in active mode as low as 90 uA/MHz in low-current mode using the IRC as the clock source.
  - Integrated PMU (Power Management Unit) to minimize power consumption.
  - Reduced power modes: Sleep mode, Deep-sleep mode, Power-down mode, and Deep power-down mode.
  - Wake-up from Deep-sleep and Power-down modes on activity on USART, SPI, and I2C peripherals.
  - Timer-controlled self wake-up from Deep power-down mode.
  - Power-On Reset (POR).
  - Brownout detect (BOD).

LPC83x

- Unique device serial number for identification.
- Single power supply (1.8 V to 3.6 V).
- Operating temperature range -40 °C to +85 °C.
- Available in a TSSOP20 and HVQFN33 (5x5) package.

## 3. Applications

- Sensor gateways
- Industrial
- Gaming controllers
- 8/16-bit applications
- Consumer
- Climate control

- Simple motor control
- Portables and wearables
- Lighting
- Motor control
- Fire and security applications

## 4. Ordering information

#### Table 1.Ordering information

| Type number     | Package |                                                                                                                       |          |  |  |  |  |
|-----------------|---------|-----------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|
|                 | Name    | Description                                                                                                           | Version  |  |  |  |  |
| LPC834M101FHI33 | HVQFN33 | HVQFN: plastic thermal enhanced very thin quad flat package; no leads; 33 terminals; body $5 \times 5 \times 0.85$ mm | n/a      |  |  |  |  |
| LPC832M101FDH20 | TSSOP20 | plastic thin shrink small outline package; 20 leads; body width 4.4 mm                                                | SOT360-1 |  |  |  |  |

#### 4.1 Ordering options

#### Table 2.Ordering options

| Type number     | Flash/K<br>B | SRAM/<br>KB | USART | l <sup>2</sup> C | SPI | ADC<br>channels | GPIO | Package |
|-----------------|--------------|-------------|-------|------------------|-----|-----------------|------|---------|
| LPC834M101FHI33 | 32           | 4           | 1     | 1                | 2   | 12              | 29   | HVQFN33 |
| LPC832M101FDH20 | 16           | 4           | 1     | 1                | 2   | 5               | 16   | TSSOP20 |

## 5. Marking



The HVQFN33 packages typically have the following top-side marking:

83xF

xx xx

yywwxR

The TSSOP20 packages typically have the following top-side marking:

LPC83x

Mx01F

XXXXXXXX

zzywwxR

In the last line, field 'y' or 'yy' states the year the device was manufactured. Field 'ww' states the week the device was manufactured during that year. Field 'R' states the chip revision.

## 6. Block diagram



## 7. Pinning information

## 7.1 Pinning





### 7.2 Pin description

The pin description table <u>Table 3</u> shows the pin functions that are fixed to specific pins on each package. These fixed-pin functions are selectable through the switch matrix between GPIO and the ADC, SWD, RESET, and the XTAL pins. By default, the GPIO function is selected except on pins PIO0\_2, PIO0\_3, and PIO0\_5. JTAG functions are available in boundary scan mode only.

\_PC83x

Movable function for the I<sup>2</sup>C, USART, SPI, and SCTimer/PWM pin functions can be assigned through the switch matrix to any pin that is not power or ground in place of the pin's fixed functions.

The following exceptions apply:

Do not assign more than one output to any pin. However, more than one input can be assigned to a pin. Once any function is assigned to a pin, the pin's GPIO functionality is disabled.

Pin PIO0\_4 triggers a wake-up from Deep power-down mode. If the part must wake up from Deep power-down mode via an external pin, do not assign any movable function to this pin.

The JTAG functions TDO, TDI, TCK, TMS, and TRST are selected on pins PIO0\_0 to PIO0\_4 by hardware when the part is in boundary scan mode.

| Symbol               | TSSOP20      | HVQFN33 |            | Reset<br>state <sup>[1]</sup> | Туре | Description                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------|--------------|---------|------------|-------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIO0_0/              | 19           | 24      | [2]        | I; PU                         | Ю    | <b>PIO0_0</b> — General-purpose port 0 input/output 0.                                                                                                                                                                                                                                                                                                                                |
| TDO                  |              |         |            |                               |      | In ISP mode, this is the U0_RXD pin.                                                                                                                                                                                                                                                                                                                                                  |
|                      |              |         |            |                               |      | In boundary scan mode: TDO (Test Data Out).                                                                                                                                                                                                                                                                                                                                           |
| PIO0_1/              | 12           | 16      | [2]        | I; PU                         | Ю    | <b>PIO0_1</b> — General-purpose port 0 input/output 1.                                                                                                                                                                                                                                                                                                                                |
| CLKIN/TDI            |              |         |            |                               |      | In boundary scan mode: TDI (Test Data In).                                                                                                                                                                                                                                                                                                                                            |
|                      |              |         |            |                               | I    | CLKIN — External clock input.                                                                                                                                                                                                                                                                                                                                                         |
| SWDIO/PIO0_2/<br>TMS | 8            | 7       | <u>[4]</u> | I; PU                         | Ю    | <b>SWDIO</b> — Serial Wire Debug I/O. SWDIO is enabled by default on this pin. In boundary scan mode: TMS (Test Mode Select).                                                                                                                                                                                                                                                         |
|                      |              |         |            |                               | I/O  | PIO0_2 — General-purpose port 0 input/output 2.                                                                                                                                                                                                                                                                                                                                       |
| SWCLK/PIO0_3/<br>TCK | 7            | 6       | <u>[4]</u> | l I; PU                       | I    | <b>SWCLK</b> — Serial Wire Clock. SWCLK is enabled by default on this pin.                                                                                                                                                                                                                                                                                                            |
|                      |              |         |            |                               |      | In boundary scan mode: TCK (Test Clock).                                                                                                                                                                                                                                                                                                                                              |
|                      |              |         |            |                               | Ю    | PIO0_3 — General-purpose port 0 input/output 3.                                                                                                                                                                                                                                                                                                                                       |
| PIO0_4/ADC_11/       | _4/ADC_11/ 6 |         | [3]        | 3] I; PU                      | 10   | PIO0_4 — General-purpose port 0 input/output 4.                                                                                                                                                                                                                                                                                                                                       |
| TRSTN/WAKEUP         |              |         |            |                               |      | In boundary scan mode: TRST (Test Reset).                                                                                                                                                                                                                                                                                                                                             |
|                      |              |         |            |                               |      | In ISP mode, this pin is the U0_TXD pin.                                                                                                                                                                                                                                                                                                                                              |
|                      |              |         |            |                               |      | This pin triggers a wake-up from Deep power-down mode. If the<br>part must wake up from Deep power-down mode via an external<br>pin, do not assign any movable function to this pin. This pin<br>should be pulled HIGH externally before entering Deep<br>power-down mode. A LOW-going pulse as short as 50 ns causes<br>the chip to exit Deep power-down mode and wakes up the part. |
|                      |              |         |            |                               | А    | ADC_11 — ADC input 11.                                                                                                                                                                                                                                                                                                                                                                |

#### Table 3. Pin description

**Product data sheet** 

LPC83x

| Symbol           | TSSOP20 | HVQFN33 |                    | Reset<br>state <sup>[1]</sup> | Туре | Description                                                                                                                                                                                                                                    |
|------------------|---------|---------|--------------------|-------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESET/PIO0_5     | 5       | 3       | [7]                | I; PU                         | IO   | <b>RESET</b> — External reset input: A LOW-going pulse as short as 50 ns 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.                      |
|                  |         |         |                    |                               |      | In deep power-down mode, this pin must be pulled HIGH externally. The RESET pin can be left unconnected or be used as a GPIO or for any movable function if an external RESET function is not needed and the Deep power-down mode is not used. |
|                  |         |         |                    |                               | I    | <b>PIO0_5</b> — General-purpose port 0 input/output 5.                                                                                                                                                                                         |
| PIO0_6/ADC_1     | -       | 23      | <u>[10]</u>        | I; PU                         | Ю    | <b>PIO0_6</b> — General-purpose port 0 input/output 6.                                                                                                                                                                                         |
| L                |         |         |                    |                               | A    | ADC_1 — ADC input 1.                                                                                                                                                                                                                           |
| PIO0_7/ADC_0 -   | -       | 22      | [2]                | I; PU                         | Ю    | <b>PIO0_7</b> — General-purpose port 0 input/output 7.                                                                                                                                                                                         |
|                  |         |         |                    |                               | А    | ADC_0 — ADC input 0.                                                                                                                                                                                                                           |
| PIO0_8/XTALIN    | 14      | 4 18    | <u>[8]</u>         | I; PU                         | IO   | PIO0_8 — General-purpose port 0 input/output 8.                                                                                                                                                                                                |
|                  |         |         |                    |                               | A    | <b>XTALIN</b> — Input to the oscillator circuit and internal clock generator circuits. Input voltage must not exceed 1.95 V.                                                                                                                   |
| PIO0_9/XTALOUT   | 13      | 17      | 7 <mark>[8]</mark> | I; PU                         | Ю    | PIO0_9 — General-purpose port 0 input/output 9.                                                                                                                                                                                                |
|                  |         |         |                    |                               | А    | <b>XTALOUT</b> — Output from the oscillator circuit.                                                                                                                                                                                           |
| PIO0_10/I2C0_SCL | 10      | 9       | <u>[6]</u>         | l Inactive                    | l; F | <b>PIO0_10</b> — General-purpose port 0 input/output 10 (open-drain).                                                                                                                                                                          |
|                  |         |         |                    |                               |      | <b>I2C0_SCL</b> — Open-drain I <sup>2</sup> C-bus clock input/output. High-current sink if I <sup>2</sup> C Fast-mode Plus is selected in the I/O configuration register.                                                                      |
| PIO0_11/I2C0_SDA | 9       | 8       | <u>[6]</u>         | Inactive                      | l; F | <b>PIO0_11 —</b> General-purpose port 0 input/output 11 (open-drain).                                                                                                                                                                          |
|                  |         |         |                    |                               |      | <b>I2C0_SDA</b> — Open-drain I <sup>2</sup> C-bus data input/output. High-current sink if I <sup>2</sup> C Fast-mode Plus is selected in the I/O configuration register.                                                                       |
| PIO0_12          | 4       | 2       | <u>[4]</u>         | I; PU                         | Ю    | <b>PIO0_12</b> — General-purpose port 0 input/output 12. ISP entry pin. A LOW level on this pin during reset starts the ISP command handler.                                                                                                   |
| PIO0_13/ADC_10   | 3       | 1       | [2]                | I; PU                         | IO   | PIO0_13 — General-purpose port 0 input/output 13.                                                                                                                                                                                              |
|                  |         |         |                    |                               | A    | ADC_10 — ADC input 10.                                                                                                                                                                                                                         |
| PIO0_14/ADC_2    | 20      | 25      | [2]                | I; PU                         | IO   | PIO0_14 — General-purpose port 0 input/output 14.                                                                                                                                                                                              |
| - —              |         |         |                    |                               | A    | ADC_2 — ADC input 2.                                                                                                                                                                                                                           |

#### Table 3. Pin description

Product data sheet

#### Table 3.Pin description

| Symbol               | TSSOP20 | HVQFN33              |            | Reset<br>state <sup>[1]</sup> | Туре | Description                                                                                                                                                                                                                                                                                                                  |  |
|----------------------|---------|----------------------|------------|-------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PIO0_15              | 11      | 15                   | <u>[5]</u> | I; PU                         | Ю    | PIO0_15 — General-purpose port 0 input/output 15.                                                                                                                                                                                                                                                                            |  |
| PIO0_16              | -       | 10                   | <u>[4]</u> | I; PU                         | Ю    | PIO0_16 — General-purpose port 0 input/output 16.                                                                                                                                                                                                                                                                            |  |
| PIO0_17/ADC_9        | 2       | 32                   | [2]        | I; PU                         | Ю    | PIO0_17 — General-purpose port 0 input/output 17.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_9 — ADC input 9.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_18/ADC_8        | -       | 31                   | [2]        | I; PU                         | 10   | PIO0_18 — General-purpose port 0 input/output 18.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_8 — ADC input 8.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_19/ADC_7        | -       | 30                   | [2]        | I; PU                         | 10   | PIO0_19 — General-purpose port 0 input/output 19.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_7 — ADC input 7.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_20/ADC_6        | -       | 29                   | [2]        | I; PU                         | 10   | PIO0_20 — General-purpose port 0 input/output 20.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_6 — ADC input 6.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_21/ADC_5        | -       | 28                   | [2]        | I; PU                         | Ю    | PIO0_21 — General-purpose port 0 input/output 21.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_5 — ADC input 5.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_22/ADC_4        | -       | 27                   | [2]        | I; PU                         | 10   | PIO0_22 — General-purpose port 0 input/output 22.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | А    | ADC_4 — ADC input 4.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_23/ADC_3        | 1       | 26                   | [2]        | I; PU                         | 10   | PIO0_23 — General-purpose port 0 input/output 23.                                                                                                                                                                                                                                                                            |  |
|                      |         |                      |            |                               | A    | ADC_3 — ADC input 3.                                                                                                                                                                                                                                                                                                         |  |
| PIO0_24              | -       | 14                   | [5]        | I; PU                         | Ю    | PIO0_24 — General-purpose port 0 input/output 24.                                                                                                                                                                                                                                                                            |  |
| PIO0_25              | -       | 13                   | [5]        | I; PU                         | 10   | PIO0_25 — General-purpose port 0 input/output 25.                                                                                                                                                                                                                                                                            |  |
| PIO0_26              | -       | 12                   | [5]        | I; PU                         | 10   | PIO0_26 — General-purpose port 0 input/output 26.                                                                                                                                                                                                                                                                            |  |
| PIO0_27              | -       | 11                   | [5]        | I; PU                         | 10   | PIO0_27 — General-purpose port 0 input/output 27.                                                                                                                                                                                                                                                                            |  |
| PIO0_28/<br>WKTCLKIN | -       | 5                    | <u>[3]</u> | I; PU                         | IO   | <b>PIO0_28</b> — General-purpose port 0 input/output 28. This pin can host an external clock for the self-wake-up timer. To use the pin as a self-wake-up timer clock input, select the external clock in the wake-up timer CTRL register. The external clock input is active in all power modes, including deep power-down. |  |
| V <sub>DD</sub>      | 15      | 19                   |            | -                             | -    | Supply voltage for the I/O pad ring, the core voltage regulator, and the analog peripherals.                                                                                                                                                                                                                                 |  |
| V <sub>SS</sub>      | 16      | 33 <mark>[11]</mark> |            | -                             | -    | Ground.                                                                                                                                                                                                                                                                                                                      |  |
| VREFN                | 17      | 20                   |            | -                             | -    | ADC negative reference voltage.                                                                                                                                                                                                                                                                                              |  |
| VREFP                | 18      | 21                   |            | -                             | -    | ADC positive reference voltage. Must be equal or lower than $V_{\text{DD}}.$                                                                                                                                                                                                                                                 |  |

[1] Pin state at reset for default function: I = Input; AI = Analog Input; O = Output; PU = internal pull-up enabled (pins pulled up to full V<sub>DD</sub> level); IA = inactive, no pull-up/down enabled; F = floating. For pin states in the different power modes, see Section 14.5 "Pin states in different power modes". For termination on unused pins, see Section 14.4 "Termination of unused pins".

[2] 5 V tolerant pin providing standard digital I/O functions with configurable modes, configurable hysteresis, and analog input. When configured as an analog input, the digital section of the pin is disabled, and the pin is not 5 V tolerant.

[3] 5 V tolerant pad providing digital I/O functions with configurable pull-up/pull-down resistors and configurable hysteresis. This pin is active in Deep power-down mode and includes a 20 ns glitch filter (active in all power modes). In Deep power-down mode, pulling the WAKEUP pin LOW wakes up the chip. The wake-up pin function can be disabled and the pin can be used for other purposes, if the WKT low-power oscillator is enabled for waking up the part from Deep power-down mode. See <u>Table 17 "Dynamic characteristics:</u> <u>WKTCLKIN pin"</u> for the WKTCLKIN input.

[4] 5 V tolerant pad providing digital I/O functions with configurable pull-up/pull-down resistors and configurable hysteresis; includes high-current output driver.

[5] 5 V tolerant pad providing digital I/O functions with configurable pull-up/pull-down resistors and configurable hysteresis.

PC83x

- [6] True open-drain pin. I<sup>2</sup>C-bus pins compliant with the I<sup>2</sup>C-bus specification for I<sup>2</sup>C standard mode, I<sup>2</sup>C Fast-mode, and I<sup>2</sup>C Fast-mode Plus. Do not use this pad for high-speed applications such as SPI or USART. The pin requires an external pull-up to provide output functionality. When power is switched off, this pin is floating and does not disturb the I<sup>2</sup>C lines. Open-drain configuration applies to all functions on this pin.
- [7] See Figure 9 for the reset pad configuration. This pin includes a 20 ns glitch filter (active in all power modes). RESET functionality is not available in Deep power-down mode. Use the WAKEUP pin to reset the chip and wake up from Deep power-down mode. An external pull-up resistor is required on this pin for the Deep power-down mode.
- [8] 5 V tolerant pin providing standard digital I/O functions with configurable modes, configurable hysteresis, and analog I/O for the system oscillator. When configured for XTALIN and XTALOUT, the digital section of the pin is disabled, and the pin is not 5 V tolerant.
- [9] The WKTCLKIN function is enabled in the DPDCTRL register in the PMU.
- [10] The digital part of this pin is 3 V tolerant pin due to special analog functionality. Pin provides standard digital I/O functions with configurable modes, configurable hysteresis, and an analog input. When configured as an analog input, the digital section of the pin is disabled.
- [11] Thermal pad for HVQFN33.

| Function name | Туре | Description                                               |
|---------------|------|-----------------------------------------------------------|
| U0_TXD        | 0    | Transmitter output for USART0.                            |
| U0_RXD        | I    | Receiver input for USART0.                                |
| U0_RTS        | 0    | Request To Send output for USART0.                        |
| U0_CTS        | I    | Clear To Send input for USART0.                           |
| U0_SCLK       | I/O  | Serial clock input/output for USART0 in synchronous mode. |
| SPI0_SCK      | I/O  | Serial clock for SPI0.                                    |
| SPI0_MOSI     | I/O  | Master Out Slave In for SPI0.                             |
| SPI0_MISO     | I/O  | Master In Slave Out for SPI0.                             |
| SPI0_SSEL0    | I/O  | Slave select 0 for SPI0.                                  |
| SPI0_SSEL1    | I/O  | Slave select 1 for SPI0.                                  |
| SPI0_SSEL2    | I/O  | Slave select 2 for SPI0.                                  |
| SPI0_SSEL3    | I/O  | Slave select 3 for SPI0.                                  |
| SPI1_SCK      | I/O  | Serial clock for SPI1.                                    |
| SPI1_MOSI     | I/O  | Master Out Slave In for SPI1.                             |
| SPI1_MISO     | I/O  | Master In Slave Out for SPI1.                             |
| SPI1_SSEL0    | I/O  | Slave select 0 for SPI1.                                  |
| SPI1_SSEL1    | I/O  | Slave select 1 for SPI1.                                  |
| SCT_PIN0      | I    | Pin input 0 to the SCT input multiplexer.                 |
| SCT_PIN1      | I    | Pin input 1 to the SCT input multiplexer.                 |
| SCT_PIN2      | I    | Pin input 2 to the SCT input multiplexer.                 |
| SCT_PIN3      | I    | Pin input 3 to the SCT input multiplexer.                 |
| SCT_OUT0      | 0    | SCT Output 0.                                             |
| SCT_OUT1      | 0    | SCT Output 1.                                             |
| SCT_OUT2      | 0    | SCT Output 2.                                             |
| SCT_OUT3      | 0    | SCT Output 3.                                             |
| SCT_OUT4      | 0    | SCT Output 4.                                             |
| SCT_OUT5      | 0    | SCT Output 5.                                             |

#### Table 4. Movable functions (assign to pins PIO0\_0 to PIO0\_28 through switch matrix)

|               |      | (                                   |
|---------------|------|-------------------------------------|
| Function name | Туре | Description                         |
| ADC_PINTRIG0  | I    | ADC external pin trigger input 0.   |
| ADC_PINTRIG1  | I    | ADC external pin trigger input 1.   |
| CLKOUT        | 0    | Clock output.                       |
| GPIO_INT_BMAT | 0    | Output of the pattern match engine. |

#### Table 4. Movable functions (assign to pins PIO0\_0 to PIO0\_28 through switch matrix)

## 8. Functional description

#### 8.1 ARM Cortex-M0+ core

The ARM Cortex-M0+ core runs at an operating frequency of up to 30 MHz using a two-stage pipeline. The core revision is r0p1.

Integrated in the core are the NVIC and Serial Wire Debug with four breakpoints and two watchpoints. The ARM Cortex-M0+ core supports a single-cycle I/O enabled port for fast GPIO access.

The core includes a single-cycle multiplier and a system tick timer.

#### 8.2 On-chip flash program memory

The LPC83x contain up to 32 KB of on-chip flash program memory. The flash memory supports a 64 Byte page size with page write and erase.

#### 8.3 On-chip SRAM

The LPC83x contain a total of 4 KB on-chip static RAM data memory.

#### 8.4 On-chip ROM

The on-chip ROM contains the bootloader and the following Application Programming Interfaces (APIs):

 In-System Programming (ISP) and In-Application Programming (IAP) support for flash including IAP erase page command.

#### 8.5 Memory map

The LPC83x incorporates several distinct memory regions. <u>Figure 6</u> shows the overall map of the entire address space from the user program viewpoint following reset. The interrupt vector area supports address remapping.

The ARM private peripheral bus includes the ARM core registers for controlling the NVIC, the system tick timer (SysTick), and the reduced power modes.

LPC83x

| 4 GB   | LPC83x                 |                            |                                   |                            |
|--------|------------------------|----------------------------|-----------------------------------|----------------------------|
| 4 OB   | reserved               |                            |                                   |                            |
|        | private peripheral bus | 0xE010 0000<br>0xE000 0000 | APB peripherals                   | 0x4008 0000                |
| 2      | reserved               |                            | 30 - 31 reserved                  | 0x4007 8000                |
|        | GPIO PINT              | 0xA000 8000                | 29 reserved                       | 0x4007 4000                |
|        | GPIO                   | 0xA000 4000<br>0xA000 0000 | 28 reserved                       | 0x4007 0000                |
|        |                        |                            | 27 reserved                       | 0x4006 C000                |
|        |                        |                            | 26 reserved                       | 0x4006 8000                |
| 2.     | reserved               |                            | 25 USART0                         | 0x4006 4000                |
|        |                        | 0x5000 C000                | 24 reserved                       | 0x4006 0000                |
|        | DMA                    | 0x5000 8000                | 23 SPI1                           | 0x4005 C000                |
|        | SCTimer/PWM            | 0x5000 4000                | 22 SPI0                           | 0x4005 8000                |
|        | CRC                    | 0x5000 0000                | 21 reserved                       | 0x4005 4000                |
|        |                        |                            | 20 I2C0                           | 0x4005 0000                |
| `.     | reserved               | Ĩ                          | 19 reserved                       | 0x4004 C000                |
|        |                        |                            | 18 system control (SYSCON)        | 0x4004 8000                |
|        | APB peripherals        | 0x4008 0000                | 17 IOCON                          | 0x4004 4000                |
| 1 GB   |                        | 0x4000 0000                | 16 flash controller               | 0x4004 0000                |
|        |                        |                            | 15 reserved                       | 0x4003 C000                |
| 3.     | reserved               |                            | - 14 reserved                     | 0x4003 8000                |
|        |                        |                            | 13 reserved                       | 0x4003 4000                |
| 0.5 GB |                        | 0x2000 0000                | 12 reserved                       | 0x4003 0000                |
|        |                        |                            | 11 input mux                      | 0x4002 C000                |
| ,      | reserved               | 0x1FFF 3000                | 10 DMA TRIGMUX                    | 0x4002 8000                |
|        | boot ROM               | 0x1FFF 0000                |                                   | 0x4002 4000                |
| `.     | reserved               |                            | 8 PMU<br>7 12-bit ADC             | 0x4002 0000                |
|        | 4 KB MTB registers     | 0x1400 1000                | 6 reserved                        | 0x4001 C000<br>0x4001 8000 |
|        |                        | 0x1400 0000                | 5 reserved                        | 0x4001 4000                |
| 22     | Į.                     |                            | 4 reserved                        | 0x4001 0000                |
|        | reserved               | <sup>*</sup>               | 3 switch matrix                   | 0x4000 C000                |
|        |                        | 0x1000 1000                | 2 self wake-up timer              | 0x4000 8000                |
|        | 4 KB SRAM              | 0x1000 0000                | 1 MRT                             | 0x4000 4000                |
| 22     |                        |                            | 0 WWDT                            | 0x4000 0000                |
|        | reserved               | Ox0000 8000                | 0x0000 00C0                       |                            |
| 0 GB   | 32 KB on-chip flash    | Ox0000 0000                | ive interrupt vectors 0x0000 0000 |                            |
| 0.00   |                        |                            |                                   | aaa-024107                 |

Product data sheet

### 8.6 Nested Vectored Interrupt Controller (NVIC)

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

#### 8.6.1 Features

- Nested Vectored Interrupt Controller is a part of the ARM Cortex-M0+.
- · Tightly coupled interrupt controller provides low interrupt latency.
- Controls system exceptions and peripheral interrupts.
- Supports 32 vectored interrupts.
- In the LPC83x, the NVIC supports vectored interrupts for each of the peripherals and the eight pin interrupts.
- Four programmable interrupt priority levels with hardware priority level masking.
- Software interrupt generation using the ARM exceptions SVCall and PendSV.
- Supports NMI.

#### 8.6.2 Interrupt sources

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

#### 8.7 System tick timer

The ARM Cortex-M0+ includes a 24-bit system tick timer (SysTick) that is intended to generate a dedicated SysTick exception at a fixed time interval (typically 10 ms).

#### 8.8 I/O configuration

The IOCON block controls the configuration of the I/O pins. Each digital or mixed digital/analog pin with the PIO0\_n designator (except the true open-drain pins PIO0\_10 and PIO0\_11) in Table 3 can be configured as follows:

- Enable or disable the weak internal pull-up and pull-down resistors.
- Select a pseudo open-drain mode. The input cannot be pulled up above V<sub>DD</sub>. The pins are not 5 V tolerant when V<sub>DD</sub> is grounded.
- Program the input glitch filter with different filter constants using one of the IOCON divided clock signals (IOCONCLKCDIV, see <u>Figure 8 "LPC83x clock generation</u>"). You can also bypass the glitch filter.
- Invert the input signal.
- Hysteresis can be enabled or disabled.
- For pins PIO0\_10 and PIO0\_11, select the I2C-mode and output driver for standard digital operation, for I2C standard and fast modes, or for I2C Fast mode+.
- The switch matrix setting enables the analog input mode on pins with analog and digital functions. Enabling the analog mode disconnects the digital functionality.

**Remark:** The functionality of each I/O pin is flexible and is determined entirely through the switch matrix. See Section 8.9 for details.

LPC83x

#### 8.8.1 Standard I/O pad configuration

Figure 7 shows the possible pin modes for standard I/O pins with analog input function:

- Digital output driver with configurable open-drain output.
- Digital input: Weak pull-up resistor (PMOS device) enabled/disabled.
- Digital input: Weak pull-down resistor (NMOS device) enabled/disabled.
- Digital input: Repeater mode enabled/disabled.
- Digital input: Programmable input digital filter selectable on all pins.
- Analog input: Selected through the switch matrix.



#### 8.9 Switch Matrix (SWM)

The switch matrix controls the function of each digital or mixed analog/digital pin in a highly flexible way by allowing to connect many functions like the USART, SPI, SCTimer/PWM, and I<sup>2</sup>C functions to any pin that is not power or ground. These functions are called movable functions and are listed in <u>Table 4</u>.

Functions that need specialized pads like the oscillator pins XTALIN and XTALOUT can be enabled or disabled through the switch matrix. These functions are called fixed-pin functions and cannot move to other pins. The fixed-pin functions are listed in <u>Table 3</u>. If a fixed-pin function is disabled, any other movable function can be assigned to this pin.

#### 8.10 Fast General-Purpose parallel I/O (GPIO)

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. Multiple outputs can be set or cleared in one write operation.

LPC83x use accelerated GPIO functions:

- GPIO registers are on the ARM Cortex-M0+ IO bus for fastest possible single-cycle I/O timing, allowing GPIO toggling with rates of up to 15 MHz.
- An entire port value can be written in one instruction.
- Mask, set, and clear operations are supported for the entire port.

All GPIO port pins are fixed-pin functions that are enabled or disabled on the pins by the switch matrix. Therefore each GPIO port pin is assigned to one specific pin and cannot be moved to another pin. Except for pins SWDIO/PIO0\_2, SWCLK/PIO0\_3, and RESET/PIO0\_5, the switch matrix enables the GPIO port pin function by default.

#### 8.10.1 Features

- Bit level port registers allow a single instruction to set and clear any number of bits in one write operation.
- Direction control of individual bits.
- All I/O default to GPIO inputs with internal pull-up resistors enabled after reset except for the I<sup>2</sup>C-bus true open-drain pins PIO0\_10 and PIO0\_11.
- Pull-up/pull-down configuration, repeater, and open-drain modes can be programmed through the IOCON block for each GPIO pin (see Figure 7).
- Direction (input/output) can be set and cleared individually.
- Pin direction bits can be toggled.

#### 8.11 Pin interrupt/pattern match engine

The pin interrupt block configures up to eight pins from all digital pins for providing eight external interrupts connected to the NVIC.

The pattern match engine can be used, with software, to create complex state machines based on pin inputs.

Any digital pin, independently of the function selected through the switch matrix, can be configured through the SYSCON block as input to the pin interrupt or pattern match engine. The registers that control the pin interrupt or pattern match engine are on the IO+ bus for fast single-cycle access.

#### 8.11.1 Features

- Pin interrupts
  - Up to eight pins can be selected from all digital pins as edge- or level-sensitive interrupt requests. Each request creates a separate interrupt in the NVIC.
  - Edge-sensitive interrupt pins can interrupt on rising or falling edges or both.
  - Level-sensitive interrupt pins can be HIGH- or LOW-active.
  - Pin interrupts can wake up the LPC83x from sleep mode, deep-sleep mode, and power-down mode.
- Pin interrupt pattern match engine
  - Up to eight pins can be selected from all digital pins to contribute to a boolean expression. The boolean expression consists of specified levels and/or transitions on various combinations of these pins.
  - Each minterm (product term) comprising the specified boolean expression can generate its own, dedicated interrupt request.
  - Any occurrence of a pattern match can be also programmed to generate an RXEV notification to the ARM CPU. The RXEV signal can be connected to a pin.
  - The pattern match engine does not facilitate wake-up.

#### 8.12 DMA controller

The DMA controller can access all memories and the USART, SPI, I2C, and ADC peripherals using DMA requests or triggers. DMA transfers can also be triggered by internal events like the ADC interrupts, the pin interrupts (PININT0 and PININT1), the SCTimer DMA requests, and the DMA trigger outputs.

#### 8.12.1 Features

- 18 channels with each channel connected to peripheral request inputs.
- DMA operations can be triggered by on-chip events or by two pin interrupts. Each DMA channel can select one trigger input from 8 sources.
- Priority is user selectable for each channel.
- Continuous priority arbitration.
- Address cache with two entries.
- Efficient use of data bus.
- Supports single transfers up to 1,024 words.
- Address increment options allow packing and/or unpacking data.

#### 8.12.2 DMA trigger input MUX (TRIGMUX)

Each DMA trigger is connected to a programmable multiplexer which connects the trigger input to one of multiple trigger sources. Each multiplexer supports the same trigger sources: the ADC sequence interrupts, the SCTimer/PWM DMA request lines, and pin interrupts PININT0 and PININT1, and the outputs of the DMA triggers 0 and 1 for chaining DMA triggers.

#### 8.13 USART0

All USART functions are movable functions and are assigned to pins through the switch matrix.

#### 8.13.1 Features

- Maximum bit rates of 1.875 Mbit/s in asynchronous mode and 10 Mbit/s in synchronous mode for USART functions connected to all digital pins except the open-drain pins.
- 7, 8, or 9 data bits and 1 or 2 stop bits
- Synchronous mode with master or slave operation. Includes data phase selection and continuous clock option.
- Multiprocessor/multidrop (9-bit) mode with software address compare. (RS-485 possible with software address detection and transceiver direction control.)
- Parity generation and checking: odd, even, or none.
- One transmit and one receive data buffer.
- RTS/CTS for hardware signaling for automatic flow control. Software flow control can be performed using Delta CTS detect, Transmit Disable control, and any GPIO as an RTS output.
- Received data and status can optionally be read from a single register
- Break generation and detection.
- Receive data is 2 of 3 sample "voting". Status flag set when one sample differs.
- Built-in Baud Rate Generator.
- A fractional rate divider is shared among all UARTs.
- Interrupts available for Receiver Ready, Transmitter Ready, Receiver Idle, change in receiver break detect, Framing error, Parity error, Overrun, Underrun, Delta CTS detect, and receiver sample noise detected.
- Separate data and flow control loopback modes for testing.
- Baud rate clock can also be output in asynchronous mode.

#### 8.14 SPI0/1

All SPI functions are movable functions and are assigned to pins through the switch matrix.

#### 8.14.1 Features

- Maximum data rates of up to 30 Mbit/s in master mode and up to 18 Mbit/s in slave mode for SPI functions connected to all digital pins except the open-drain pins.
- Data frames of 1 to 16 bits supported directly. Larger frames supported by software.
- Master and slave operation.
- Data can be transmitted to a slave without the need to read incoming data, which can be useful while setting up an SPI memory.
- Control information can optionally be written along with data, which allows very versatile operation, including "any length" frames.
- One Slave Select input/output with selectable polarity and flexible usage.

Remark: Texas Instruments SSI and National Microwire modes are not supported.

#### 8.15 I<sup>2</sup>C-bus interface (I<sup>2</sup>C0)

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 (for example, 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.

The  $I^2C0$ -bus functions are fixed-pin functions. The true open-drain pins provide the electrical characteristics to support the full  $I^2C$ -bus specification (see <u>Ref. 1</u>).

#### 8.15.1 Features

- I<sup>2</sup>C0 supports Fast-mode Plus with data rates of up to 1 Mbit/s in addition to standard and fast modes on two true open-drain pins.
- True open-drain pins provide fail-safe operation: When the power to an I<sup>2</sup>C-bus device is switched off, the SDA and SCL pins connected to the I<sup>2</sup>C0-bus are floating and do not disturb the bus.
- Independent Master, Slave, and Monitor functions.
- Supports both Multi-master and Multi-master with Slave functions.
- Multiple I<sup>2</sup>C slave addresses supported in hardware.
- One slave address can be selectively qualified with a bit mask or an address range in order to respond to multiple I<sup>2</sup>C bus addresses.
- 10-bit addressing supported with software assist.
- · Supports SMBus.

#### 8.16 SCTimer/PWM

The SCTimer/PWM can perform basic 16-bit and 32-bit timer/counter functions with match outputs and external and internal capture inputs. In addition, the SCTimer/PWM can employ up to eight different programmable states, which can change under the control of events, to provide complex timing patterns.

The inputs to the SCT are multiplexed between movable functions from the switch matrix and internal connections such as the ADC threshold compare interrupt, and the ARM core signals ARM\_TXEV and DEBUG\_HALTED. The signal on each SCT input is selected through the INPUT MUX.

All outputs of the SCT are movable functions and are assigned to pins through the switch matrix. One SCT output can also be selected as one of the ADC conversion triggers.

#### 8.16.1 Features

- Each SCTimer/PWM supports:
  - Eight match/capture registers.
  - Eight events.

PC83x

- Eight states.
- Four inputs. Each input is configurable through an input multiplexer to use one of four external pins (connected through the switch matrix) or one of four internal sources. The maximum input signal frequency is 25 MHz.
- Six outputs. Connected to pins through the switch matrix.
- Counter/timer features:
  - Each SCTimer is configurable as two 16-bit counters or one 32-bit counter.
  - Counters can be clocked by the system clock or selected input.
  - Configurable as up counters or up-down counters.
  - Configurable number of match and capture registers. Up to eight match and capture registers total.
  - Upon match create the following events: interrupt; stop, limit, halt the timer or change counting direction; toggle outputs.
  - Counter value can be loaded into capture register triggered by a match or input/output toggle.
- PWM features:
  - Counters can be used with match registers to toggle outputs and create time-proportioned PWM signals.
  - Up to six single-edge or dual-edge PWM outputs with independent duty cycle and common PWM cycle length.
- Event creation features:
  - The following conditions define an event: a counter match condition, an input (or output) condition such as a rising or falling edge or level, a combination of match and/or input/output condition.
  - Selected events can limit, halt, start, or stop a counter or change its direction.
  - Events trigger state changes, output toggles, interrupts, and DMA transactions.
  - Match register 0 can be used as an automatic limit.
  - In bidirectional mode, events can be enabled based on the count direction.
  - Match events can be held until another qualifying event occurs.
- State control features:
  - A state is defined by events that can happen in the state while the counter is running.
  - A state changes into another state as a result of an event.
  - Each event can be assigned to one or more states.
  - State variable allows sequencing across multiple counter cycles.
- One SCTimer match output can be selected as ADC hardware trigger input.

#### 8.16.2 SCTimer/PWM input MUX (INPUT MUX)

Each input of the SCTimer/PWM is connected to a programmable multiplexer which allows to connect one of multiple internal or external sources to the input. The available sources are the same for each SCTimer/PWM input and can be selected from four pins configured through the switch matrix, the ADC threshold compare interrupt, and the ARM core signals ARM\_TXEV and DEBUG\_HALTED.

#### 8.17 Multi-Rate Timer (MRT)

The Multi-Rate Timer (MRT) provides a repetitive interrupt timer with four channels. Each channel can be programmed with an independent time interval, and each channel operates independently from the other channels.

#### 8.17.1 Features

- 31-bit interrupt timer
- · Four channels independently counting down from individually set values
- Bus stall, repeat and one-shot interrupt modes

#### 8.18 Windowed WatchDog Timer (WWDT)

The watchdog timer resets the controller if software fails to service the watchdog timer periodically within a programmable time window.

#### 8.18.1 Features

- Internally resets chip if not periodically reloaded during the programmable time-out period.
- Optional windowed operation requires reload to occur between a minimum and maximum time period, both programmable.
- Optional warning interrupt can be generated at a programmable time prior to watchdog time-out.
- Enabled by software but requires a hardware reset or a watchdog reset/interrupt to be disabled.
- Incorrect feed sequence causes reset or interrupt if enabled.
- 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) is generated by the dedicated watchdog oscillator (WDOSC).

#### 8.19 Self-Wake-up Timer (WKT)

The self-wake-up timer is a 32-bit, loadable down counter. Writing any non-zero value to this timer automatically enables the counter and launches a count-down sequence. When the counter is used as a wake-up timer, this write can occur prior to entering a reduced power mode.

#### 8.19.1 Features

- 32-bit loadable down counter. Counter starts automatically when a count value is loaded. Time-out generates an interrupt/wake up request.
- The WKT resides in a separate, always-on power domain.
- The WKT supports three clock sources: an external clock on the WKTCLKIN pin, the low-power oscillator, and the IRC. The low-power oscillator is located in the always-on power domain, so it can be used as the clock source in Deep power-down mode.

PC83x

• The WKT can be used for waking up the part from any reduced power mode, including Deep power-down mode, or for general-purpose timing.

#### 8.20 Analog-to-Digital Converter (ADC)

The ADC supports a resolution of 12 bit and fast conversion rates of up to 1.2 MSamples/s. Sequences of analog-to-digital conversions can be triggered by multiple sources.

The ADC includes a hardware threshold compare function with zero-crossing detection.

**Remark:** For best performance, select VREFP and VREFN at the same voltage levels as  $V_{DD}$  and  $V_{SS}$ . When selecting VREFP and VREFN different from VDD and VSS, ensure that the voltage midpoints are the same:

 $(VREFP-VREFN)/2 + VREFN = V_{DD}/2$ 

#### 8.20.1 Features

- 12-bit successive approximation analog to digital converter.
- 12-bit conversion rate of up to 1.2 MSamples/s.
- Two configurable conversion sequences with independent triggers.
- Optional automatic high/low threshold comparison and zero-crossing detection.
- Power-down mode and low-power operating mode.
- Measurement range VREFN to VREFP (not to exceed V<sub>DD</sub> voltage level).
- Burst conversion mode for single or multiple inputs.
- Hardware calibration mode.

PC83x



#### 8.21 Clocking and power control

#### 8.21.1 Crystal and internal oscillators

The LPC83x include four independent oscillators:

- 1. The crystal oscillator (SysOsc) operating at frequencies between 1 MHz and 25 MHz.
- 2. The internal RC Oscillator (IRC) with a fixed frequency of 12 MHz.
- 3. The internal low-power, low-frequency Oscillator with a nominal frequency of 10 kHz with 40% accuracy for use with the self-wake-up timer.
- 4. The dedicated Watchdog Oscillator (WDOsc) with a programmable nominal frequency between 9.4 kHz and 2.3 MHz with 40% accuracy.

Each oscillator, except the low-frequency oscillator, can be used for more than one purpose as required in a particular application.

Following reset, the LPC83x operates from the IRC until switched by software allowing the part to run without any external crystal and the bootloader code to operate at a known frequency.

See Figure 8 for an overview of the LPC83x clock generation.

#### 8.21.1.1 Internal RC Oscillator (IRC)

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

The IRC can be used as a clock source for the CPU with or without using the PLL. The IRC frequency can be boosted to a higher frequency, up to the maximum CPU operating frequency, by the system PLL.

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

#### 8.21.1.2 Crystal Oscillator (SysOsc)

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

The SysOsc 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.

#### 8.21.1.3 Internal Low-power Oscillator and Watchdog Oscillator (WDOsc)

The nominal frequency of the WDOsc is programmable between 9.4 kHz and 2.3 MHz. The frequency spread over silicon process variations is  $\pm$  40%.

The WDOsc is a dedicated oscillator for the windowed WWDT.

The internal low-power 10 kHz ( $\pm$  40% accuracy) oscillator serves as the clock input to the WKT. This oscillator can be configured to run in all low-power modes.

#### 8.21.2 Clock input

An external clock source can be supplied on the selected CLKIN pin directly to the PLL input. When selecting a clock signal for the CLKIN pin, follow the specifications for digital I/O pins in <u>Table 8 "Static characteristics, supply pins"</u> and <u>Table 16 "Dynamic characteristics: I/O pins<sup>[1]</sup>"</u>.

An 1.8 V external clock source can be supplied on the XTALIN pins to the system oscillator limiting the voltage of this signal (see Section 14.1).

The maximum frequency for both clock signals is 25 MHz.

#### 8.21.3 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. 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 nominally 100  $\mu$ s.

#### 8.21.4 Clock output

The LPC83x features a clock output function that routes the IRC, the SysOsc, the watchdog oscillator, or the main clock to the CLKOUT function. The CLKOUT function can be connected to any digital pin through the switch matrix.

#### 8.21.5 Wake-up process

The LPC83x begin operation at power-up by using the IRC as the clock source allowing chip operation to resume quickly. If the SysOsc, the external clock source, or the PLL are needed by the application, software must enable these features and wait for them to stabilize before they are used as a clock source.

#### 8.21.6 Power control

The LPC83x supports the ARM Cortex-M0 Sleep 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 to fine-tune 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.

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

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.

#### 8.21.6.2 Deep-sleep mode

In Deep-sleep mode, the LPC83x core is in Sleep mode and all peripheral clocks and all clock sources are off except for the IRC and watchdog oscillator or low-power oscillator if selected. The IRC output is disabled. In addition, all analog blocks are shut down and the flash is in standby mode. In Deep-sleep mode, the application can keep the watchdog oscillator and the BOD circuit running for self-timed wake-up and BOD protection.

The LPC83x can wake up from Deep-sleep mode via a reset, digital pins selected as inputs to the pin interrupt block, a watchdog timer interrupt, or an interrupt from the USART (if the USART is configured in synchronous slave mode), the SPI, or the I2C blocks (in slave mode).