

# **UM11021** LPC83x User manual Rev. 1.1 – 5 October 2016

**User manual** 

### **Document information**

| Info     | Content                                  |  |
|----------|------------------------------------------|--|
| Keywords | LPC83x, LPC834M101FHI33, LPC832M101FDH20 |  |
| Abstract | LPC83x User manual                       |  |



### **Revision history**

| Rev            | Date                                                                                                                                                                                                   | Description                                                                                                                                                                                                                                                                       |  |  |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| v.1.1          | 20161005                                                                                                                                                                                               | LPC83x User manual.                                                                                                                                                                                                                                                               |  |  |  |  |
| Modifications: |                                                                                                                                                                                                        | ure 17 "DMA trigger multiplexing".                                                                                                                                                                                                                                                |  |  |  |  |
|                | <ul> <li>Updated reg<br/>0x4002 8000</li> </ul>                                                                                                                                                        | ister descriptions in Table 140 "Register overview: Input multiplexing (base address ))".                                                                                                                                                                                         |  |  |  |  |
|                | address 0x4                                                                                                                                                                                            | ole 142 "DMA input trigger Input mux registers 0 to 17 (DMA_ITRIG_INMUX[0:17],<br>002 80E0 (DMA_ITRIG_INMUX0) to 0x4002 8124 (DMA_ITRIG_INMUX17)) bit<br>value: 0x4 Reserved.                                                                                                     |  |  |  |  |
|                | <ul> <li>Updated <u>Table 144 "SCT input mux registers 0 to 3 (SCT0_INMUX[0:3], address 0x4002 Classes (SCT0_INMUX0) to 0x4002 C02C (SCT0_INMUX3)) bit description</u>": value: 0x5Reserved</li> </ul> |                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                |                                                                                                                                                                                                        | ction 12.2 "Features": DMA operations can be triggered by on- or off-chip events. Each<br>el can select one trigger input from 9 sources.                                                                                                                                         |  |  |  |  |
|                | <ul> <li>Updated Fig</li> </ul>                                                                                                                                                                        | ure 18 "DMA block diagram".                                                                                                                                                                                                                                                       |  |  |  |  |
|                | <ul> <li>Updated <u>Tab</u></li> </ul>                                                                                                                                                                 | ole 145 "DMA requests".                                                                                                                                                                                                                                                           |  |  |  |  |
|                | (CFG0) to ac                                                                                                                                                                                           | ble 167 "Configuration registers for channel 0 to 17 (CFG[0:17], addresses 0x5000 8400<br>ddress 0x5000 8510 (CFG17)) bit description": Description of PERIPHREQEN: This bit<br>or channel 2, 3, 4, 5, and channels 12 to 17 since peripheral request is not available on<br>els. |  |  |  |  |
|                | 24 - ADC_RST_N and 29 - DMA_RST_N to Table 21 "Peripheral reset control register<br>TRL, address 0x4004 8004) bit description".                                                                        |                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                | on 12.5.7 "Channel chaining".                                                                                                                                                                          |                                                                                                                                                                                                                                                                                   |  |  |  |  |
| v.1            | 20160829                                                                                                                                                                                               | Initial revision. LPC83x User manual.                                                                                                                                                                                                                                             |  |  |  |  |

### **Contact information**

For more information, please visit: http://www.nxp.com

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

UM11021

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

### Chapter 1: LPC83x Introductory information

Rev. 1.1 — 5 October 2016

**User manual** 

### **1.1 Introduction**

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 8 KB of SRAM.

The peripheral complement of the LPC83x includes a CRC engine, one I2C-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.

Remark: For additional documentation, see Section 27.2 "References".

### **1.2 Features**

- 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.
  - Micro 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.
  - 8 KB SRAM.
- ROM API support:
  - bootloader.
  - On-chip ROM APIs for ADC, SPI, I2C, USART, power configuration (power profiles) and integer divide.
  - 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 32 General-Purpose I/O (GPIO) pins with configurable pull-up/pull-down resistors, programmable open-drain mode, input inverter, and glitch 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.
  - 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 9 trigger inputs.
- Timers:
  - SCTimer/PWM with input and output functions (including capture and match) 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.
  - Comparator with four input pins and external or internal reference voltage.
- Serial peripherals:
  - Three USART interfaces with pin functions assigned through the switch matrix and one common fractional baud rate generator.
  - Two SPI controllers with pin functions assigned through the switch matrix.
  - Four I<sup>2</sup>C-bus interfaces. One I2C supports Fast-mode plus with 1 Mbit/s data rates on two true open-drain pins and listen mode. Three I2Cs support data rates up to 400 kbit/s on standard digital pins.
- · 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:
  - 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).

#### Chapter 1: LPC83x Introductory information

- Unique device serial number for identification.
- Single power supply (1.8 V to 3.6 V).
- Operating temperature range -40 °C to +105 °C.
- Available in a HVQFN33 (5x5) package.
- 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.
  - 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).

UM11021

### Chapter 1: LPC83x Introductory information

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

### **1.3 Ordering options**

| Fable 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 |  |  |  |

### Table 2.Ordering options

| Type number     | Flash/K<br>B | SRAM/<br>KB | USART | I <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 |

### Chapter 1: LPC83x Introductory information

### **1.4 General description**

### 1.4.1 ARM Cortex-M0+ core configuration

The ARM Cortex-M0+ core runs at an operating frequency of up to 30 MHz. Integrated in the core are the NVIC and Serial Wire Debug with four breakpoints and two watch points. The ARM Cortex-M0+ core supports a single-cycle I/O enabled port (IOP) for fast GPIO access at address 0xA000 0000. The ARM Cortex M0+ core version is r0p1.

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

**User manual** 

#### Chapter 1: LPC83x Introductory information

### 1.5 Block diagram



Chapter 2: LPC83x memory mapping

Rev. 1.1 — 5 October 2016

**User manual** 

### 2.1 How to read this chapter

The memory mapping is identical for all LPC83x parts. Different LPC83x parts support different flash and SRAM memory sizes.

### 2.2 General description

The LPC83x incorporates several distinct memory regions. <u>Figure 2</u> shows the overall map of the entire address space from the user program viewpoint following reset.

The APB peripheral area is 512 KB in size and is divided to allow for up to 32 peripherals. Each peripheral is allocated 16 KB of space simplifying the address decoding.

The registers incorporated into the ARM Cortex-M0+ core, such as NVIC, SysTick, and sleep mode control, are located on the private peripheral bus.

The GPIO port and pin interrupt/pattern match registers are accessed by the ARM Cortex-M0+ single-cycle I/O enabled port (IOP).



### 2.2.1 Memory mapping

### 2.2.2 Micro Trace Buffer (MTB)

The LPC83x supports the ARM Cortex-M0+ Micro Trace Buffer. See Section 25.5.4.

### Chapter 3: LPC83x Boot ROM

Rev. 1.1 — 5 October 2016

**User manual** 

### 3.1 How to read this chapter

The bootloader is identical for all parts.

### 3.2 Features

- 12 KB on-chip boot ROM
- Contains the bootloader with In-System Programming (ISP) facility and the following APIs:
  - In-Application Programming (IAP) of flash memory

### 3.3 Basic configuration

The clock to the ROM is enabled by default. No configuration is required to use the ROM APIs.

### 3.4 Pin description

When the ISP entry pin is pulled LOW on reset, the part enters ISP mode and the ISP command handler starts up. In ISP mode, pin PIO0\_0 is connected to function U0\_RXD and pin PIO0\_4 is connected to function U0\_TXD on the USART0 block.

### Table 3. Pin location in ISP mode

| ISP entry pin | USART RXD | USART TXD |
|---------------|-----------|-----------|
| PIO0_12       | PIO0_0    | PIO0_4    |

### 3.5 General description

### 3.5.1 Bootloader

The bootloader controls initial operation after reset and also provides the means to accomplish programming of the flash memory via USART. This could be initial programming of a blank device, erasure and re-programming of a previously programmed device, or programming of the flash memory by the application program in a running system.

The bootloader code is executed every time the part is powered on or reset. The bootloader can execute the ISP command handler or the user application code. A LOW level after reset at the ISP entry pin is considered as an external hardware request to start the ISP command handler via USART.

For details on the boot process, see Section 3.6.2 "Boot process".

**Remark:** SRAM location 0x1000 0000 to 0x1000 0050 is not used by the bootloader and the memory content in this area is retained during reset. SRAM memory is not retained when the part powers down or enters Deep power-down mode.

Assuming that power supply pins are at their nominal levels when the rising edge on RESET pin is generated, it may take up to 3 ms before the ISP entry pin is sampled and the decision whether to continue with user code or ISP handler is made. The bootloader performs the following steps (see Figure 3):

- 1. If the watchdog overflow flag is set, the bootloader checks whether a valid user code is present. If the watchdog overflow flag is not set, the ISP entry pin is checked.
- 2. If there is no request for the ISP command handler execution (ISP entry pin is sampled HIGH after reset), a search is made for a valid user program.
- 3. If a valid user program is found then the execution control is transferred to it. If a valid user program is not found, the bootloader attempts to load a valid user program via the USART interface.

**Remark:** The sampling of pin the ISP entry pin can be disabled through programming flash location 0x0000 02FC (see <u>Section 24.5.3 "Code Read Protection (CRP)"</u>).

### 3.6 Functional description

### 3.6.1 Memory map after any reset

The boot block is 12 KB in size. The boot block is located in the memory region starting from the address 0x1FFF 0000. The bootloader is designed to run from this memory area, but both the ISP and IAP software use parts of the on-chip RAM. The RAM usage is described in <u>Section 24.7.2 "Memory and interrupt use for ISP and IAP</u>". The interrupt vectors residing in the boot block of the on-chip flash memory also become active after reset, i.e., the bottom 512 bytes of the boot block are also visible in the memory region starting from the address 0x0000 0000.

### 3.6.2 Boot process

During the boot process, the bootloader checks if there is valid user code in flash. The criterion for valid user code is as follows:

The reserved Cortex-M0+ exception vector location 7 (offset 0x0000 001C in the vector table) should contain the 2's complement of the check-sum of table entries 0 through 6. This causes the checksum of the first 8 table entries to be 0. The bootloader code checksums the first 8 locations in sector 0 of the flash. If the result is 0, then execution control is transferred to the user code.

If the signature is not valid, the auto-baud routine synchronizes with the host via serial port USART0. The host should send a '?' (0x3F) as a synchronization character and wait for a response. The host side serial port settings should be 8 data bits, 1 stop bit and no parity. The auto-baud routine measures the bit time of the received synchronization character in terms of its own frequency (the 12 MHz IRC frequency) and programs the baud rate generator of the serial port. It also sends an ASCII string ("Synchronized<CR><LF>") to the host. In response, the host should send the same string ("Synchronized<CR><LF>").

The bootloader auto-baud routine looks at the received characters to verify synchronization. If synchronization is verified then "OK<CR><LF>" string is sent to the host. The host should respond by sending the crystal frequency (in kHz) at which the part is running. The response is required for backward compatibility of the bootloader code and, on the LPC800, is ignored. The bootloader configures the part to run at the 12 MHz IRC frequency.

Once the crystal frequency response is received, the part is initialized and the ISP command handler is invoked. For safety reasons an "Unlock" command is required before executing the commands resulting in flash erase/write operations and the "Go" command. The rest of the commands can be executed without the unlock command. The Unlock command is required to be executed once per ISP session. The Unlock command is explained in Table 306 "UART ISP Unlock command".

**User manual** 





Chapter 4: LPC83x Nested Vectored Interrupt Controller (NVIC)

Rev. 1.1 — 5 October 2016

**User manual** 

### 4.1 How to read this chapter

The NVIC is identical on all LPC83x parts.

### 4.2 Features

- Nested Vectored Interrupt Controller that is an integral part of the ARM Cortex-M0+.
- Tightly coupled interrupt controller provides low interrupt latency.
- Controls system exceptions and peripheral interrupts.
- The NVIC supports 32 vectored interrupts.
- Four programmable interrupt priority levels with hardware priority level masking.
- Software interrupt generation using the ARM exceptions SVCall and PendSV (see <u>Ref. 3</u>).
- Support for NMI.
- ARM Cortex M0+ Vector table offset register VTOR implemented.

### 4.3 General description

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.

### 4.3.1 Interrupt sources

<u>Table 4</u> lists the interrupt sources for each peripheral function. Each peripheral device may have one or more interrupt lines to the Vectored Interrupt Controller. Each line may represent more than one interrupt source. Interrupts with the same priority level are serviced in the order of their interrupt number.

See <u>Ref. 3</u> for a detailed description of the NVIC and the NVIC register description.

| Interrupt<br>number | Name                       | Description      | Flags                                                                                                                                          |
|---------------------|----------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                   | register (INTENSET, addres |                  | See Table 190 "SPI Interrupt Enable read and Set<br>register (INTENSET, addresses 0x4005 800C (SPI0),<br>0x4005 C00C (SPI1)) bit description". |
| 1                   | SPI1_IRQ                   | SPI1 interrupt   | Same as SPI0_IRQ                                                                                                                               |
| 2                   | -                          | Reserved         | -                                                                                                                                              |
| 3                   | UART0_IRQ                  | USART0 interrupt | See <u>Table 176 "USART Interrupt Enable read and set</u><br>register (INTENSET, address 0x4006 400C (USART0))<br><u>bit description"</u>      |
| 4                   | -                          | Reserved         | -                                                                                                                                              |

Table 4. Connection of interrupt sources to the NVIC

### Chapter 4: LPC83x Nested Vectored Interrupt Controller (NVIC)

| Interrupt<br>number |               |                                                                 | Flags                                                                                                         |  |
|---------------------|---------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|
| 5                   | -             | Reserved                                                        | -                                                                                                             |  |
| 6                   | -             | Reserved                                                        | -                                                                                                             |  |
| 7                   | -             | Reserved                                                        | -                                                                                                             |  |
| 8                   | I2C0_IRQ      | I2C0 interrupt                                                  | See Table 206 "Interrupt Enable Clear register<br>(INTENCLR, address 0x4005 000C (I2C0)) bit<br>description". |  |
| 9                   | SCT_IRQ       | State configurable timer interrupt                              | EVFLAG SCT event                                                                                              |  |
| 10                  | MRT_IRQ       | Multi-rate timer interrupt                                      | Global MRT interrupt.<br>GFLAG0<br>GFLAG1<br>GFLAG2<br>GFLAG3                                                 |  |
| 11                  | -             | Reserved                                                        | -                                                                                                             |  |
| 12                  | WDT_IRQ       | Windowed watchdog timer interrupt                               | WARNINT - watchdog warning interrupt                                                                          |  |
| 13                  | BOD_IRQ       | BOD interrupts                                                  | BODINTVAL - BOD interrupt level                                                                               |  |
| 14                  | FLASH_IRQ     | flash interrupt                                                 | -                                                                                                             |  |
| 15                  | WKT_IRQ       | Self-wake-up timer interrupt                                    | ALARMFLAG                                                                                                     |  |
| 16                  | ADC_SEQA_IRQ  | ADC sequence A completion                                       | -                                                                                                             |  |
| 17                  | ADC_SEQB_IRQ  | ADC sequence B completion                                       | -                                                                                                             |  |
| 18                  | ADC_THCMP_IRQ | ADC threshold compare                                           | -                                                                                                             |  |
| 19                  | ADC_OVR_IRQ   | ADC overrun                                                     | -                                                                                                             |  |
| 20                  | DMA_IRQ       | DMA interrupt                                                   | -                                                                                                             |  |
| 21                  | -             | Reserved                                                        | -                                                                                                             |  |
| 22                  | -             | Reserved                                                        | -                                                                                                             |  |
| 23                  | -             | Reserved                                                        | -                                                                                                             |  |
| 24                  | PININT0_IRQ   | Pin interrupt 0 or pattern<br>match engine slice 0<br>interrupt | PSTAT - pin interrupt status                                                                                  |  |
| 25                  | PININT1_IRQ   | Pin interrupt 1 or pattern<br>match engine slice 1<br>interrupt | PSTAT - pin interrupt status                                                                                  |  |
| 26                  | PININT2_IRQ   | Pin interrupt 2 or pattern<br>match engine slice 2<br>interrupt | PSTAT - pin interrupt status                                                                                  |  |
| 27                  | PININT3_IRQ   | Pin interrupt 3 or pattern<br>match engine slice 3<br>interrupt | PSTAT - pin interrupt status                                                                                  |  |
| 28                  | PININT4_IRQ   | Pin interrupt 4 or pattern<br>match engine slice 4<br>interrupt | PSTAT - pin interrupt status                                                                                  |  |

### Table 4. Connection of interrupt sources to the NVIC

| Chapter 4: LPC83x N | ested Vectored Inte | errupt Controller (NVIC) |
|---------------------|---------------------|--------------------------|
|                     |                     |                          |

| Interrupt<br>number | Name        | Description                                                     | Flags                        |  |
|---------------------|-------------|-----------------------------------------------------------------|------------------------------|--|
| 29                  | PININT5_IRQ | Pin interrupt 5 or pattern<br>match engine slice 5<br>interrupt | PSTAT - pin interrupt status |  |
| 30                  | PININT6_IRQ | Pin interrupt 6 or pattern<br>match engine slice 6<br>interrupt | PSTAT - pin interrupt status |  |
| 31                  | PININT7_IRQ | Pin interrupt 7 or pattern<br>match engine slice 7<br>interrupt | PSTAT - pin interrupt status |  |

#### Table 4. Connection of interrupt sources to the NVIC

### 4.3.2 Non-Maskable Interrupt (NMI)

The part supports the NMI, which can be triggered by an peripheral interrupt or triggered by software. The NMI has the highest priority exception other than the reset.

You can set up any peripheral interrupt listed in <u>Table 4</u> as NMI using the NMISRC register in the SYSCON block (<u>Table 46</u>). To avoid using the same peripheral interrupt as NMI exception and normal interrupt, disable the interrupt in the NVIC when you configure it as NMI.

### 4.3.3 Vector table offset

The vector table contains the reset value of the stack pointer and the start addresses, also called exception vectors, for all exception handlers. On system reset, the vector table is located at address 0x0000 0000. Software can write to the VTOR register in the NVIC to relocate the vector table start address to a different memory location. For a description of the VTOR register, see the ARM Cortex-M0+ documentation (Ref. 3).

### 4.4 Register description

The NVIC registers are located on the ARM private peripheral bus.

| Table 5. | Registe | r overview | : NVIC (base | address 0xE000 E000) |
|----------|---------|------------|--------------|----------------------|
|          |         |            |              |                      |

| Name  | Access | Address<br>offset | Description                                                                                                                                                                          | Reset<br>value | Reference |
|-------|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|
| ISER0 | RW     | 0x100             | Interrupt Set Enable Register 0. This register allows enabling (<br>interrupts and reading back the interrupt enables for specific<br>peripheral functions.                          |                | Table 6   |
| -     | -      | 0x104             | Reserved.                                                                                                                                                                            | -              | -         |
| ICER0 | RW     | 0x180             | Interrupt Clear Enable Register 0. This register allows disabling interrupts and reading back the interrupt enables for specific peripheral functions.                               | 0              | Table 7   |
| -     | -      | 0x184             | Reserved.                                                                                                                                                                            | 0              | -         |
| ISPR0 | RW     | 0x200             | Interrupt Set Pending Register 0. This register allows changing the interrupt state to pending and reading back the interrupt pending state for specific peripheral functions.       | 0              | Table 8   |
| -     | -      | 0x204             | Reserved.                                                                                                                                                                            | 0              | -         |
| ICPR0 | RW     | 0x280             | Interrupt Clear Pending Register 0. This register allows changing the interrupt state to not pending and reading back the interrupt pending state for specific peripheral functions. | 0              | Table 9   |
| -     | -      | 0x284             | Reserved.                                                                                                                                                                            | 0              | -         |
| IABR0 | RO     | 0x300             | Interrupt Active Bit Register 0. This register allows reading the current interrupt active state for specific peripheral functions.                                                  |                | Table 10  |
| -     | -      | 0x304             | Reserved.                                                                                                                                                                            | 0              | -         |
| IPR0  | RW     | 0x400             | Interrupt Priority Registers 0. This register allows assigning a priority to each interrupt. This register contains the 2-bit priority fields for interrupts 0 to 3.                 |                | Table 11  |
| IPR2  | RW     | 0x408             | Interrupt Priority Registers 2. This register allows assigning a priority to each interrupt. This register contains the 2-bit priority fields for interrupts 8 to 11.                | 0              | Table 12  |
| IPR3  | RW     | 0x40C             | Interrupt Priority Registers 3. This register allows assigning a priority to each interrupt. This register contains the 2-bit priority fields for interrupts 12 to 15.               | 0              | Table 13  |
| IPR4  | RW     |                   |                                                                                                                                                                                      | 0              | Table 14  |
| IPR5  | RW     | 0x414             | Interrupt Priority Registers 5. This register allows assigning a priority 0 to each interrupt. This register contains the 2-bit priority fields for interrupts 20 to 23.             |                | Table 15  |
| IPR6  | RW     | 0x418             | Interrupt Priority Registers 6. This register allows assigning a priority 0 to each interrupt. This register contains the 2-bit priority fields for interrupts 24 to 27.             |                | Table 16  |
| IPR7  | RW     | 0x41C             | Interrupt Priority Registers 7. This register allows assigning a priority to each interrupt. This register contains the 2-bit priority fields for interrupts 28 to 31.               | 0              | Table 17  |

### 4.4.1 Interrupt Set Enable Register 0 register

The ISER0 register allows to enable peripheral interrupts or to read the enabled state of those interrupts. Disable interrupts through the ICER0 (<u>Section 4.4.2</u>).

The bit description is as follows for all bits in this register:

Write — Writing 0 has no effect, writing 1 enables the interrupt.

**Read** — 0 indicates that the interrupt is disabled, 1 indicates that the interrupt is enabled.

### Table 6. Interrupt Set Enable Register 0 register (ISER0, address 0xE000 E100) bit description

| Bit | Symbol        | Description       | Reset value |
|-----|---------------|-------------------|-------------|
| 0   | ISE_SPI0      | Interrupt enable. | 0           |
| 1   | ISE_SPI1      | Interrupt enable. | 0           |
| 2   | -             | Reserved.         | -           |
| 3   | ISE_UART0     | Interrupt enable. | 0           |
| 4   | -             | Reserved          | -           |
| 5   | -             | Reserved          | -           |
| 6   | -             | Reserved.         | -           |
| 7   | -             | Reserved          | -           |
| 8   | ISE_I2C0      | Interrupt enable. | 0           |
| 9   | ISE_SCT       | Interrupt enable. | 0           |
| 10  | ISE_MRT       | Interrupt enable. | 0           |
| 11  | -             | Reserved          | -           |
| 12  | ISE_WDT       | Interrupt enable. | 0           |
| 13  | ISE_BOD       | Interrupt enable. | 0           |
| 14  | ISE_FLASH     | Interrupt enable. | 0           |
| 15  | ISE_WKT       | Interrupt enable. | 0           |
| 16  | ISE_ADC_SEQA  | Interrupt enable. | 0           |
| 17  | ISE_ADC_SEQB  | Interrupt enable. | 0           |
| 18  | ISE_ADC_THCMP | Interrupt enable. | 0           |
| 19  | ISE_ADC_OVR   | Interrupt enable. | 0           |
| 20  | -             | Reserved          | -           |
| 21  | -             | Reserved          | -           |
| 22  | ISE_I2C3      | Interrupt enable. | 0           |
| 23  | -             | Reserved.         | -           |
| 24  | ISE_PININT0   | Interrupt enable. | 0           |
| 25  | ISE_PININT1   | Interrupt enable. | 0           |
| 26  | ISE_PININT2   | Interrupt enable. | 0           |
| 27  | ISE_PININT3   | Interrupt enable. | 0           |
| 28  | ISE_PININT4   | Interrupt enable. | 0           |
| 29  | ISE_PININT5   | Interrupt enable. | 0           |
| 30  | ISE_PININT6   | Interrupt enable. | 0           |
| 31  | ISE_PININT7   | Interrupt enable. | 0           |

UM11021

### 4.4.2 Interrupt clear enable register 0

The ICER0 register allows disabling the peripheral interrupts, or for reading the enabled state of those interrupts. Enable interrupts through the ISER0 registers (<u>Section 4.4.1</u>).

The bit description is as follows for all bits in this register:

Write — Writing 0 has no effect, writing 1 disables the interrupt.

**Read** — 0 indicates that the interrupt is disabled, 1 indicates that the interrupt is enabled.

| Bit | Symbol        | Description        | Reset value |
|-----|---------------|--------------------|-------------|
| 0   | ICE_SPI0      | Interrupt disable. | 0           |
| 1   | ICE_SPI1      | Interrupt disable. | 0           |
| 2   | -             | Reserved.          | -           |
| 3   | ICE_UART0     | Interrupt disable. | 0           |
| 4   | -             | Reserved           | -           |
| 5   | -             | Reserved           | -           |
| 6   | -             | Reserved.          | -           |
| 7   | -             | Reserved           | -           |
| 8   | ICE_I2C0      | Interrupt disable. | 0           |
| 9   | ICE_SCT       | Interrupt disable. | 0           |
| 10  | ICE_MRT       | Interrupt disable. | 0           |
| 11  | -             | Reserved           | -           |
| 12  | ICE_WDT       | Interrupt disable. | 0           |
| 13  | ICE_BOD       | Interrupt disable. | 0           |
| 14  | ICE_FLASH     | Interrupt disable. | 0           |
| 15  | ICE_WKT       | Interrupt disable. | 0           |
| 16  | ICE_ADC_SEQA  | Interrupt disable. | 0           |
| 17  | ICE_ADC_SEQB  | Interrupt disable. | 0           |
| 18  | ICE_ADC_THCMP | Interrupt disable. | 0           |
| 19  | ICE_ADC_OVR   | Interrupt disable. | 0           |
| 20  | ICE_SDMA      | Interrupt disable. | 0           |
| 21  | -             | Reserved           | -           |
| 22  | -             | Reserved           | -           |
| 23  | -             | Reserved.          | -           |
| 24  | ICE_PININT0   | Interrupt disable. | 0           |
| 25  | ICE_PININT1   | Interrupt disable. | 0           |
| 26  | ICE_PININT2   | Interrupt disable. | 0           |
| 27  | ICE_PININT3   | Interrupt disable. | 0           |
| 28  | ICE_PININT4   | Interrupt disable. | 0           |
| 29  | ICE_PININT5   | Interrupt disable. | 0           |
| 30  | ICE_PININT6   | Interrupt disable. | 0           |
| 31  | ICE_PININT7   | Interrupt disable. | 0           |

Table 7. Interrupt clear enable register 0 (ICER0, address 0xE000 E180)

### 4.4.3 Interrupt Set Pending Register 0 register

The ISPR0 register allows setting the pending state of the peripheral interrupts, or for reading the pending state of those interrupts. Clear the pending state of interrupts through the ICPR0 registers (Section 4.4.4).

The bit description is as follows for all bits in this register:

Write — Writing 0 has no effect, writing 1 changes the interrupt state to pending.

**Read** — 0 indicates that the interrupt is not pending, 1 indicates that the interrupt is pending.

|     | description   |                        |             |  |  |
|-----|---------------|------------------------|-------------|--|--|
| Bit | Symbol        | Description            | Reset value |  |  |
| 0   | ISP_SPI0      | Interrupt pending set. | 0           |  |  |
| 1   | ISP_SPI1      | Interrupt pending set. | 0           |  |  |
| 2   | -             | Reserved.              | -           |  |  |
| 3   | ISP_UART0     | Interrupt pending set. | 0           |  |  |
| 4   | -             | Reserved               | -           |  |  |
| 5   | -             | Reserved               | -           |  |  |
| 6   | -             | Reserved.              | -           |  |  |
| 7   | -             | Reserved               | -           |  |  |
| 8   | ISP_I2C0      | Interrupt pending set. | 0           |  |  |
| 9   | ISP_SCT       | Interrupt pending set. | 0           |  |  |
| 10  | ISP_MRT       | Interrupt pending set. | 0           |  |  |
| 11  | -             | Reserved               | -           |  |  |
| 12  | ISP_WDT       | Interrupt pending set. | 0           |  |  |
| 13  | ISP_BOD       | Interrupt pending set. | 0           |  |  |
| 14  | ISP_FLASH     | Interrupt pending set. | 0           |  |  |
| 15  | ISP_WKT       | Interrupt pending set. | 0           |  |  |
| 16  | ISP_ADC_SEQA  | Interrupt pending set. | 0           |  |  |
| 17  | ISP_ADC_SEQB  | Interrupt pending set. | 0           |  |  |
| 18  | ISP_ADC_THCMP | Interrupt pending set. | 0           |  |  |
| 19  | ISP_ADC_OVR   | Interrupt pending set. | 0           |  |  |
| 20  | ISP_SDMA      | Interrupt pending set. | 0           |  |  |
| 21  | -             | Reserved               | -           |  |  |
| 22  | -             | Reserved               | -           |  |  |
| 23  | -             | Reserved.              | -           |  |  |
| 24  | ISP_PININT0   | Interrupt pending set. | 0           |  |  |
| 25  | ISP_PININT1   | Interrupt pending set. | 0           |  |  |
| 26  | ISP_PININT2   | Interrupt pending set. | 0           |  |  |
| 27  | ISP_PININT3   | Interrupt pending set. | 0           |  |  |
| 28  | ISP_PININT4   | Interrupt pending set. | 0           |  |  |
|     |               |                        |             |  |  |

 Table 8.
 Interrupt set pending register 0 register (ISPR0, address 0xE000 E200) bit description

|     | descriptioncontinued |                        |             |  |  |
|-----|----------------------|------------------------|-------------|--|--|
| Bit | Symbol               | Description            | Reset value |  |  |
| 29  | ISP_PININT5          | Interrupt pending set. | 0           |  |  |
| 30  | ISP_PININT6          | Interrupt pending set. | 0           |  |  |
| 31  | ISP_PININT7          | Interrupt pending set. | 0           |  |  |

### Table 8. Interrupt set pending register 0 register (ISPR0, address 0xE000 E200) bit description ...continued

### 4.4.4 Interrupt Clear Pending Register 0 register

The ICPR0 register allows clearing the pending state of the peripheral interrupts, or for reading the pending state of those interrupts. Set the pending state of interrupts through the ISPR0 register (Section 4.4.3).

The bit description is as follows for all bits in this register:

Write — Writing 0 has no effect, writing 1 changes the interrupt state to not pending.

 $\ensuremath{\text{Read}}\xspace - 0$  indicates that the interrupt is not pending, 1 indicates that the interrupt is pending.

### Table 9. Interrupt clear pending register 0 register (ICPR0, address 0xE000 E280) bit description

| Bit | Symbol        | Function                 | Reset value |
|-----|---------------|--------------------------|-------------|
| 0   | ICP_SPI0      | Interrupt pending clear. | 0           |
| 1   | ICP_SPI1      | Interrupt pending clear. | 0           |
| 2   | -             | Reserved.                | -           |
| 3   | ICP_UART0     | Interrupt pending clear. | 0           |
| 4   | -             | Reserved                 | -           |
| 5   | -             | Reserved                 | -           |
| 6   | -             | Reserved.                | -           |
| 7   | -             | Reserved                 | -           |
| 8   | ICP_I2C0      | Interrupt pending clear. | 0           |
| 9   | ICP_SCT       | Interrupt pending clear. | 0           |
| 10  | ICP_MRT       | Interrupt pending clear. | 0           |
| 11  | -             | Reserved                 | -           |
| 12  | ICP_WDT       | Interrupt pending clear. | 0           |
| 13  | ICP_BOD       | Interrupt pending clear. | 0           |
| 14  | ICP_FLASH     | Interrupt pending clear. | 0           |
| 15  | ICP_WKT       | Interrupt pending clear. | 0           |
| 16  | ISP_ADC_SEQA  | Interrupt pending clear. | 0           |
| 17  | ISP_ADC_SEQB  | Interrupt pending clear. | 0           |
| 18  | ISP_ADC_THCMP | Interrupt pending clear. | 0           |
| 19  | ISP_ADC_OVR   | Interrupt pending clear. | 0           |
| 20  | ISP_SDMA      | Interrupt pending clear. | 0           |
| 21  | -             | Reserved                 | -           |
| 22  | -             | Reserved                 | -           |
| 23  | -             | Reserved.                | -           |

|     | description continued |                          |             |  |
|-----|-----------------------|--------------------------|-------------|--|
| Bit | Symbol                | Function                 | Reset value |  |
| 24  | ICP_PININT0           | Interrupt pending clear. | 0           |  |
| 25  | ICP_PININT1           | Interrupt pending clear. | 0           |  |
| 26  | ICP_PININT2           | Interrupt pending clear. | 0           |  |
| 27  | ICP_PININT3           | Interrupt pending clear. | 0           |  |
| 28  | ICP_PININT4           | Interrupt pending clear. | 0           |  |
| 29  | ICP_PININT5           | Interrupt pending clear. | 0           |  |
| 30  | ICP_PININT6           | Interrupt pending clear. | 0           |  |
| 31  | ICP_PININT7           | Interrupt pending clear. | 0           |  |

### Table 9. Interrupt clear pending register 0 register (ICPR0, address 0xE000 E280) bit description ...continued

### 4.4.5 Interrupt Active Bit Register 0

The IABR0 register is a read-only register that allows reading the active state of the peripheral interrupts. Use this register to determine which peripherals are asserting an interrupt to the NVIC and may also be pending if there are enabled.

The bit description is as follows for all bits in this register:

Write — n/a.

**Read** — 0 indicates that the interrupt is not active, 1 indicates that the interrupt is active.

| Bit | Symbol        | Function          | Reset value |
|-----|---------------|-------------------|-------------|
| 0   | IAB_SPI0      | Interrupt active. | 0           |
| 1   | IAB_SPI1      | Interrupt active. | 0           |
| 2   | -             | Reserved.         | -           |
| 3   | IAB_UART0     | Interrupt active. | 0           |
| 4   | -             | Reserved          | -           |
| 5   | -             | Reserved          | -           |
| 6   | -             | Reserved.         | -           |
| 7   | -             | Reserved          | -           |
| 8   | IAB_I2C0      | Interrupt active. | 0           |
| 9   | IAB_SCT       | Interrupt active. | 0           |
| 10  | IAB_MRT       | Interrupt active. | 0           |
| 11  | -             | Reserved          | -           |
| 12  | IAB_WDT       | Interrupt active. | 0           |
| 13  | IAB_BOD       | Interrupt active. | 0           |
| 14  | IAB_FLASH     | Interrupt active. | 0           |
| 15  | IAB_WKT       | Interrupt active. | 0           |
| 16  | ISP_ADC_SEQA  | Interrupt active. | 0           |
| 17  | ISP_ADC_SEQB  | Interrupt active. | 0           |
| 18  | ISP_ADC_THCMP | Interrupt active. | 0           |
| 19  | ISP_ADC_OVR   | Interrupt active. | 0           |
| 20  | ISP_SDMA      | Interrupt active. | 0           |

 Table 10.
 Interrupt Active Bit Register 0 (IABR0, address 0xE000 E300) bit description

### Chapter 4: LPC83x Nested Vectored Interrupt Controller (NVIC)

| Bit | Symbol      | Function          | Reset value |
|-----|-------------|-------------------|-------------|
| 21  | -           | Reserved          | -           |
| 22  | -           | Reserved          | -           |
| 23  | -           | Reserved.         | -           |
| 24  | IAB_PININT0 | Interrupt active. | 0           |
| 25  | IAB_PININT1 | Interrupt active. | 0           |
| 26  | IAB_PININT2 | Interrupt active. | 0           |
| 27  | IAB_PININT3 | Interrupt active. | 0           |
| 28  | IAB_PININT4 | Interrupt active. | 0           |
| 29  | IAB_PININT5 | Interrupt active. | 0           |
| 30  | IAB_PININT6 | Interrupt active. | 0           |
| 31  | IAB_PININT7 | Interrupt active. | 0           |

 Table 10.
 Interrupt Active Bit Register 0 (IABR0, address 0xE000 E300) bit description

### 4.4.6 Interrupt Priority Register 0

The IPR0 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol   | Description                                                    |
|-------|----------|----------------------------------------------------------------|
| 5:0   | -        | These bits ignore writes, and read as 0.                       |
| 7:6   | IP_SPI0  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 13:8  | -        | These bits ignore writes, and read as 0.                       |
| 15:14 | IP_SPI1  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 21:16 | -        | These bits ignore writes, and read as 0.                       |
| 23:22 | -        | Reserved.                                                      |
| 29:24 | -        | Reserved.                                                      |
| 31:30 | IP_UART0 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |

 Table 11.
 Interrupt Priority Register 0 (IPR0, address 0xE000 E400) bit description

### 4.4.7 Interrupt Priority Register 2

The IPR2 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol  | Description                                                    |
|-------|---------|----------------------------------------------------------------|
| 5:0   | -       | These bits ignore writes, and read as 0.                       |
| 7:6   | IP_I2C0 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 13:8  | -       | These bits ignore writes, and read as 0.                       |
| 15:14 | IP_SCT  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 21:16 | -       | These bits ignore writes, and read as 0.                       |
| 23:22 | IP_MRT  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 29:24 | -       | These bits ignore writes, and read as 0.                       |
| 31:30 | -       | Reserved.                                                      |

### 4.4.8 Interrupt Priority Register 3

The IPR3 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol   | Description                                                    |
|-------|----------|----------------------------------------------------------------|
| 5:0   | -        | These bits ignore writes, and read as 0.                       |
| 7:6   | IP_WDT   | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 13:8  | -        | These bits ignore writes, and read as 0.                       |
| 15:14 | IP_BOD   | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 21:16 | -        | These bits ignore writes, and read as 0.                       |
| 23:22 | IP_FLASH | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 29:24 | -        | These bits ignore writes, and read as 0.                       |
| 31:30 | IP_WKT   | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |

 Table 13.
 Interrupt Priority Register 3 (IPR3, address 0xE000 E40C) bit description

### 4.4.9 Interrupt Priority Register 4

The IPR3 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol       | Description                                                    |
|-------|--------------|----------------------------------------------------------------|
| 5:0   | -            | These bits ignore writes, and read as 0.                       |
| 7:6   | IP_ADC_SEQA  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 13:8  | -            | These bits ignore writes, and read as 0.                       |
| 15:14 | IP_ADC_SEQB  | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 21:16 | -            | These bits ignore writes, and read as 0.                       |
| 23:22 | IP_ADC_THCMP | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |
| 29:24 | -            | These bits ignore writes, and read as 0.                       |
| 31:30 | IP_ADC_OVR   | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |

Table 14. Interrupt Priority Register 4 (IPR4, address 0xE000 E410) bit description

### 4.4.10 Interrupt Priority Register 5

The IPR3 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol | Description                                                    |  |  |
|-------|--------|----------------------------------------------------------------|--|--|
| 5:0   | -      | These bits ignore writes, and read as 0.                       |  |  |
| 7:6   | IP_DMA | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |
| 13:8  | -      | hese bits ignore writes, and read as 0.                        |  |  |
| 15:14 | -      | Reserved.                                                      |  |  |
| 21:16 | -      | These bits ignore writes, and read as 0.                       |  |  |
| 23:22 | -      | Reserved.                                                      |  |  |
| 29:24 | -      | Reserved.                                                      |  |  |
| 31:30 | -      | Reserved.                                                      |  |  |

### 4.4.11 Interrupt Priority Register 6

The IPR6 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol     | Description                                                    |  |  |  |  |
|-------|------------|----------------------------------------------------------------|--|--|--|--|
| 5:0   | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 7:6   | IP_PININT0 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |
| 13:8  | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 15:14 | IP_PININT1 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |
| 21:16 | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 23:22 | IP_PININT2 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |
| 29:24 | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 31:30 | IP_PININT3 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |

 Table 16.
 Interrupt Priority Register 6 (IPR6, address 0xE000 E418) bit description

### 4.4.12 Interrupt Priority Register 7

The IPR7 register controls the priority of four peripheral interrupts. Each interrupt can have one of 4 priorities, where 0 is the highest priority.

| Bit   | Symbol     | Description                                                    |  |  |  |  |
|-------|------------|----------------------------------------------------------------|--|--|--|--|
| 5:0   | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 7:6   | IP_PININT4 | terrupt Priority. 0 = highest priority. 3 = lowest priority.   |  |  |  |  |
| 13:8  | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 15:14 | IP_PININT5 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |
| 21:16 | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 23:22 | IP_PININT6 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |
| 29:24 | -          | These bits ignore writes, and read as 0.                       |  |  |  |  |
| 31:30 | IP_PININT7 | Interrupt Priority. 0 = highest priority. 3 = lowest priority. |  |  |  |  |

Table 17. Interrupt Priority Register 7 (IPR7, address 0xE000 E41C) bit description

Chapter 5: LPC83x System configuration (SYSCON)

Rev. 1.1 — 5 October 2016

**User manual** 

### 5.1 How to read this chapter

The system configuration block is identical for all LPC820 parts.

### 5.2 Features

- Clock control
  - Configure the system PLL.
  - Configure system oscillator and watchdog oscillator.
  - Enable clocks to individual peripherals and memories.
  - Configure clock output.
  - Configure clock dividers, digital filter clock, and USART baud rate clock.
- Monitor and release reset to individual peripherals.
- Select pins for external pin interrupts and pattern match engine.
- Configuration of reduced power modes.
- Wake-up control.
- BOD configuration.
- MTB trace start and stop.
- Interrupt latency control.
- Select a source for the NMI.
- Calibrate system tick timer.

### 5.3 Basic configuration

Configure the SYSCON block as follows:

- The SYSCON uses the CLKIN, CLKOUT, RESET, and XTALIN/OUT pins. Configure the pin functions through the switch matrix. See <u>Section 5.4</u>.
- No clock configuration is needed. The clock to the SYSCON block is always enabled. By default, the SYSCON block is clocked by the IRC.

### 5.3.1 Set up the PLL

The PLL creates a stable output clock at a higher frequency than the input clock. If you need a main clock with a frequency higher than the 12 MHz IRC clock, use the PLL to boost the input frequency.

1. Power up the system PLL in the PDRUNCFG register.

Section 5.6.33 "Power configuration register"

Select the PLL input in the SYSPLLCLKSEL register. You have the following input options:

- IRC: 12 MHz internal oscillator.
- System oscillator: External crystal oscillator using the XTALIN/XTALOUT pins.
- External clock input CLKIN. Select this pin through the switch matrix.
- Section 5.6.9 "System PLL clock source select register"
- 3. Update the PLL clock source in the SYSPLLCLKUEN register. Section 5.6.10 "System PLL clock source update register"
- 4. Configure the PLL M and N dividers. Section 5.6.3 "System PLL control register"
- 5. Wait for the PLL to lock by monitoring the PLL lock status. Section 5.6.4 "System PLL status register"

### 5.3.2 Configure the main clock and system clock

The clock source for the registers and memories is derived from main clock. The main clock can be sourced from the IRC at a fixed clock frequency of 12 MHz or from the PLL.

The divided main clock is called the system clock and clocks the core, the memories, and the peripherals (register interfaces and peripheral clocks).

- 1. Select the main clock. You have the following options:
  - IRC: 12 MHz internal oscillator (default).
  - PLL output: You must configure the PLL to use the PLL output.

Section 5.6.11 "Main clock source select register"

2. Update the main clock source.

Section 5.6.12 "Main clock source update enable register"

3. Select the divider value for the system clock. A divider value of 0 disables the system clock.

Section 5.6.13 "System clock divider register"

4. Select the memories and peripherals that are operating in your application and therefore must have an active clock. The core is always clocked.

Section 5.6.14 "System clock control register"

### 5.3.3 Set up the system oscillator using XTALIN and XTALOUT

To use the system oscillator with the LPC800, you need to assign the XTALIN and XTALOUT pins, which connect to the external crystal, through the fixed-pin function in the switch matrix. XTALIN and XTALOUT can only be assigned to pins PIO0\_8 and PIO0\_9.

- 1. In the IOCON block, remove the pull-up and pull-down resistors in the IOCON registers for pins PIO0\_8 and PIO0\_9.
- 2. In the switch matrix block, enable the 1-bit functions for XTALIN and XTALOUT.
- 3. In the SYSOSCCTRL register, disable the BYPASS bit and select the oscillator frequency range according to the desired oscillator output clock.

Related registers:

Table 93 "PIO0\_8 register (PIO0\_8, address 0x4004 4038) bit description"

**User manual** 

© NXP Semiconductors N.V. 2016. All rights reserved.

Table 92 "PIO0\_9 register (PIO0\_9, address 0x4004 4034) bit description"

Table 76 "Pin enable register 0 (PINENABLE0, address 0x4000 C1C0) bit description"

Table 24 "System oscillator control register (SYSOSCCTRL, address 0x4004 8020) bit description"

### 5.4 Pin description

The SYSCON inputs and outputs are assigned to external pins through the switch matrix.

See <u>Section 7.3.1 "Connect an internal signal to a package pin"</u> to assign the CLKOUT function to a pin.

See <u>Section 7.3.2</u> to enable the clock input, the oscillator pins, and the external reset input.

Table 18. SYSCON pin description

| Function | Direction | Pin            | Description                             | SWM register | Reference |
|----------|-----------|----------------|-----------------------------------------|--------------|-----------|
| CLKOUT   | 0         | any            | CLKOUT clock output.                    | PINASSIGN8   | Table 72  |
| CLKIN    | 1         | PIO0_1/CLKIN   | External clock input to the system PLL. | PINENABLE0   | Table 76  |
| XTALIN   | I         | PIO0_8/XTALIN  | Input to the system oscillator.         | PINENABLE0   | Table 76  |
| XTALOUT  | 0         | PIO0_9/XTALOUT | Output from the system oscillator.      | PINENABLE0   | Table 76  |
| RESET    | I         | RESET/PIO0_5   | External reset input                    | PINENABLE0   | Table 76  |

### 5.5 General description

### 5.5.1 Clock generation

The system control block generates all clocks for the chip. Only the low-power oscillator used for wake-up timing is controlled by the PMU. Except for the USART clock and the clock to configure the glitch filters of the digital I/O pins, the clocks to the core and peripherals run at the same frequency. The maximum system clock frequency is 30 MHz. See Figure 4.

Remark: The main clock frequency is limited to 100 MHz.

UM11021



### 5.5.2 Power control of analog components

The system control block controls the power to the analog components such as the oscillators and PLL, and the BOD. For details, see the following registers:

Section 5.6.31 "Deep-sleep mode configuration register"

Section 5.6.3 "System PLL control register"

Section 5.6.6 "Watchdog oscillator control register"

Section 5.6.5 "System oscillator control register"

### 5.5.3 Configuration of reduced power-modes

The system control block configures analog blocks that can remain running in the reduced power modes (the BOD and the watchdog oscillator for safe operation) and enables various interrupts to wake up the chip when the internal clocks are shut down in Deep-sleep and Power-down modes. For details, see the following registers:

Section 5.6.33 "Power configuration register"

Section 5.6.30 "Start logic 1 interrupt wake-up enable register"

### 5.5.4 Reset and interrupt control

The peripheral reset control register in the system control register allows to assert and release individual peripheral resets. See <u>Table 21</u>.

Up to eight external pin interrupts can be assigned to any digital pin in the system control block (see <u>Section 5.6.28 "Pin interrupt select registers</u>").

### 5.6 Register description

All system control block registers reside on word address boundaries. Details of the registers appear in the description of each function.

Reset values describe the content of the registers after the bootloader has executed.

All address offsets not shown in <u>Table 19</u> are reserved and should not be written to.

| Table 19. | Register overview: | System configuration | (base address 0x4004 8000) |
|-----------|--------------------|----------------------|----------------------------|
|-----------|--------------------|----------------------|----------------------------|

| Name          | Access | Offset | Description                           | Reset value | Reset<br>value<br>after boot | Reference |
|---------------|--------|--------|---------------------------------------|-------------|------------------------------|-----------|
| SYSMEMREMAP   | R/W    | 0x000  | System memory remap                   | 0x2         |                              | Table 20  |
| PRESETCTRL    | R/W    | 0x004  | Peripheral reset control              | 0x0001 FFFF |                              | Table 21  |
| SYSPLLCTRL    | R/W    | 0x008  | System PLL control                    | 0           |                              | Table 22  |
| SYSPLLSTAT    | R      | 0x00C  | System PLL status                     | 0           |                              | Table 23  |
| -             | -      | 0x010  | Reserved                              | -           |                              | -         |
| -             | -      | 0x014  | Reserved                              | -           |                              | -         |
| SYSOSCCTRL    | R/W    | 0x020  | System oscillator control             | 0x000       |                              | Table 24  |
| WDTOSCCTRL    | R/W    | 0x024  | Watchdog oscillator control           | 0x0A0       |                              | Table 25  |
| IRCCTRL       | R/W    | 0x028  | IRC control                           | 0x080       |                              | Table 26  |
| -             | -      | 0x02C  | Reserved                              | -           |                              | -         |
| SYSRSTSTAT    | R/W    | 0x030  | System reset status register          | 0           |                              | Table 27  |
| SYSPLLCLKSEL  | R/W    | 0x040  | System PLL clock source select        | 0           |                              | Table 28  |
| SYSPLLCLKUEN  | R/W    | 0x044  | System PLL clock source update enable | 0           |                              | Table 29  |
| MAINCLKSEL    | R/W    | 0x070  | Main clock source select              | 0           |                              | Table 30  |
| MAINCLKUEN    | R/W    | 0x074  | Main clock source update enable       | 0           |                              | Table 31  |
| SYSAHBCLKDIV  | R/W    | 0x078  | System clock divider                  | 1           |                              | Table 32  |
| SYSAHBCLKCTRL | R/W    | 0x080  | System clock control                  | 0xDF        |                              | Table 33  |
| UARTCLKDIV    | R/W    | 0x094  | USART clock divider                   | 0           |                              | Table 34  |

UM11021

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

© NXP Semiconductors N.V. 2016. All rights reserved.

| Table 19.              | Register                                                                                    | overview | : System                                                             | configuration (base address 0x4004 800                                 | 00)continued      |                              |                 |
|------------------------|---------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------|------------------------------------------------------------------------|-------------------|------------------------------|-----------------|
| Name                   |                                                                                             | Access   | Offset                                                               | Description                                                            | Reset value       | Reset<br>value<br>after boot | Reference       |
| -                      |                                                                                             | -        | 0x098                                                                | Reserved                                                               | -                 |                              | -               |
| -                      |                                                                                             | -        | 0x09C                                                                | Reserved                                                               | -                 |                              | -               |
| -                      |                                                                                             | -        | 0x0A0 -<br>0x0BC                                                     | Reserved                                                               | -                 |                              | -               |
| -                      |                                                                                             | -        | 0x0CC                                                                | Reserved                                                               | -                 |                              | -               |
| CLKOUTS                | SEL                                                                                         | R/W      | 0x0E0                                                                | CLKOUT clock source select                                             | 0                 |                              | Table 35        |
| CLKOUTI                | JEN                                                                                         | R/W      | 0x0E4                                                                | CLKOUT clock source update enable                                      | 0                 |                              | Table 36        |
| CLKOUTE                | NIV                                                                                         | R/W      | 0x0E8                                                                | CLKOUT clock divider                                                   | 0                 |                              | Table 37        |
| UARTFRO                | GDIV                                                                                        | R/W      | 0x0F0                                                                | USART0 common fractional generator divider value                       | 0                 |                              | Table 38        |
| UARTFRO                | GMULT                                                                                       | R/W      | 0x0F4                                                                | USART0 common fractional generator multiplier value                    | 0                 |                              | Table 39        |
| EXTTRAC                | CECMD                                                                                       | R/W      | 0x0FC                                                                | External trace buffer command register                                 | 0                 |                              | Table 40        |
| PIOPORC                | CAP0                                                                                        | R        | 0x100                                                                | POR captured PIO status 0                                              | user<br>dependent |                              | Table 41        |
| -                      |                                                                                             | -        | 0x104                                                                | Reserved                                                               | -                 |                              | -               |
| IOCONCLKDIV6 R/W 0x134 |                                                                                             | 0x134    | Peripheral clock 6 to the IOCON block for programmable glitch filter | 0                                                                      |                   | Table 42                     |                 |
| IOCONCL                | CONCLKDIV5 R/W 0x138 Peripheral clock 5 to the IOCON block for 0 programmable glitch filter |          |                                                                      | Table 42                                                               |                   |                              |                 |
| IOCONCL                | KDIV4                                                                                       | R/W      | 0x13C                                                                | Peripheral clock 4 to the IOCON block for programmable glitch filter   | 0                 |                              | Table 42        |
| IOCONCL                | KDIV3                                                                                       | R/W      | 0x140                                                                | Peripheral clock 3 to the IOCON block for programmable glitch filter   | 0                 |                              | Table 42        |
| IOCONCL                | KDIV2                                                                                       | R/W      | 0x144                                                                | Peripheral clock 2 to the IOCON block for programmable glitch filter   | 0                 |                              | Table 42        |
| IOCONCL                | KDIV1                                                                                       | R/W      | 0x148                                                                | Peripheral clock 1 to the IOCON block for programmable glitch filter   | 0                 |                              | Table 42        |
| IOCONCL                | KDIV0                                                                                       | R/W      | 0x14C                                                                | Peripheral clock 0 to the IOCON block for programmable glitch filter   | 0                 |                              | <u>Table 42</u> |
| BODCTRI                | L                                                                                           | R/W      | 0x150                                                                | Brown-Out Detect                                                       | 0                 |                              | Table 43        |
| SYSTCK                 | CAL                                                                                         | R/W      | 0x154                                                                | System tick counter calibration                                        | 0                 |                              | Table 44        |
| -                      |                                                                                             | R/W      | 0x168                                                                | Reserved                                                               | -                 |                              | -               |
| IRQLATEI               | NCY                                                                                         | R/W      | 0x170                                                                | IQR delay. Allows trade-off between interrupt latency and determinism. | 0x0000 0010       |                              | Table 45        |
| NMISRC                 |                                                                                             | R/W      | 0x174                                                                | NMI Source Control                                                     | 0                 |                              | Table 46        |
| PINTSEL                | C                                                                                           | R/W      | 0x178                                                                | GPIO Pin Interrupt Select register 0                                   | 0                 |                              | Table 47        |
| PINTSEL                | 1                                                                                           | R/W      | 0x17C                                                                | GPIO Pin Interrupt Select register 1                                   | 0                 |                              | Table 47        |
| PINTSEL                | 2                                                                                           | R/W      | 0x180                                                                | GPIO Pin Interrupt Select register 2                                   | 0                 |                              | Table 47        |
| PINTSEL                | 3                                                                                           | R/W      | 0x184                                                                | GPIO Pin Interrupt Select register 3                                   | 0                 |                              | Table 47        |
| PINTSEL                | 4                                                                                           | R/W      | 0x188                                                                | GPIO Pin Interrupt Select register 4                                   | 0                 |                              | Table 47        |
| PINTSEL                | 5                                                                                           | R/W      | 0x18C                                                                | GPIO Pin Interrupt Select register 5                                   | 0                 |                              | Table 47        |
| PINTSEL                | 6                                                                                           | R/W      | 0x190                                                                | GPIO Pin Interrupt Select register 6                                   | 0                 |                              | Table 47        |

### Table 19. Register overview: System configuration (base address 0x4004 8000) ...continued

UM11021

© NXP Semiconductors N.V. 2016. All rights reserved.

| Name Access Offset |     | Offset | Description                                     | Reset value                                | Reset<br>value<br>after boot | Reference |  |
|--------------------|-----|--------|-------------------------------------------------|--------------------------------------------|------------------------------|-----------|--|
| PINTSEL7           | R/W | 0x194  | GPIO Pin Interrupt Select register 7            | 0                                          |                              | Table 47  |  |
| STARTERP0          | R/W | 0x204  | Start logic 0 pin wake-up enable register       | tart logic 0 pin wake-up enable register 0 |                              | Table 48  |  |
| STARTERP1          | R/W | 0x214  | Start logic 1 interrupt wake-up enable register | 0                                          |                              | Table 49  |  |
| PDSLEEPCFG         | R/W | 0x230  | Power-down states in deep-sleep mode            | 0xFFFF                                     |                              | Table 50  |  |
| PDAWAKECFG         | R/W | 0x234  | Power-down states for wake-up from deep-sleep   | 0xEDF0                                     |                              | Table 51  |  |
| PDRUNCFG           | R/W | 0x238  | Power configuration register                    | 0xEDF0                                     |                              | Table 52  |  |
| DEVICE_ID          | R   | 0x3F8  | Device ID                                       | part<br>dependent                          |                              | Table 53  |  |

| Table 19. | Register overview: | System configuration | (base address 0x4004 8000) | continued |
|-----------|--------------------|----------------------|----------------------------|-----------|
|-----------|--------------------|----------------------|----------------------------|-----------|

### 5.6.1 System memory remap register

The system memory remap register selects whether the exception vectors are read from boot ROM, flash, or SRAM. By default, the flash memory is mapped to address 0x0000 0000. When the MAP bits in the SYSMEMREMAP register are set to 0x0 or 0x1, the boot ROM or RAM respectively are mapped to the bottom 512 bytes of the memory map (addresses 0x0000 0000 to 0x0000 0200).

 Table 20.
 System memory remap register (SYSMEMREMAP, address 0x4004 8000) bit description

| Bit                                | Symbol                                                               | Value | Description                                                               | Reset<br>value |
|------------------------------------|----------------------------------------------------------------------|-------|---------------------------------------------------------------------------|----------------|
| 1:0                                | 1:0 MAP                                                              |       | System memory remap. Value 0x3 is reserved.                               | 0x2            |
|                                    | 0x0 Bootloader Mode. Interrupt vectors are re-mapped to Boot<br>ROM. |       |                                                                           |                |
| 0x1 User RAM Mode. Interru<br>RAM. |                                                                      | 0x1   | User RAM Mode. Interrupt vectors are re-mapped to Static RAM.             |                |
|                                    |                                                                      | 0x2   | User Flash Mode. Interrupt vectors are not re-mapped and reside in Flash. |                |
| 31:2                               | -                                                                    | -     | Reserved                                                                  | -              |

### 5.6.2 Peripheral reset control register

The PRESETCTRL register allows software to reset specific peripherals. A zero in any assigned bit in this register resets the specified peripheral. A 1 clears the reset and allows the peripheral to operate.

 Table 21.
 Peripheral reset control register (PRESETCTRL, address 0x4004 8004) bit description

| Bit | Symbol     | Value | Description            | Reset<br>value |
|-----|------------|-------|------------------------|----------------|
| 0   | SPI0_RST_N |       | SPI0 reset control     | 1              |
|     |            | 0     | Assert the SPI0 reset. |                |
|     |            | 1     | Clear the SPI0 reset.  |                |

| Bit   | Symbol        | Value | Description                                                     | Reset<br>value |
|-------|---------------|-------|-----------------------------------------------------------------|----------------|
|       |               |       |                                                                 |                |
| 1     | SPI1_RST_N    |       | SPI1 reset control                                              | 1              |
|       |               | 0     | Assert the SPI1 reset.                                          |                |
|       |               | 1     | Clear the SPI1 reset.                                           |                |
| 2     | UARTFRG_RST_N |       | USART fractional baud rate generator<br>(UARTFRG) reset control | 1              |
|       |               | 0     | Assert the UARTFRG reset.                                       |                |
|       |               | 1     | Clear the UARTFRG reset.                                        |                |
| 3     | UART0_RST_N   |       | USART0 reset control                                            | 1              |
|       |               | 0     | Assert the USART0 reset.                                        |                |
|       |               | 1     | Clear the USART0 reset.                                         |                |
| 5:4   | -             | -     | Reserved                                                        |                |
| 6     | I2C0_RST_N    |       | I2C0 reset control                                              | 1              |
|       |               | 0     | Assert the I2C0 reset.                                          |                |
|       |               | 1     | Clear the I2C0 reset.                                           |                |
| 7     | MRT_RST_N     |       | Multi-rate timer (MRT) reset control                            | 1              |
|       |               | 0     | Assert the MRT reset.                                           |                |
|       |               | 1     | Clear the MRT reset.                                            |                |
| 8     | SCT_RST_N     |       | SCT reset control                                               | 1              |
|       |               | 0     | Assert the SCT reset.                                           |                |
|       |               | 1     | Clear the SCT reset.                                            |                |
| 9     | WKT_RST_N     |       | Self-wake-up timer (WKT) reset control                          | 1              |
|       |               | 0     | Assert the WKT reset.                                           |                |
|       |               | 1     | Clear the WKT reset.                                            |                |
| 10    | GPIO_RST_N    |       | GPIO and GPIO pin interrupt reset control                       | 1              |
|       |               | 0     | Assert the GPIO reset.                                          |                |
|       |               | 1     | Clear the GPIO reset.                                           |                |
| 11    | FLASH_RST_N   |       | Flash controller reset control                                  | 1              |
|       |               | 0     | Assert the flash controller reset.                              |                |
|       |               | 1     | Clear the flash controller reset.                               |                |
| 23:12 | -             |       | Reserved                                                        | -              |
| 24    | ADC_RST_N     |       | ADC reset control                                               | 1              |
|       |               | 0     | Assert the ADC reset.                                           |                |
|       |               | 1     | Clear the ADC reset.                                            |                |
| 28:25 | -             | -     | Reserved                                                        | -              |
| 29    | DMA_RST_N     |       | DMA reset control                                               | 1              |
|       |               | 0     | Assert the DMA reset.                                           |                |
|       |               | 1     | Clear the DMA reset.                                            |                |
| 31:30 | -             | -     | Reserved                                                        | -              |

### Table 21. Peripheral reset control register (PRESETCTRL, address 0x4004 8004) bit description

UM11021

### 5.6.3 System PLL control register

This register connects and enables the system PLL and configures the PLL multiplier and divider values. The PLL accepts an input frequency from 10 MHz to 25 MHz from various clock sources. The input frequency is multiplied to a higher frequency and then divided down to provide the actual clock used by the CPU, peripherals, and memories. The PLL can produce a clock up to the maximum allowed for the CPU.

**Remark:** The divider values for P and M must be selected so that the PLL output clock frequency FCLKOUT is lower than 100 MHz.

| Bit  | Symbol | Value | Description                                                                                                                                            | Reset<br>value |  |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|
| 4:0  | MSEL   |       | Feedback divider value. The division value M is the<br>programmed MSEL value + 1.<br>00000: Division ratio M = 1<br>to<br>11111: Division ratio M = 32 | 0              |  |
| 6:5  | PSEL   |       | Post divider ratio P. The division ratio is $2 \times P$ .                                                                                             | 0              |  |
|      |        | 0x0   | P = 1                                                                                                                                                  |                |  |
|      |        | 0x1   | P = 2                                                                                                                                                  |                |  |
|      |        | 0x2   | P = 4                                                                                                                                                  |                |  |
|      |        | 0x3   | P = 8                                                                                                                                                  |                |  |
| 31:7 | -      | -     | Reserved. Do not write ones to reserved bits.                                                                                                          |                |  |

### Table 22. System PLL control register (SYSPLLCTRL, address 0x4004 8008) bit description

### 5.6.4 System PLL status register

This register is a Read-only register and supplies the PLL lock status (see <u>Section 5.7.4.1</u>).

### Table 23. System PLL status register (SYSPLLSTAT, address 0x4004 800C) bit description

| Bit  | Symbol | Value | Description     | Reset<br>value |
|------|--------|-------|-----------------|----------------|
| 0    | LOCK   |       | PLL lock status | 0              |
|      |        | 0     | PLL not locked  | -              |
|      |        | 1     | PLL locked      | -              |
| 31:1 | -      | -     | Reserved        | -              |

### 5.6.5 System oscillator control register

This register configures the frequency range for the system oscillator. The system oscillator itself is powered on or off in the PDRUNCFG register. See Table 52.

|      | description |       |                                                                                                                                                                                              |                |  |  |  |  |  |
|------|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|--|--|
| Bit  | Symbol      | Value | Description                                                                                                                                                                                  | Reset<br>value |  |  |  |  |  |
| 0    | BYPASS      |       | Bypass system oscillator                                                                                                                                                                     | 0x0            |  |  |  |  |  |
|      |             | 0     | Disabled. Oscillator is not bypassed.                                                                                                                                                        |                |  |  |  |  |  |
|      |             | 1     | Enabled. PLL input (sys_osc_clk) is fed directly<br>from the XTALIN pin bypassing the oscillator. Use<br>this mode when using an external clock source<br>instead of the crystal oscillator. | r. Üse         |  |  |  |  |  |
| 1    | FREQRANGE   |       | Determines oscillator frequency range.                                                                                                                                                       | 0x0            |  |  |  |  |  |
|      |             | 0     | 1 - 20 MHz frequency range.                                                                                                                                                                  |                |  |  |  |  |  |
|      |             | 1     | 15 - 25 MHz frequency range                                                                                                                                                                  |                |  |  |  |  |  |
| 31:2 | -           | -     | Reserved                                                                                                                                                                                     | 0x00           |  |  |  |  |  |
|      |             |       |                                                                                                                                                                                              |                |  |  |  |  |  |

 Table 24.
 System oscillator control register (SYSOSCCTRL, address 0x4004 8020) bit description

#### 5.6.6 Watchdog oscillator control register

This register configures the watchdog oscillator. The oscillator consists of an analog and a digital part. The analog part contains the oscillator function and generates an analog clock (Fclkana). With the digital part, the analog output clock (Fclkana) can be divided to the required output clock frequency wdt\_osc\_clk. The analog output frequency (Fclkana) can be adjusted with the FREQSEL bits between 600 kHz and 4.6 MHz. With the digital part Fclkana will be divided (divider ratios = 2, 4,...,64) to wdt\_osc\_clk using the DIVSEL bits.

The output clock frequency of the watchdog oscillator can be calculated as wdt\_osc\_clk = Fclkana/( $2 \times (1 + DIVSEL)$ ) = 9.3 kHz to 2.3 MHz (nominal values).

**Remark:** Any setting of the FREQSEL bits will yield a Fclkana value within  $\pm 40\%$  of the listed frequency value. The watchdog oscillator is the clock source with the lowest power consumption. If accurate timing is required, use the IRC or system oscillator.

**Remark:** The frequency of the watchdog oscillator is undefined after reset. The watchdog oscillator frequency must be programmed by writing to the WDTOSCCTRL register before using the watchdog oscillator.

| Bit | Symbol | Value | Description                                                                                                                                                                  | Reset<br>value |
|-----|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 4:0 | DIVSEL |       | Select divider for Fclkana.<br>wdt_osc_clk = Fclkana/ (2 × (1 + DIVSEL))<br>00000: 2 × (1 + DIVSEL) = 2<br>00001: 2 × (1 + DIVSEL) = 4<br>to<br>11111: 2 × (1 + DIVSEL) = 64 | 0              |

| Table 25. | Watchdog oscillator control register (WDTOSCCTRL, address 0x4004 8024) bit |
|-----------|----------------------------------------------------------------------------|
|           | description                                                                |

| Bit  | Symbol  | Value | Description                                                   | Reset<br>value |
|------|---------|-------|---------------------------------------------------------------|----------------|
| 8:5  | FREQSEL |       | Select watchdog oscillator analog output frequency (Fclkana). | 0x00           |
|      |         | 0x1   | 0.6 MHz                                                       |                |
|      |         | 0x2   | 1.05 MHz                                                      |                |
|      |         | 0x3   | 1.4 MHz                                                       |                |
|      |         | 0x4   | 1.75 MHz                                                      |                |
|      |         | 0x5   | 2.1 MHz                                                       |                |
|      |         | 0x6   | 2.4 MHz                                                       |                |
|      |         | 0x7   | 2.7 MHz                                                       |                |
|      |         | 0x8   | 3.0 MHz                                                       |                |
|      |         | 0x9   | 3.25 MHz                                                      |                |
|      |         | 0xA   | 3.5 MHz                                                       |                |
|      |         | 0xB   | 3.75 MHz                                                      |                |
|      |         | 0xC   | 4.0 MHz                                                       |                |
|      |         | 0xD   | 4.2 MHz                                                       |                |
|      |         | 0xE   | 4.4 MHz                                                       |                |
|      |         | 0xF   | 4.6 MHz                                                       |                |
| 31:9 | -       | -     | Reserved                                                      | 0x00           |

## Table 25. Watchdog oscillator control register (WDTOSCCTRL, address 0x4004 8024) bit description

### 5.6.7 Internal resonant crystal control register

This register can be used to re-trim the on-chip 12 MHz oscillator. Note that the factory-preset trim value is written to this register by the boot code on start-up.

 Table 26.
 Internal resonant crystal control register (IRCCTRL, address 0x4004 8028) bit description

| Bit  | Symbol | Description | Reset value                     |
|------|--------|-------------|---------------------------------|
| 7:0  | TRIM   | Trim value  | 0x80, then flash will reprogram |
| 31:8 | -      | Reserved    | 0x00                            |

#### 5.6.8 System reset status register

The SYSRSTSTAT register shows the source of the latest reset event. The bits are cleared by writing a one to any of the bits. The POR event clears all other bits in this register. If another reset signal - for example the external RESET pin - remains asserted after the POR signal is negated, then its bit is set to detected. Write a one to clear the reset.

The reset value given in Table 27 applies to the POR reset.

| Bit  | Symbol | Value | Description                                              | Reset<br>value |
|------|--------|-------|----------------------------------------------------------|----------------|
| 0    | POR    |       | POR reset status                                         | 0              |
|      |        | 0     | No POR detected                                          |                |
|      |        | 1     | POR detected. Writing a one clears this reset.           |                |
| 1    | EXTRST |       | Status of the external RESET pin. External reset status. | 0              |
|      |        | 0     | No reset event detected.                                 |                |
|      |        | 1     | Reset detected. Writing a one clears this reset.         |                |
| 2    | WDT    |       | Status of the Watchdog reset                             | 0              |
|      |        | 0     | No WDT reset detected                                    |                |
|      |        | 1     | WDT reset detected. Writing a one clears this reset.     |                |
| 3    | BOD    |       | Status of the Brown-out detect reset                     | 0              |
|      |        | 0     | No BOD reset detected                                    |                |
|      |        | 1     | BOD reset detected. Writing a one clears this reset.     |                |
| 4    | SYSRST |       | Status of the software system reset                      | 0              |
|      |        | 0     | No System reset detected                                 |                |
|      |        | 1     | System reset detected. Writing a one clears this reset.  |                |
| 31:5 | -      | -     | Reserved                                                 | -              |

Table 27. System reset status register (SYSRSTSTAT, address 0x4004 8030) bit description

#### 5.6.9 System PLL clock source select register

This register selects the clock source for the system PLL. The SYSPLLCLKUEN register (see Section 5.6.10) must be toggled from LOW to HIGH for the update to take effect.

|      | Dit ues | scription |                              |                |
|------|---------|-----------|------------------------------|----------------|
| Bit  | Symbol  | Value     | Description                  | Reset<br>value |
| 1:0  | SEL     |           | System PLL clock source      | 0              |
|      |         | 0x0       | IRC                          |                |
|      |         | 0x1       | Crystal Oscillator (SYSOSC)  |                |
|      |         | 0x2       | Reserved.                    |                |
|      |         | 0x3       | CLKIN. External clock input. |                |
| 31:2 | -       | -         | Reserved                     | -              |

## Table 28. System PLL clock source select register (SYSPLLCLKSEL, address 0x4004 8040) bit description

#### 5.6.10 System PLL clock source update register

This register updates the clock source of the system PLL with the new input clock after the SYSPLLCLKSEL register has been written to. In order for the update to take effect, first write a zero to the SYSPLLUEN register and then write a one to SYSPLLUEN.

#### Table 29. System PLL clock source update enable register (SYSPLLCLKUEN, address 0x4004 8044) bit description

| Bit  | Symbol | Value | Description                           | Reset value |
|------|--------|-------|---------------------------------------|-------------|
| 0    | ENA    |       | Enable system PLL clock source update | 0           |
|      |        | 0     | No change                             |             |
|      |        | 1     | Update clock source                   |             |
| 31:1 | -      | -     | Reserved                              | -           |

#### 5.6.11 Main clock source select register

This register selects the main system clock, which can be the system PLL (sys\_pllclkout), or the watchdog oscillator, or the IRC oscillator. The main system clock clocks the core, the peripherals, and the memories.

Bit 0 of the MAINCLKUEN register (see Section 5.6.12) must be toggled from 0 to 1 for the update to take effect.

| Table 30 | ). |  | ock s | ouro | ce s | sel | ect | t re | eg | jis | te | r ( | (№ | ۸A | 41 | N | IC | Ľ | .K | S | SE | EL | -, | ac | lc | r | es | S | 0 | x4 | 00 | )4 | 80 | )7( | 0) | bit | t |  |
|----------|----|--|-------|------|------|-----|-----|------|----|-----|----|-----|----|----|----|---|----|---|----|---|----|----|----|----|----|---|----|---|---|----|----|----|----|-----|----|-----|---|--|
|          |    |  |       |      |      |     |     |      |    |     |    |     |    |    |    |   |    |   |    |   |    |    |    |    |    |   |    |   |   |    |    |    |    |     |    |     |   |  |

| Bit  | Symbol | Value | Description                 | Reset value |
|------|--------|-------|-----------------------------|-------------|
| 1:0  | SEL    |       | Clock source for main clock | 0           |
|      |        | 0x0   | IRC Oscillator              |             |
|      |        | 0x1   | PLL input                   |             |
|      |        | 0x2   | Watchdog oscillator         |             |
|      |        | 0x3   | PLL output                  |             |
| 31:2 | -      | -     | Reserved                    | -           |

#### 5.6.12 Main clock source update enable register

This register updates the clock source of the main clock with the new input clock after the MAINCLKSEL register has been written to. In order for the update to take effect, first write a zero to bit 0 of this register, then write a one.

#### Main clock source update enable register (MAINCLKUEN, address 0x4004 8074) Table 31. bit description

| Bit  | Symbol | Value | Description                     | Reset value |
|------|--------|-------|---------------------------------|-------------|
| 0    | ENA    |       | Enable main clock source update | 0           |
|      |        | 0     | No change                       | -           |
|      |        | 1     | Update clock source             | -           |
| 31:1 | -      | -     | Reserved                        | -           |

#### 5.6.13 System clock divider register

This register controls how the main clock is divided to provide the system clock to the core, memories, and the peripherals. The system clock can be shut down completely by setting the DIV field to zero.

## Table 32. System clock divider register (SYSAHBCLKDIV, address 0x4004 8078) bit description

| Bit  | Symbol | Description                                                                                                  | Reset<br>value |
|------|--------|--------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | DIV    | System AHB clock divider values<br>0: System clock disabled.<br>1: Divide by 1.<br>to<br>255: Divide by 255. | 0x01           |
| 31:8 | -      | Reserved                                                                                                     | -              |

### 5.6.14 System clock control register

The SYSAHBCLKCTRL register enables the clocks to individual system and peripheral blocks. The system clock (bit 0) provides the clock for the AHB, the APB bridge, the ARM Cortex-M0+, the SYSCON block, and the PMU. This clock cannot be disabled.

# Table 33. System clock control register (SYSAHBCLKCTRL, address 0x4004 8080) bit description

| Bit | Symbol   | Value | Description                                                                                                                                        | Reset<br>value |
|-----|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | SYS      |       | Enables the clock for the AHB, the APB bridge, the<br>Cortex-M0+ core clocks, SYSCON, and the PMU.<br>This bit is read only and always reads as 1. | 1              |
| 1   | ROM      |       | Enables clock for ROM.                                                                                                                             | 1              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |
| 2   | RAM0     |       | Enables clock for SRAM0.                                                                                                                           | 1              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |
| 3   | FLASHREG |       | Enables clock for flash register interface.                                                                                                        | 1              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |
| 4   | FLASH    |       | Enables clock for flash.                                                                                                                           | 1              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |
| 5   | I2C0     |       | Enables clock for I2C0.                                                                                                                            | 0              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |
| 6   | GPIO     |       | Enables clock for GPIO port registers and GPIO pin interrupt registers.                                                                            | 1              |
|     |          | 0     | Disable                                                                                                                                            |                |
|     |          | 1     | Enable                                                                                                                                             |                |

UM11021

| Bit   | Symbol | Value | Description                                             | Reset |
|-------|--------|-------|---------------------------------------------------------|-------|
|       |        |       |                                                         | value |
| 7     | SWM    |       | Enables clock for switch matrix.                        | 1     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 8     | SCT    |       | Enables clock for state configurable timer SCTimer/PWM. | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 9     | WKT    |       | Enables clock for self-wake-up timer.                   | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 10    | MRT    |       | Enables clock for multi-rate timer.                     |       |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 11    | SPI0   |       | Enables clock for SPI0.                                 | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 12    | SPI1   |       | Enables clock for SPI1.                                 |       |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 13    | CRC    |       | Enables clock for CRC.                                  | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 14    | UART0  |       | Enables clock for USART0.                               | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 15    | -      |       | Reserved                                                | -     |
| 16    | -      |       | Reserved                                                | -     |
| 17    | WWDT   |       | Enables clock for WWDT.                                 | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 18    | IOCON  |       | Enables clock for IOCON block.                          | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 23:19 | -      | -     | Reserved                                                | -     |
| 24    | ADC    |       | Enables clock to ADC.                                   | 0     |
|       |        | 0     | Disable                                                 |       |
|       |        | 1     | Enable                                                  |       |
| 25    | -      | -     | Reserved                                                | -     |

# Table 33. System clock control register (SYSAHBCLKCTRL, address 0x4004 8080) bit description ...continued

UM11021

| Bit   | Symbol | Value | Description                                                                                                                           | Reset<br>value |
|-------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 26    | МТВ    |       | Enables clock to micro-trace buffer control registers.<br>Turn on this clock when using the micro-trace buffer<br>for debug purposes. | 0              |
|       |        | 0     | Disable                                                                                                                               |                |
|       |        | 1     | Enable                                                                                                                                | 1              |
| 28:27 | -      | -     | Reserved                                                                                                                              | -              |
| 29    | DMA    |       | Enables clock to DMA.                                                                                                                 | 0              |
|       |        | 0     | Disable                                                                                                                               | -              |
|       |        | 1     | Enable                                                                                                                                | 1              |
| 31:30 | -      | -     | Reserved                                                                                                                              | -              |

 Table 33.
 System clock control register (SYSAHBCLKCTRL, address 0x4004 8080) bit description ...continued

### 5.6.15 USART clock divider register

This register configures the clock for the fractional baud rate generator and all USARTs. The UART clock can be disabled by setting the DIV field to zero (this is the default setting).

| Table 34. | USART clock divider register ( | (UARTCLKDIV, address | 0x4004 8094) bit description |
|-----------|--------------------------------|----------------------|------------------------------|
|-----------|--------------------------------|----------------------|------------------------------|

| Bit  | Symbol | Description                                                                                                                      | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | DIV    | USART fractional baud rate generator clock divider values.<br>0: Clock disabled.<br>1: Divide by 1.<br>to<br>255: Divide by 255. | 0              |
| 31:8 | -      | Reserved                                                                                                                         | -              |

#### 5.6.16 CLKOUT clock source select register

This register selects the signal visible on the CLKOUT pin. Any oscillator or the main clock can be selected.

Bit 0 of the CLKOUTUEN register (see <u>Section 5.6.17</u>) must be toggled from 0 to 1 for the update to take effect.

## Table 35. CLKOUT clock source select register (CLKOUTSEL, address 0x4004 80E0) bit description

| Bit  | Symbol | Value | Description                 | Reset<br>value |
|------|--------|-------|-----------------------------|----------------|
| 1:0  | SEL    |       | CLKOUT clock source         | 0              |
|      |        | 0x0   | IRC oscillator              | -              |
|      |        | 0x1   | Crystal oscillator (SYSOSC) |                |
|      |        | 0x2   | Watchdog oscillator         | -              |
|      |        | 0x3   | Main clock                  | -              |
| 31:2 | -      | -     | Reserved                    | 0              |

### 5.6.17 CLKOUT clock source update enable register

This register updates the clock source of the CLKOUT pin with the new clock after the CLKOUTSEL register has been written to. In order for the update to take effect at the input of the CLKOUT pin, first write a zero to bit 0 of this register, then write a one.

 Table 36.
 CLKOUT clock source update enable register (CLKOUTUEN, address 0x4004 80E4) bit description

| Bit  | Symbol | Value | Description                       | Reset value |
|------|--------|-------|-----------------------------------|-------------|
| 0    | ENA    |       | Enable CLKOUT clock source update | 0           |
|      |        | 0     | No change                         |             |
|      |        | 1     | Update clock source               |             |
| 31:1 | -      | -     | Reserved                          | -           |

#### 5.6.18 CLKOUT clock divider register

This register determines the divider value for the signal on the CLKOUT pin.

## Table 37. CLKOUT clock divider registers (CLKOUTDIV, address 0x4004 80E8) bit description

| Bit  | Symbol | Description                                                                                                     | Reset<br>value |
|------|--------|-----------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | DIV    | CLKOUT clock divider values<br>0: Disable CLKOUT clock divider.<br>1: Divide by 1.<br>to<br>255: Divide by 255. | 0              |
| 31:8 | -      | Reserved                                                                                                        | -              |

### 5.6.19 USART fractional generator divider value register

All USART peripherals share a common clock U\_PCLK, which can be adjusted by a fractional divider:

U\_PCLK = UARTCLKDIV/(1 + MULT/DIV).

UARTCLKDIV is the USART clock configured in the UARTCLKDIV register.

The fractional portion (1 + MULT/DIV) is determined by the two USART fractional divider registers in the SYSCON block:

- 1. The DIV value programmed in this register is the denominator of the divider used by the fractional rate generator to create the fractional component of U\_PCLK.
- The MULT value of the fractional divider is programmed in the UARTFRGMULT register. See <u>Table 39</u>.

**Remark:** To use of the fractional baud rate generator, you must write 0xFF to this register to yield a denominator value of 256. All other values are not supported.

See also:

Section 13.3.1 "Configure the USART clock and baud rate"

Section 13.7.1 "Clocking and baud rates"

|      | ou of bit description |                                                                                                                                                    |                |  |  |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| Bit  | Symbol                | Description                                                                                                                                        | Reset<br>value |  |  |
| 7:0  | DIV                   | Denominator of the fractional divider. DIV is equal to the programmed value +1. Always set to 0xFF to use with the fractional baud rate generator. | 0              |  |  |
| 31:8 | -                     | Reserved                                                                                                                                           | -              |  |  |

## Table 38.USART fractional generator divider value register (UARTFRGDIV, address 0x4004<br/>80F0) bit description

#### 5.6.20 USART fractional generator multiplier value register

The USART peripheral shares a common clock U\_PCLK, which can be adjusted by a fractional divider:

U\_PCLK = UARTCLKDIV/(1 + MULT/DIV).

UARTCLKDIV is the USART clock configured in the UARTCLKDIV register.

The fractional portion (1 + MULT/DIV) is determined by the two USART fractional divider registers in the SYSCON block:

- 1. The DIV denominator of the fractional divider value is programmed in the UARTFRGDIV register. See <u>Table 38</u>.
- The MULT value programmed in this register is the numerator of the fractional divider value used by the fractional rate generator to create the fractional component to the baud rate.

See also:

Section 13.3.1 "Configure the USART clock and baud rate"

Section 13.7.1 "Clocking and baud rates"

## Table 39.USART fractional generator multiplier value register (UARTFRGMULT, address<br/>0x4004 80F4) bit description

| Bit  | Symbol | Description                                                                 | Reset<br>value |
|------|--------|-----------------------------------------------------------------------------|----------------|
| 7:0  | MULT   | Numerator of the fractional divider. MULT is equal to the programmed value. | 0              |
| 31:8 | -      | Reserved                                                                    | -              |

### 5.6.21 External trace buffer command register

This register works in conjunction with the MTB master register to start and stop tracing. Also see <u>Section 25.5.4</u>.

|      | bit description |                                                                                                                                                                                     |                |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Bit  | Symbol          | Description                                                                                                                                                                         | Reset<br>value |
| 0    | START           | Trace start command. Writing a one to this bit sets the TSTART signal to the MTB to HIGH and starts tracing if the TSTARTEN bit in the MTB master register is set to one as well.   | 0              |
| 1    | STOP            | Trace stop command. Writing a one to this bit sets the TSTOP signal<br>in the MTB to HIGH and stops tracing if the TSTOPEN bit in the MTB<br>master register is set to one as well. | 0              |
| 31:2 | -               | Reserved                                                                                                                                                                            | 0              |

 Table 40.
 External trace buffer command register (EXTTRACECMD, address 0x4004 80FC)

 bit description

#### 5.6.22 POR captured PIO status register 0

The PIOPORCAP0 register captures the state of GPIO port 0 at power-on-reset. Each bit represents the reset state of one GPIO pin. This register is a read-only status register.

# Table 41. POR captured PIO status register 0 (PIOPORCAP0, address 0x4004 8100) bit description

| Bit   | Symbol  | Description                                       | Reset value              |
|-------|---------|---------------------------------------------------|--------------------------|
| 17:0  | PIOSTAT | State of PIO0_17 through PIO0_0 at power-on reset | Implementation dependent |
| 31:18 | -       | Reserved.                                         | -                        |

#### 5.6.23 IOCON glitch filter clock divider registers 6 to 0

These registers individually configure the seven peripheral input clocks (IOCONFILTR\_PCLK) to the IOCON programmable glitch filter. The clocks can be shut down by setting the DIV bits to 0x0.

#### Table 42. IOCON glitch filter clock divider registers 6 to 0 (IOCONCLKDIV[6:0], address 0x4004 8134 (IOCONCLKDIV6) to 0x004 814C (IOCONFILTCLKDIV0)) bit description

| Bit  | Symbol | Description                                                                                                             | Reset value |  |  |
|------|--------|-------------------------------------------------------------------------------------------------------------------------|-------------|--|--|
| 7:0  | DIV    | IOCON glitch filter clock divider values<br>0: Disable IOCONFILTR_PCLK.<br>1: Divide by 1.<br>to<br>255: Divide by 255. | 0           |  |  |
| 31:8 | -      | Reserved                                                                                                                | 0x00        |  |  |

### 5.6.24 BOD control register

The BOD control register selects four separate threshold values for sending a BOD interrupt to the NVIC and for forced reset. Reset and interrupt threshold values listed in Table 43 are typical values.

Both the BOD interrupt and the BOD reset, depending on the value of bit BODRSTENA in this register, can wake-up the chip from Sleep, Deep-sleep, and Power-down modes.

See the LPC800 data sheet for the BOD reset and interrupt levels.

| Bit  | Symbol    | Value | Description             | Reset<br>value |
|------|-----------|-------|-------------------------|----------------|
| 1:0  | BODRSTLEV |       | BOD reset level         | 0              |
|      |           | 0x0   | Reserved.               |                |
|      |           | 0x1   | Level 1.                |                |
|      |           | 0x2   | Level 2.                |                |
|      |           | 0x3   | Level 3.                |                |
| 3:2  | BODINTVAL |       | BOD interrupt level     | 0              |
|      |           | 0x0   | Reserved                |                |
|      |           | 0x1   | Level 1.                |                |
|      |           | 0x2   | Level 2.                |                |
|      |           | 0x3   | Level 3.                |                |
| 4    | BODRSTENA |       | BOD reset enable        | 0              |
|      |           | 0     | Disable reset function. |                |
|      |           | 1     | Enable reset function.  |                |
| 31:5 | -         | -     | Reserved                | 0x00           |

 Table 43.
 BOD control register (BODCTRL, address 0x4004 8150) bit description

#### 5.6.25 System tick counter calibration register

This register determines the value of the SYST\_CALIB register.

## Table 44. System tick timer calibration register (SYSTCKCAL, address 0x4004 8154) bit description

| Bit   | Symbol | Description                         | Reset<br>value |
|-------|--------|-------------------------------------|----------------|
| 25:0  | CAL    | System tick timer calibration value | 0              |
| 31:26 | -      | Reserved                            | -              |

### 5.6.26 IRQ latency register

The IRQLATENCY register is an eight-bit register which specifies the minimum number of cycles (0-255) permitted for the system to respond to an interrupt request. The intent of this register is to allow the user to select a trade-off between interrupt response time and determinism.

Setting this parameter to a very low value (e.g. zero) will guarantee the best possible interrupt performance but will also introduce a significant degree of uncertainty and jitter. Requiring the system to always take a larger number of cycles (whether it needs it or not) will reduce the amount of uncertainty but may not necessarily eliminate it.

Theoretically, the ARM Cortex-M0+ core should always be able to service an interrupt request within 15 cycles. However, system factors external to the cpu, such as bus latencies or peripheral response times, can increase the time required to complete a previous instruction before an interrupt can be serviced. Therefore, accurately specifying a minimum number of cycles that will ensure determinism will depend on the application.

The default setting for this register is 0x010.

| Bit  | Symbol  |                     | Reset<br>value |
|------|---------|---------------------|----------------|
| 7:0  | LATENCY | 8-bit latency value | 0x010          |
| 31:8 | -       | Reserved            | -              |

#### Table 45. IRQ latency register (IRQLATENCY, address 0x4004 8170) bit description

#### 5.6.27 NMI source selection register

The NMI source selection register selects a peripheral interrupt as source for the NMI interrupt of the ARM Cortex-M0+ core. For a list of all peripheral interrupts and their IRQ numbers see <u>Table 4</u>. For a description of the NMI functionality, see <u>Section 4.3.2</u>.

**Remark:** When you want to change the interrupt source for the NMI, you must first disable the NMI source by setting bit 31 in this register to 0. Then change the source by updating the IRQN bits and re-enable the NMI source by setting bit 31 to 1.

 Table 46.
 NMI source selection register (NMISRC, address 0x4004 8174) bit description

| Bit  | Symbol | Description                                                                                                                                                               | Reset<br>value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 4:0  | IRQN   | The IRQ number of the interrupt that acts as the Non-Maskable Interrupt (NMI) if bit 31 is 1. See <u>Table 4</u> for the list of interrupt sources and their IRQ numbers. | 0              |
| 30:5 | -      | Reserved                                                                                                                                                                  | -              |
| 31   | NMIEN  | Write a 1 to this bit to enable the Non-Maskable Interrupt (NMI) source selected by bits 4:0.                                                                             | 0              |

**Remark:** If the NMISRC register is used to select an interrupt as the source of Non-Maskable interrupts, and the selected interrupt is enabled, one interrupt request can result in both a Non-Maskable and a normal interrupt. This can be avoided by disabling the normal interrupt in the NVIC.

#### 5.6.28 Pin interrupt select registers

Each of these 8 registers selects one pin from all digital pins as the source of a pin interrupt or as the input to the pattern match engine. To select a pin for any of the eight pin interrupts or pattern match engine inputs, write the GPIO port pin number as 0 to 28 for pins PIO0\_0 to PIO0\_28 to the INTPIN bits. For example, setting INTPIN to 0x5 in PINTSEL0 selects pin PIO0\_5 for pin interrupt 0.

**Remark:** The GPIO port pin number serves to identify the pin to the PINTSEL register. Any digital input function, including GPIO, can be assigned to this pin through the switch matrix.

Each of the 8 pin interrupts must be enabled in the NVIC using interrupt slots # 24 to 31 (see <u>Table 4</u>).

To use the selected pins for pin interrupts or the pattern match engine, see <u>Section 10.5.2</u> "Pattern match engine".

# Table 47. Pin interrupt select registers (PINTSEL[0:7], address 0x4004 8178 (PINTSEL0) to 0x4004 8194 (PINTSEL7)) bit description

| Bit  | Symbol | Description                                                                                                           | Reset<br>value |
|------|--------|-----------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  | INTPIN | Pin number select for pin interrupt or pattern match engine input. (PIO0_0 to PIO0_28 correspond to numbers 0 to 28). | 0              |
| 31:6 | -      | Reserved                                                                                                              | -              |

#### 5.6.29 Start logic 0 pin wake-up enable register

The STARTERP0 register enables the selected pin interrupts for wake-up from deep-sleep mode and power-down modes.

**Remark:** Also enable the corresponding interrupts in the NVIC. See <u>Table 4 "Connection</u> of interrupt sources to the NVIC".

#### Bit Symbol Value Description Reset value 0 PINT0 GPIO pin interrupt 0 wake-up 0 0 Disabled 1 Enabled 1 PINT1 GPIO pin interrupt 1 wake-up 0 0 Disabled 1 Enabled 2 PINT2 GPIO pin interrupt 2 wake-up 0 0 Disabled 1 Enabled 3 PINT3 0 GPIO pin interrupt 3 wake-up 0 Disabled 1 Enabled PINT4 0 4 GPIO pin interrupt 4 wake-up 0 Disabled 1 Enabled 5 PINT5 GPIO pin interrupt 5 wake-up 0 0 Disabled 1 Enabled 6 PINT6 GPIO pin interrupt 6 wake-up 0 0 Disabled 1 Enabled 7 PINT7 GPIO pin interrupt 7 wake-up 0 0 Disabled 1 Enabled 31:8 Reserved

## Table 48. Start logic 0 pin wake-up enable register 0 (STARTERP0, address 0x4004 8204) bit description

UM11021

#### 5.6.30 Start logic 1 interrupt wake-up enable register

This register selects which interrupts wake up the part from deep-sleep and power-down modes.

**Remark:** Also enable the corresponding interrupts in the NVIC. See <u>Table 4 "Connection</u> of interrupt sources to the NVIC".

| Table 49. | Start logic 1 interrupt wake-up enable register (STARTERP1, address |
|-----------|---------------------------------------------------------------------|
|           | 0x4004 8214) bit description                                        |

| Bit   | Symbol | Value | Description                                                          | Reset<br>value |
|-------|--------|-------|----------------------------------------------------------------------|----------------|
| 0     | SPI0   |       | SPI0 interrupt wake-up                                               | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 1     | SPI1   |       | SPI1 interrupt wake-up                                               | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 2     | -      |       | Reserved                                                             | -              |
| 3     | USART0 |       | USART0 interrupt wake-up. Configure USART in synchronous slave mode. | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              | _              |
| 7:4   | -      |       | Reserved                                                             | -              |
| 8     | 12C0   |       | I2C0 interrupt wake-up.                                              | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 11:9  | -      |       | Reserved                                                             | -              |
| 12    | WWDT   |       | WWDT interrupt wake-up                                               | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 13    | BOD    |       | BOD interrupt wake-up                                                | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 14    | -      |       | Reserved                                                             | -              |
| 15    | WKT    |       | Self-wake-up timer interrupt wake-up                                 | 0              |
|       |        | 0     | Disabled                                                             |                |
|       |        | 1     | Enabled                                                              |                |
| 31:16 | -      |       | Reserved.                                                            | -              |

### 5.6.31 Deep-sleep mode configuration register

The bits in this register (BOD\_PD and WDTOSC\_OD) can be programmed to control aspects of Deep-sleep and Power-down modes. The bits are loaded into corresponding bits of the PDRUNCFG register when Deep-sleep mode or Power-down mode is entered.

**Remark:** Hardware forces the analog blocks to be powered down in Deep-sleep and Power-down modes. An exception are the BOD and watchdog oscillator, which can be configured to remain running through this register. The WDTOSC\_PD value written to the PDSLEEPCFG register is overwritten if the LOCK bit in the WWDT MOD register (see Table 250) is set. See Section 17.5.3 for details.

| Table 50. | Deep-sleep configuration register (PDSLEEPCFG, address 0x4004 8230) bit |
|-----------|-------------------------------------------------------------------------|
|           | description                                                             |

| Bit   | Symbol    | Value | Description                                                                                                                                                                                                                                           | Reset value |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 2:0   | -         |       | Reserved.                                                                                                                                                                                                                                             | 0b111       |
| 3     | BOD_PD    |       | BOD power-down control for Deep-sleep and Power-down mode                                                                                                                                                                                             | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                                                               | _           |
|       |           | 1     | Powered down                                                                                                                                                                                                                                          | _           |
| 5:4   | -         |       | Reserved.                                                                                                                                                                                                                                             | 11          |
| 6     | WDTOSC_PD |       | Watchdog oscillator power-down control for<br>Deep-sleep and Power-down mode. Changing<br>this bit to powered-down has no effect when the<br>LOCK bit in the WWDT MOD register is set. In<br>this case, the watchdog oscillator is always<br>running. | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                                                               |             |
|       |           | 1     | Powered down                                                                                                                                                                                                                                          | 1           |
| 15:7  | -         |       | Reserved                                                                                                                                                                                                                                              | 0b111111111 |
| 31:16 | -         | -     | Reserved                                                                                                                                                                                                                                              | 0           |

### 5.6.32 Wake-up configuration register

This register controls the power configuration of the device when waking up from Deep-sleep or Power-down mode.

## Table 51. Wake-up configuration register (PDAWAKECFG, address 0x4004 8234) bit description

| Bit | Symbol    | Value | Description                                     | Reset value |
|-----|-----------|-------|-------------------------------------------------|-------------|
| 0   | IRCOUT_PD |       | IRC oscillator output wake-up configuration     | 0           |
|     |           | 0     | Powered                                         |             |
|     |           | 1     | Powered down                                    |             |
| 1   | IRC_PD    |       | IRC oscillator power-down wake-up configuration | 0           |
|     |           | 0     | Powered                                         |             |
|     |           | 1     | Powered down                                    |             |
| 2   | FLASH_PD  |       | Flash wake-up configuration                     | 0           |
|     |           | 0     | Powered                                         |             |
|     |           | 1     | Powered down                                    |             |
| 3   | BOD_PD    |       | BOD wake-up configuration                       | 0           |
|     |           | 0     | Powered                                         |             |
|     |           | 1     | Powered down                                    |             |

UM11021

| Bit   | Symbol    | Value | Description                                                                                                                                                                                                        | Reset value |
|-------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 4     | ADC_PD    |       | ADC wake-up configuration                                                                                                                                                                                          | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                            |             |
|       |           | 1     | Powered down                                                                                                                                                                                                       |             |
| 5     | SYSOSC_PD |       | Crystal oscillator wake-up configuration                                                                                                                                                                           | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                            |             |
|       |           | 1     | Powered down                                                                                                                                                                                                       |             |
| 6     | WDTOSC_PD |       | Watchdog oscillator wake-up configuration.<br>Changing this bit to powered-down has no effect<br>when the LOCK bit in the WWDT MOD register is<br>set. In this case, the watchdog oscillator is always<br>running. | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                            |             |
|       |           | 1     | Powered down                                                                                                                                                                                                       |             |
| 7     | SYSPLL_PD |       | System PLL wake-up configuration                                                                                                                                                                                   | 1           |
|       |           | 0     | Powered                                                                                                                                                                                                            |             |
|       |           | 1     | Powered down                                                                                                                                                                                                       |             |
| 11:8  | -         |       | Reserved. Always write these bits as 0b1101                                                                                                                                                                        | 0b1101      |
| 14:12 | -         |       | Reserved. Always write these bits as 0b110                                                                                                                                                                         | 0b110       |
| 31:15 | -         | -     | Reserved                                                                                                                                                                                                           | 0           |

## Table 51. Wake-up configuration register (PDAWAKECFG, address 0x4004 8234) bit description ...continued

### 5.6.33 Power configuration register

The PDRUNCFG register controls the power to the various analog blocks. This register can be written to at any time while the chip is running, and a write will take effect immediately with the exception of the power-down signal to the IRC.

To avoid glitches when powering down the IRC, the IRC clock is automatically switched off at a clean point. Therefore, for the IRC a delay is possible before the power-down state takes effect.

The system oscillator requires typically 500  $\mu$ s to start up after the SYSOSC\_PD bit has been changed from 1 to 0. There is no hardware flag to monitor the state of the system oscillator. Therefore, add a software delay of about 500  $\mu$ s before using the system oscillator after power-up.

| Bit | Symbol    | Value | Description                 | Reset value |
|-----|-----------|-------|-----------------------------|-------------|
| 0   | IRCOUT_PD |       | IRC oscillator output power | 0           |
|     |           | 0     | Powered                     |             |
|     |           | 1     | Powered down                |             |
| 1   | IRC_PD    |       | IRC oscillator power down   | 0           |
|     |           | 0     | Powered                     |             |
|     |           | 1     | Powered down                |             |

 Table 52.
 Power configuration register (PDRUNCFG, address 0x4004 8238) bit description

| Bit         | Symbol    | Value | Description                                                                                                                                                                                             | Reset value |  |
|-------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|
| 2           | FLASH_PD  |       | Flash power down                                                                                                                                                                                        | 0           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 3           | BOD_PD    |       | BOD power down                                                                                                                                                                                          | 0           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 4           | ADC_PD    |       | ADC wake-up configuration                                                                                                                                                                               | 1           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 5           | SYSOSC_PD |       | Crystal oscillator power down. After power-up, add a software delay of approximately 500 $\mu s$ before using.                                                                                          | 1           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 6 WDTOSC_PD |           |       | Watchdog oscillator power down. Changing<br>this bit to powered-down has no effect when<br>the LOCK bit in the WWDT MOD register is<br>set. In this case, the watchdog oscillator is<br>always running. | 1           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 7           | SYSPLL_PD |       | System PLL power down                                                                                                                                                                                   | 1           |  |
|             |           | 0     | Powered                                                                                                                                                                                                 |             |  |
|             |           | 1     | Powered down                                                                                                                                                                                            |             |  |
| 11:8        | -         |       | Reserved. Always write these bits as 0b1101                                                                                                                                                             | 0b1101      |  |
| 14:12       | -         |       | Reserved. Always write these bits as 0b110                                                                                                                                                              | 0b110       |  |
| 31:15       | -         | -     | Reserved                                                                                                                                                                                                | 0           |  |

#### Table 52. Power configuration register (PDRUNCFG, address 0x4004 8238) bit description

#### 5.6.34 Device ID register

This device ID register is a read-only register and contains the part ID for each part. This register is also read by the ISP/IAP commands (see Table 317).

#### Table 53. Device ID register (DEVICE\_ID, address 0x4004 83F8) bit description

| Bit  | Symbol   | Description                   | Reset value    |
|------|----------|-------------------------------|----------------|
| 31:0 | DEVICEID | 0x0000 8341 = LPC8341201FHI33 | part-dependent |
|      |          | 0x0000 8322 = LPC832M101FDH20 |                |

### **5.7 Functional description**

#### 5.7.1 Reset

Reset has the following sources: the RESET pin, Watchdog Reset, Power-On Reset (POR), and Brown Out Detect (BOD). In addition, there is an ARM software reset.

UM11021

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 causing reset to remain asserted until the external Reset is de-asserted, the oscillator is running, and the flash controller has completed its initialization.

On the assertion of any reset source (ARM core software reset, POR, BOD reset, External reset, and Watchdog reset), the following processes are initiated:

- 1. The IRC starts up. After the IRC-start-up time (maximum of 6  $\mu$ s on power-up), the IRC provides a stable clock output.
- 2. The flash is powered up. This takes approximately 100  $\mu$ s. Then the flash initialization sequence is started, which takes about 250 cycles.
- 3. The boot code in the ROM starts. The boot code performs the boot tasks and may jump to the flash.

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.

#### 5.7.2 Start-up behavior

See <u>Figure 5</u> for the start-up timing after reset. The IRC is the default clock at Reset and provides a clean system clock shortly after the supply voltage reaches the threshold value of 1.8 V.



#### UM11021

© NXP Semiconductors N.V. 2016. All rights reserved.

#### 5.7.3 Brown-out detection

The brown-out detection circuit includes up to three levels for monitoring the voltage on the  $V_{DD}$  pin. If this voltage falls below one of the selected levels, the BOD asserts an interrupt signal to the NVIC or issues a reset, depending on the value of the BODRSTENA bit in the BOD control register (Table 43).

The interrupt signal can be enabled for interrupt in the Interrupt Enable Register in the NVIC (see <u>Table 5</u>) in order to cause a CPU interrupt; if not, software can monitor the signal by reading a dedicated status register.

If the BOD interrupt is enabled in the STARTERP1 register (see <u>Table 49</u>) and in the NVIC, the BOD interrupt can wake up the chip from Deep-sleep and power-down mode.

If the BOD reset is enabled, the forced BOD reset can wake up the chip from Deep-sleep or Power-down mode.

#### 5.7.4 System PLL functional description

irc osc clk FCLKIN sys osc clk ᢀᢂ FCCO pd CLKIN PSEL<1:0> 1 PFD cd SYSPLLCLKSEL pd LOCK /2P LOCK FCLKOUT DETECT analog section pd cd /M 5 MSEL<4:0> Fig 6. System PLL block diagram

The LPC83x uses the system PLL to create the clocks for the core and peripherals.

The block diagram of this PLL is shown in Figure 6. The input frequency range is 10 MHz to 25 MHz. The input clock is fed directly to the Phase-Frequency Detector (PFD). This block compares the phase and frequency of its inputs, and generates a control signal when phase and/ or frequency do not match. The loop filter filters these control signals and drives the current controlled oscillator (CCO), which generates the main clock and optionally two additional phases. The CCO frequency range is 156 MHz to 320 MHz. These clocks are either divided by 2xP by the programmable post divider to create the output clocks, or are sent directly to the outputs. The main output clock is then divided by M by the programmable feedback divider to generate the feedback clock. The output signal of the phase-frequency detector is also monitored by the lock detector, to signal when the PLL has locked on to the input clock.

**Remark:** The divider values for P and M must be selected so that the PLL output clock frequency FCLKOUT is lower than 100 MHz because the main clock is limited to a maximum frequency of 100 MHz

#### 5.7.4.1 Lock detector

The lock detector measures the phase difference between the rising edges of the input and feedback clocks. Only when this difference is smaller than the so called "lock criterion" for more than eight consecutive input clock periods, the lock output switches from low to high. A single too large phase difference immediately resets the counter and causes the lock signal to drop (if it was high). Requiring eight phase measurements in a row to be below a certain figure ensures that the lock detector will not indicate lock until both the phase and frequency of the input and feedback clocks are very well aligned. This effectively prevents false lock indications, and thus ensures a glitch free lock signal.

#### 5.7.4.2 Power-down control

To reduce the power consumption when the PLL clock is not needed, a PLL Power-down mode has been incorporated. This mode is enabled by setting the SYSPLL\_PD bit to one in the Power-down configuration register (Table 52). In this mode, the internal current reference will be turned off, the oscillator and the phase-frequency detector will be stopped and the dividers will enter a reset state. While in PLL Power-down mode, the lock output will be low to indicate that the PLL is not in lock. When the PLL Power-down mode is terminated by setting the SYSPLL\_PD bit to zero, the PLL will resume its normal operation and will make the lock signal high once it has regained lock on the input clock.

#### 5.7.4.3 Divider ratio programming

#### 5.7.4.3.1 Post divider

The division ratio of the post divider is controlled by the PSEL bits. The division ratio is two times the value of P selected by PSEL bits as shown in <u>Table 22</u>. This guarantees an output clock with a 50% duty cycle.

#### 5.7.4.3.2 Feedback divider

The feedback divider's division ratio is controlled by the MSEL bits. The division ratio between the PLL's output clock and the input clock is the decimal value on MSEL bits plus one, as specified in Table 22.

#### 5.7.4.3.3 Changing the divider values

Changing the divider ratio while the PLL is running is not recommended. As there is no way to synchronize the change of the MSEL and PSEL values with the dividers, the risk exists that the counter will read in an undefined value, which could lead to unwanted spikes or drops in the frequency of the output clock. The recommended way of changing between divider settings is to power down the PLL, adjust the divider settings and then let the PLL start up again.

#### 5.7.4.4 Frequency selection

The PLL frequency equations use the following parameters (also see Figure 6):

 Table 54.
 PLL frequency parameters

| Parameter | System PLL                                                                                                               |
|-----------|--------------------------------------------------------------------------------------------------------------------------|
| FCLKIN    | Frequency of sys_pllclkin (input clock to the system PLL) from the SYSPLLCLKSEL multiplexer (see <u>Section 5.6.9</u> ). |
| FCCO      | Frequency of the Current Controlled Oscillator (CCO); 156 to 320 MHz.                                                    |
| FCLKOUT   | Frequency of sys_pllclkout. This is the PLL output frequency and must be < 100 MHz.                                      |
| Р         | System PLL post divider ratio; PSEL bits in SYSPLLCTRL (see Section 5.6.3).                                              |
| Μ         | System PLL feedback divider register; MSEL bits in SYSPLLCTRL (see <u>Section 5.6.3</u> ).                               |

#### 5.7.4.4.1 Normal mode

In this mode the post divider is enabled, giving a 50% duty cycle clock with the following frequency relations:

(1)

$$Fclkout = M \times Fclkin = (FCCO)/(2 \times P)$$

To select the appropriate values for M and P, it is recommended to follow these steps:

- 1. Specify the input clock frequency Fclkin.
- 2. Calculate M to obtain the desired output frequency Fclkout with M =  $F_{clkout} / F_{clkin}$ .
- 3. Find a value so that FCCO =  $2 \times P \times F_{clkout}$ .
- Verify that all frequencies and divider values conform to the limits specified in <u>Table 22</u>.

**Remark:** The divider values for P and M must be selected so that the PLL output clock frequency FCLKOUT is lower than 100 MHz.

Table 55 shows how to configure the PLL for a 12 MHz crystal oscillator using the SYSPLLCTRL register (Table 22). The main clock is equivalent to the system clock if the system clock divider SYSAHBCLKDIV is set to one (see Table 32).

| PLL input<br>clock<br>sys_pllclkin<br>(Fclkin) | Main clock<br>(Fclkout) | MSEL bits<br>Table 22 |   | PSEL bits<br>Table 22 | P<br>divider<br>value | FCCO<br>frequency | SYSAHBCLKDIV | System<br>clock |
|------------------------------------------------|-------------------------|-----------------------|---|-----------------------|-----------------------|-------------------|--------------|-----------------|
| 12 MHz                                         | 60 MHz                  | 00100 (binary)        | 5 | 01 (binary)           | 2                     | 240 MHz           | 2            | 30 MHz          |
| 12 MHz                                         | 24 MHz                  | 00001(binary)         | 2 | 10 (binary)           | 4                     | 192 MHz           | 1            | 24 MHz          |

#### Table 55. PLL configuration examples

#### 5.7.4.4.2 PLL Power-down mode

In this mode, the internal current reference will be turned off, the oscillator and the phase-frequency detector will be stopped and the dividers will enter a reset state. While in PLL Power-down mode, the lock output will be low, to indicate that the PLL is not in lock. When the PLL Power-down mode is terminated by SYSPLL\_PD bit to zero in the Power-down configuration register (Table 52), the PLL will resume its normal operation and will make the lock signal high once it has regained lock on the input clock.

# UM11021

Chapter 6: LPC83x Reduced power modes and power management

Rev. 1.1 — 5 October 2016

**User manual** 

### 6.1 How to read this chapter

Read this chapter to configure the reduced power modes Deep-sleep mode, Power-down mode, and Deep power-down mode.

**Remark:** The external clock input WKTCLKIN on the wake-up timer is not available on the TSSOP20 package.

### 6.2 Features

- Reduced power modes control
- Low-power oscillator control
- Five general purpose backup registers to retain data in Deep power-down mode

### 6.3 Basic configuration

The PMU is always on as long as V<sub>DD</sub> is present.

If using the WAKEUP function, disable the hysteresis for the WAKEUP pad in the DPDCTRL register when the supply voltage VDD is below 2.2 V. See Table 61.

If using the WKTCLKIN function, disable the hysteresis for that pin in the DPDCTRL register. See Table 61.

#### 6.3.1 Low power modes in the ARM Cortex-M0+ core

Entering and exiting the low power modes is always controlled by the ARM Cortex-M0+ core. The SCR register is the software interface for controlling the core's actions when entering a low power mode. The SCR register is located on the ARM private peripheral bus. For details, see <u>Ref. 3</u>.

#### 6.3.1.1 System control register

The System control register (SCR) controls entry to and exit from a low power state. This register is located on the private peripheral bus and is a R/W register with reset value of 0x0000 0000. The SCR register allows to put the ARM core into sleep mode or the entire system in Deep-sleep or Power-down mode. To set the low power state with SLEEPDEEP = 1 to either deep-sleep or power-down or to enter the Deep power-down mode, use the PCON register (Table 59).

#### Chapter 6: LPC83x Reduced power modes and power management

| Bit | Symbol      | Description                                                                                                                                                                                        | Reset<br>value |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | -           | Reserved.                                                                                                                                                                                          | 0              |
| 1   | SLEEPONEXIT | Indicates sleep-on-exit when returning from Handler mode to Thread mode:                                                                                                                           | 0              |
|     |             | 0 = do not sleep when returning to Thread mode.                                                                                                                                                    |                |
|     |             | 1 = enter sleep, or deep sleep, on return from an ISR to Thread mode.                                                                                                                              |                |
|     |             | Setting this bit to 1 enables an interrupt driven application to avoid returning to an empty main application.                                                                                     |                |
| 2   | SLEEPDEEP   | Controls whether the processor uses sleep or deep-sleep as its low power mode:                                                                                                                     | 0              |
|     |             | 0 = sleep                                                                                                                                                                                          |                |
|     |             | 1 = deep sleep.                                                                                                                                                                                    |                |
| 3   | -           | Reserved.                                                                                                                                                                                          | 0              |
| 4   | SEVONPEND   | Send Event on Pending bit:                                                                                                                                                                         | 0              |
|     |             | 0 = only enabled interrupts or events can wake-up the processor, disabled interrupts are excluded                                                                                                  |                |
|     |             | 1 = enabled events and all interrupts, including disabled interrupts, can wake up the processor.                                                                                                   |                |
|     |             | When an event or interrupt enters pending state, the event signal wakes up the processor from WFE. If the processor is not waiting for an event, the event is registered and affects the next WFE. |                |
|     |             | The processor also wakes up on execution of an SEV                                                                                                                                                 |                |

#### System control register (SCD, address 0x5000 ED40) hit description

### 6.4 Pin description

31:5

In Deep power-down only the WAKEUP pin PIO0\_4 and the self-wake-up timer clock input WKTCLKIN on pin PIO0\_28 are functional (if enabled). The WAKEUP function can be disabled in the DPDCTRL register to lower the power consumption even more. In this case, enable the self-wake-up timer to provide an internal wake-up signal. See Section 6.6.3 "Deep power-down control register".

Remark: When entering Deep power-down mode, an external pull-up resistor is required on the WAKEUP pin to hold it HIGH. In addition, pull the RESET pin HIGH to prevent it from floating while in Deep power-down mode.

instruction.

Reserved.

0

#### Chapter 6: LPC83x Reduced power modes and power management

### 6.5 General description

Power on the LPC800 is controlled by the PMU, by the SYSCON block, and the ARM Cortex-M0+ core. The following reduced power modes are supported in order from highest to lowest power consumption:

1. Sleep mode:

The sleep mode affects the ARM Cortex-M0+ core only. Peripherals and memories are active.

2. Deep-sleep and power-down modes:

The Deep-sleep and power-down modes affect the core and the entire system with memories and peripherals. Before entering deep-sleep or power-down, you must switch the main clock to the IRC to provide a clock signal that can be shut down cleanly.

- a. In Deep-sleep mode, the peripherals receive no internal clocks. The flash is in standby mode. The SRAM memory and all peripheral registers as well as the processor maintain their internal states. The WWDT, WKT, and BOD can remain active to wake up the system on an interrupt.
- b. In Power-down mode, the peripherals receive no internal clocks. The internal SRAM memory and all peripheral registers as well as the processor maintain their internal states. The flash memory is powered down. The WWDT, WKT, and BOD can remain active to wake up the system on an interrupt.
- 3. Deep power-down mode:

For maximal power savings, the entire system is shut down except for the general purpose registers in the PMU and the self-wake-up timer. Only the general purpose registers in the PMU maintain their internal states. The part can wake up on a pulse on the WAKEUP pin or when the self-wake-up timer times out. On wake-up, the part reboots.

**Remark:** The part is in active mode when it is fully powered and operational after booting.

#### 6.5.1 Wake-up process

If the part receives a wake-up signal in any of the reduced power modes, it wakes up to the active mode.

See these links for related registers and wake-up instructions:

- To configure the system after wake-up: <u>Table 51 "Wake-up configuration register</u> (PDAWAKECFG, address 0x4004 8234) bit description".
- To use external interrupts for wake-up: <u>Table 48 "Start logic 0 pin wake-up enable</u> register 0 (STARTERP0, address 0x4004 8204) bit description" and <u>Table 47 "Pin</u> interrupt select registers (PINTSEL[0:7], address 0x4004 8178 (PINTSEL0) to 0x4004 8194 (PINTSEL7)) bit description"
- To enable external or internal signals to wake up the part from Deep-sleep or Power-down modes: <u>Table 49 "Start logic 1 interrupt wake-up enable register</u> (STARTERP1, address 0x4004 8214) bit description"
- To configure the USART to wake up the part: <u>Section 13.3.2 "Configure the USART</u> for wake-up"
- For configuring the self-wake-up timer: <u>Section 18.5</u>
- For a list of all wake-up sources: <u>Table 57 "Wake-up sources for reduced power</u> modes"

#### Chapter 6: LPC83x Reduced power modes and power management

| Table 57. | Wake-up sources | for reduced | power modes |
|-----------|-----------------|-------------|-------------|
|-----------|-----------------|-------------|-------------|

| Power mode      | Wake-up source              | Conditions                                                                                                                          |
|-----------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Sleep           | Any interrupt               | Enable interrupt in NVIC.                                                                                                           |
| Deep-sleep and  | Pin interrupts              | Enable pin interrupts in NVIC and STARTERP0 registers.                                                                              |
| Power-down      | BOD interrupt               | <ul> <li>Enable interrupt in NVIC and STARTERP1 registers.</li> </ul>                                                               |
|                 |                             | <ul> <li>Enable interrupt in BODCTRL register.</li> </ul>                                                                           |
|                 |                             | <ul> <li>BOD powered in PDSLEEPCFG register.</li> </ul>                                                                             |
|                 | BOD reset                   | Enable reset in BODCTRL register.                                                                                                   |
|                 |                             | <ul> <li>BOD powered in PDSLEEPCFG register.</li> </ul>                                                                             |
|                 | WWDT interrupt              | <ul> <li>Enable interrupt in NVIC and STARTERP1 registers.</li> </ul>                                                               |
|                 |                             | <ul> <li>WWDT running. Enable WWDT in WWDT MOD register and feed.</li> </ul>                                                        |
|                 |                             | <ul> <li>Enable interrupt in WWDT MOD register.</li> </ul>                                                                          |
|                 |                             | <ul> <li>WDOsc powered in PDSLEEPCFG register.</li> </ul>                                                                           |
|                 | WWDT reset                  | WWDT running.                                                                                                                       |
|                 |                             | <ul> <li>Enable reset in WWDT MOD register.</li> </ul>                                                                              |
|                 |                             | <ul> <li>WDOsc powered in PDSLEEPCFG register.</li> </ul>                                                                           |
|                 | Self-Wake-up Timer          | <ul> <li>Enable interrupt in NVIC and STARTERP1 registers.</li> </ul>                                                               |
|                 | (WKT) time-out              | • Enable low-power oscillator in the DPDCTRL register in the PCON block.                                                            |
|                 |                             | <ul> <li>Select low-power clock for WKT clock in the WKT CTRL register.</li> </ul>                                                  |
|                 |                             | <ul> <li>Start the WKT by writing a time-out value to the WKT COUNT register.</li> </ul>                                            |
|                 | Interrupt from              | <ul> <li>Enable interrupt in NVIC and STARTERP1 registers.</li> </ul>                                                               |
|                 | USART/SPI/I2C<br>peripheral | <ul> <li>Enable USART/I2C/SPI interrupts.</li> </ul>                                                                                |
|                 | penpherai                   | <ul> <li>Provide an external clock signal to the peripheral.</li> </ul>                                                             |
|                 |                             | <ul> <li>Configure the USART in synchronous slave mode and I2C and SPI in<br/>slave mode.</li> </ul>                                |
| Deep power-down | WAKEUP pin PIO0_4           | Enable the WAKEUP function in the DPDCTRL register in the PMU.                                                                      |
|                 | WKT time-out                | • Enable the low-power oscillator in the DPDCTRL register in the PMU.                                                               |
|                 |                             | <ul> <li>Enable the low-power oscillator to keep running in Deep power-down<br/>mode in the DPDCTRL register in the PMU.</li> </ul> |
|                 |                             | <ul> <li>Select low-power clock for WKT clock in the WKT CTRL register.</li> </ul>                                                  |
|                 |                             | <ul> <li>Start WKT by writing a time-out value to the WKT COUNT register.</li> </ul>                                                |

### 6.6 Register description

| Table 58. | Register | overview: | PMU (base | e address ( | 0x4002 0000) |  |
|-----------|----------|-----------|-----------|-------------|--------------|--|
|           |          |           |           |             |              |  |

| Name    | Access | Address<br>offset | Description                                                                       | Reset<br>value | Reference       |
|---------|--------|-------------------|-----------------------------------------------------------------------------------|----------------|-----------------|
| PCON    | R/W    | 0x000             | Power control register                                                            | 0x0            | Table 59        |
| GPREG0  | R/W    | 0x004             | General purpose register 0                                                        | 0x0            | Table 60        |
| GPREG1  | R/W    | 0x008             | General purpose register 1                                                        | 0x0            | Table 60        |
| GPREG2  | R/W    | 0x00C             | General purpose register 2                                                        | 0x0            | Table 60        |
| GPREG3  | R/W    | 0x010             | General purpose register 3                                                        | 0x0            | Table 60        |
| DPDCTRL | R/W    | 0x014             | Deep power-down control register. Also includes bits for general purpose storage. | 0x0            | <u>Table 61</u> |

#### 6.6.1 Power control register

The power control register selects whether one of the ARM Cortex-M0+ controlled power-down modes (Sleep mode or Deep-sleep/Power-down mode) or the Deep power-down mode is entered and provides the flags for Sleep or Deep-sleep/Power-down modes and Deep power-down modes respectively.

| Bit   | Symbol    | Value | Description                                                                                                                                                                                                                                                                                                                                               | Reset<br>value |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 2:0   | PM        |       | Power mode                                                                                                                                                                                                                                                                                                                                                | 000            |
|       |           | 0x0   | Default. The part is in active or sleep mode.                                                                                                                                                                                                                                                                                                             |                |
|       |           | 0x1   | Deep-sleep mode. ARM WFI will enter Deep-sleep mode.                                                                                                                                                                                                                                                                                                      |                |
|       |           | 0x2   | Power-down mode. ARM WFI will enter Power-down mode.                                                                                                                                                                                                                                                                                                      |                |
|       |           | 0x3   | Deep power-down mode. ARM WFI will enter<br>Deep-power down mode (ARM Cortex-M0+ core<br>powered-down).                                                                                                                                                                                                                                                   | _              |
| 3     | NODPD     |       | A 1 in this bit prevents entry to Deep power-down mode<br>when 0x3 is written to the PM field above, the<br>SLEEPDEEP bit is set, and a WFI is executed.<br>This bit is cleared only by power-on reset, so writing a one<br>to this bit locks the part in a mode in which Deep<br>power-down mode is blocked.<br>Reserved. Do not write ones to this bit. |                |
| 7:4   | -         | -     | Reserved. Do not write ones to this bit.                                                                                                                                                                                                                                                                                                                  |                |
| 8     | SLEEPFLAG |       | Sleep mode flag                                                                                                                                                                                                                                                                                                                                           | 0              |
|       |           | 0     | Active mode. Read: No power-down mode entered. Part<br>is in Active mode.<br>Write: No effect.                                                                                                                                                                                                                                                            |                |
|       |           | 1     | Low power mode. Read: Sleep, Deep-sleep or<br>Power-down mode entered.<br>Write: Writing a 1 clears the SLEEPFLAG bit to 0.                                                                                                                                                                                                                               |                |
| 10:9  | -         | -     | Reserved. Do not write ones to this bit.                                                                                                                                                                                                                                                                                                                  | 0              |
| 11    | DPDFLAG   |       | Deep power-down flag                                                                                                                                                                                                                                                                                                                                      | 0              |
|       |           | 0     | Not Deep power-down. Read: Deep power-down mode<br><b>not</b> entered.<br>Write: No effect.                                                                                                                                                                                                                                                               | 0              |
|       |           | 1     | Deep power-down. Read: Deep power-down mode<br>entered.<br>Write: Clear the Deep power-down flag.                                                                                                                                                                                                                                                         |                |
| 31:12 | -         | -     | Reserved. Do not write ones to this bit.                                                                                                                                                                                                                                                                                                                  | 0              |

 Table 59.
 Power control register (PCON, address 0x4002 0000) bit description

#### 6.6.2 General purpose registers 0 to 3

The general purpose registers retain data through the Deep power-down mode when power is still applied to the  $V_{DD}$  pin but the chip has entered Deep power-down mode. Only a cold boot - when all power has been completely removed from the chip - will reset the general purpose registers.

UM11021

| Bit  | Symbol |                                            | Reset<br>value |  |  |  |
|------|--------|--------------------------------------------|----------------|--|--|--|
| 31:0 | GPDATA | Data retained during Deep power-down mode. | 0x0            |  |  |  |

## Table 60. General purpose registers 0 to 3 (GPREG[0:3], address 0x4002 0004 (GPREG0) to 0x4002 0010 (GPREG3)) bit description

#### 6.6.3 Deep power-down control register

The Deep power-down control register controls the low-power oscillator that can be used by the self-wake-up timer to wake up from Deep power-down mode. In addition, this register configures the functionality of the WAKEUP pin (PIO0\_4).

The bits in the register not used for deep power-down control (bits 31:4) can be used for storing additional data which are retained in Deep power-down mode in the same way as registers GPREG0 to GPREG3.

**Remark:** If there is a possibility that the external voltage applied on pin  $V_{DD}$  drops below 2.2 V during Deep power-down, the hysteresis of the WAKEUP input pin has to be disabled in this register before entering Deep power-down mode in order for the chip to wake up.

**Remark:** Enabling the low-power oscillator in Deep power-down mode increases the power consumption. Only enable this oscillator if you need the self-wake-up timer to wake up the part from Deep power-down mode. You may need the self-wake-up timer if the wake-up pin is used for other purposes and the wake-up function is not available.

#### Table 61. Deep power down control register (DPDCTRL, address 0x4002 0014) bit description

| Bit | Symbol              | Value | Description                                                                                                                                                                                           | Reset<br>value |
|-----|---------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | WAKEUPHYS           |       | WAKEUP pin hysteresis enable                                                                                                                                                                          | 0              |
|     |                     | 0     | Disabled. Hysteresis for WAKEUP pin disabled.                                                                                                                                                         |                |
|     |                     | 1     | Enabled. Hysteresis for WAKEUP pin enabled.                                                                                                                                                           |                |
| 1   | WAKEPAD_<br>DISABLE |       | WAKEUP pin disable. Setting this bit disables the wake-up pin, so it can be used for other purposes.                                                                                                  | 0              |
|     |                     |       | <b>Remark:</b> Never set this bit if you intend to use a pin to wake up the part from Deep power-down mode. You can only disable the wake-up pin if the self-wake-up timer is enabled and configured. |                |
|     |                     |       | <b>Remark:</b> Setting this bit is not necessary if Deep power-down mode is not used.                                                                                                                 |                |
|     |                     | 0     | Enabled. The wake-up function is enabled on pin PIO0_4.                                                                                                                                               |                |
|     |                     | 1     | Disabled. Setting this bit disables the wake-up function on pin PIO0_4.                                                                                                                               |                |
| 2   | LPOSCEN             |       | Enable the low-power oscillator for use with the 10 kHz self-wake-up timer clock. You must set this bit if the CLKSEL bit in the self-wake-up timer CTRL bit is set.                                  | 0              |
|     |                     |       | Do not enable the low-power oscillator if the self-wake-up timer is clocked by the divided IRC or the external clock input.                                                                           |                |
|     |                     | 0     | Disabled.                                                                                                                                                                                             |                |
|     |                     | 1     | Enabled.                                                                                                                                                                                              |                |

#### Chapter 6: LPC83x Reduced power modes and power management

| Bit  | Symbol                 | Value | Description                                                                                                                                                                                                                                                                                                 | Reset<br>value |
|------|------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3    | LPOSCDPDEN             |       | Enable the low-power oscillator in Deep power-down mode. Setting this bit causes the low-power oscillator to remain running during Deep power-down mode provided that bit 2 in this register is set as well.                                                                                                | 0              |
|      |                        |       | You must set this bit for the self-wake-up timer to be able to wake up the part from Deep power-down mode.                                                                                                                                                                                                  |                |
|      |                        |       | <b>Remark:</b> Do not set this bit unless you use the self-wake-up timer with the low-power oscillator clock source to wake up from Deep power-down mode.                                                                                                                                                   |                |
|      |                        | 0     | Disabled.                                                                                                                                                                                                                                                                                                   |                |
|      |                        | 1     | Enabled.                                                                                                                                                                                                                                                                                                    |                |
| 4    | WAKEUPCLKHYS           |       | External clock input for the self-wake-up timer WKTCLKIN hysteresis enable.                                                                                                                                                                                                                                 | 0              |
|      |                        | 0     | Disabled. Hysteresis for WAKEUP clock pin disabled.                                                                                                                                                                                                                                                         |                |
|      |                        | 1     | Enabled. Hysteresis for WAKEUP clock pin enabled.                                                                                                                                                                                                                                                           |                |
| 5    | WAKECLKPAD_<br>DISABLE |       | Disable the external clock input for the self-wake-up timer. Setting this bit<br>enables the self-wake-up timer clock pin WKTCLKLIN. To minimize power<br>consumption, especially in deep power-down mode, disable this clock input<br>when not using the external clock option for the self-wake-up timer. | 0              |
|      |                        | 0     | Disabled. Setting this bit disables external clock input on pin PIO0_28.                                                                                                                                                                                                                                    | 1              |
|      |                        | 1     | Enabled. The external clock input for the self-wake-up timer is enabled on pin PIO0_28.                                                                                                                                                                                                                     | 1              |
| 31:6 | -                      |       | Data retained during Deep power-down mode.                                                                                                                                                                                                                                                                  | 0x0            |

#### Table 61. Deep power down control register (DPDCTRL, address 0x4002 0014) bit description ...continued

### 6.7 Functional description

#### 6.7.1 Power management

The part supports a variety of power control features. In Active mode, when the chip is running, power and clocks to selected peripherals can be optimized for power consumption. In addition, there are four special modes of processor power reduction with different peripherals running: Sleep mode, Deep-sleep mode, Power-down mode, and Deep power-down mode.

| Peripheral | Sleep mode            | Deep-sleep<br>mode       | Power-down<br>mode       | Deep<br>power-down<br>mode |
|------------|-----------------------|--------------------------|--------------------------|----------------------------|
| IRC        | software configurable | on                       | off                      | off                        |
| IRC output | software configurable | off                      | off                      | off                        |
| Flash      | software configurable | on                       | off                      | off                        |
| BOD        | software configurable | software<br>configurable | software<br>configurable | off                        |
| PLL        | software configurable | off                      | off                      | off                        |
| SysOsc     | software configurable | off                      | off                      | off                        |

#### Table 62. Peripheral configuration in reduced power modes

#### Chapter 6: LPC83x Reduced power modes and power management

| Peripheral                  | Sleep mode            | Deep-sleep<br>mode       | Power-down<br>mode       | Deep<br>power-down<br>mode |
|-----------------------------|-----------------------|--------------------------|--------------------------|----------------------------|
| WDosc/WWDT                  | software configurable | software<br>configurable | software<br>configurable | off                        |
| Digital peripherals         | software configurable | off                      | off                      | off                        |
| WKT/low-power<br>oscillator | software configurable | software<br>configurable | software<br>configurable | software<br>configurable   |

 Table 62.
 Peripheral configuration in reduced power modes

**Remark:** The Debug mode is not supported in Sleep, Deep-sleep, Power-down, or Deep power-down modes.

#### 6.7.2 Reduced power modes and WWDT lock features

The WWDT lock feature influences the power consumption in any of the power modes because locking the WWDT clock source forces the watchdog oscillator to be on independently of the Deep-sleep and Power-down mode software configuration through the PDSLEEPCFG register. For details see <u>Section 17.5.3 "Using the WWDT lock</u> features".

#### 6.7.3 Active mode

In Active mode, the ARM Cortex-M0+ core, memories, and peripherals are clocked by the system clock or main clock.

The chip is in Active mode after reset and the default power configuration is determined by the reset values of the PDRUNCFG and SYSAHBCLKCTRL registers. The power configuration can be changed during run time.

#### 6.7.3.1 Power configuration in Active mode

Power consumption in Active mode is determined by the following configuration choices:

- The SYSAHBCLKCTRL register controls which memories and peripherals are running (Table 33).
- The power to various analog blocks (PLL, oscillators, the BOD circuit, and the flash block) can be controlled at any time individually through the PDRUNCFG register (<u>Table 52 "Power configuration register (PDRUNCFG, address 0x4004 8238) bit</u> description").
- The clock source for the system clock can be selected from the IRC (default), the system oscillator, or the watchdog oscillator (see Figure 4 and related registers).
- The system clock frequency can be selected by the SYSPLLCTRL (<u>Table 22</u>) and the SYSAHBCLKDIV register (<u>Table 32</u>).
- The USART and CLKOUT use individual peripheral clocks with their own clock dividers. The peripheral clocks can be shut down through the corresponding clock divider registers.

#### 6.7.4 Sleep mode

In Sleep mode, the system clock to the ARM Cortex-M0+ core is stopped and execution of instructions is suspended until either a reset or an interrupt occurs.

Peripheral functions, if selected to be clocked in the SYSAHBCLKCTRL register, 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. The processor state and registers, peripheral registers, and internal SRAM values are maintained, and the logic levels of the pins remain static.

#### 6.7.4.1 Power configuration in Sleep mode

Power consumption in Sleep mode is configured by the same settings as in Active mode:

- The clock remains running.
- The system clock frequency remains the same as in Active mode, but the processor is not clocked.
- Analog and digital peripherals are selected as in Active mode.

#### 6.7.4.2 Programming Sleep mode

The following steps must be performed to enter Sleep mode:

- 1. The PM bits in the PCON register must be set to the default value 0x0.
- The SLEEPDEEP bit in the ARM Cortex-M0+ SCR register must be set to zero (Table 56).
- 3. Use the ARM Cortex-M0+ Wait-For-Interrupt (WFI) instruction.

#### 6.7.4.3 Wake-up from Sleep mode

Sleep mode is exited automatically when an interrupt enabled by the NVIC arrives at the processor or a reset occurs. After wake-up due to an interrupt, the microcontroller returns to its original power configuration defined by the contents of the PDRUNCFG and the SYSAHBCLKDIV registers. If a reset occurs, the microcontroller enters the default configuration in Active mode.

#### 6.7.5 Deep-sleep mode

In Deep-sleep mode, the system clock to the processor is disabled as in Sleep mode. All analog blocks are powered down, except for the BOD circuit and the watchdog oscillator, which can be selected or deselected during Deep-sleep mode in the PDSLEEPCFG register. The main clock, and therefore all peripheral clocks, are disabled except for the clock to the watchdog timer if the watchdog oscillator is selected. The IRC is running, but its output is disabled. The flash is in standby mode.

Deep-sleep mode eliminates all power used by analog peripherals and all dynamic power used by the processor itself, memory systems and related controllers, and internal buses. The processor state and registers, peripheral registers, and internal SRAM values are maintained, and the logic levels of the pins remain static.

#### 6.7.5.1 Power configuration in Deep-sleep mode

Power consumption in Deep-sleep mode is determined by the Deep-sleep power configuration setting in the PDSLEEPCFG (<u>Table 50</u>) register:

• The watchdog oscillator can be left running in Deep-sleep mode if required for the WWDT.

• The BOD circuit can be left running in Deep-sleep mode if required by the application.

#### 6.7.5.2 Programming Deep-sleep mode

The following steps must be performed to enter Deep-sleep mode:

- 1. The PM bits in the PCON register must be set to 0x1 (Table 59).
- 2. Select the power configuration in Deep-sleep mode in the PDSLEEPCFG (<u>Table 50</u>) register.
- Select the power configuration after wake-up in the PDAWAKECFG (<u>Table 51</u>) register.
- 4. If any of the available wake-up interrupts are needed for wake-up, enable the interrupts in the interrupt wake-up registers (<u>Table 48</u>, <u>Table 49</u>) and in the NVIC.
- 5. Select the IRC as the main clock. See <u>Table 30</u>.
- 6. Write one to the SLEEPDEEP bit in the ARM Cortex-M0+ SCR register (Table 56).
- 7. Use the ARM WFI instruction.

#### 6.7.5.3 Wake-up from Deep-sleep mode

The microcontroller can wake up from Deep-sleep mode in the following ways:

- Signal on one of the eight pin interrupts selected in <u>Table 47</u>. Each pin interrupt must also be enabled in the STARTERP0 register (<u>Table 48</u>) and in the NVIC.
- BOD signal, if the BOD is enabled in the PDSLEEPCFG register:
  - BOD interrupt using the deep-sleep interrupt wake-up register 1 (<u>Table 49</u>). The BOD interrupt must be enabled in the NVIC. The BOD interrupt must be selected in the BODCTRL register.
  - Reset from the BOD circuit. In this case, the BOD circuit must be enabled in the PDSLEEPCFG register, and the BOD reset must be enabled in the BODCTRL register (<u>Table 43</u>).
- WWDT signal, if the watchdog oscillator is enabled in the PDSLEEPCFG register:
  - WWDT interrupt using the interrupt wake-up register 1 (<u>Table 49</u>). The WWDT interrupt must be enabled in the NVIC. The WWDT interrupt must be set in the WWDT MOD register, and the WWDT must be enabled in the SYSAHBCLKCTRL register.
  - Reset from the watchdog timer. The WWDT reset must be set in the WWDT MOD register. In this case, the watchdog oscillator must be running in Deep-sleep mode (see PDSLEEPCFG register), and the WDT must be enabled in the SYSAHBCLKCTRL register.
- Via any of the USART blocks if the USART is configured in synchronous mode. See <u>Section 13.3.2 "Configure the USART for wake-up"</u>.
- Via the I2C. See Section 15.3.3.
- Via any of the SPI blocks. See <u>Section 14.3.1</u>.

#### 6.7.6 Power-down mode

In Power-down mode, the system clock to the processor is disabled as in Sleep mode. All analog blocks are powered down, except for the BOD circuit and the watchdog oscillator, which must be selected or deselected during Power-down mode in the PDSLEEPCFG

register. The main clock and therefore all peripheral clocks are disabled except for the clock to the watchdog timer if the watchdog oscillator is selected. The IRC itself and the flash are powered down, decreasing power consumption compared to Deep-sleep mode.

Power-down mode eliminates all power used by analog peripherals and all dynamic power used by the processor itself, memory systems and related controllers, and internal buses. The processor state and registers, peripheral registers, and internal SRAM values are maintained, and the logic levels of the pins remain static. Wake-up times are longer compared to the Deep-sleep mode.

#### 6.7.6.1 Power configuration in Power-down mode

Power consumption in Power-down mode can be configured by the power configuration setting in the PDSLEEPCFG (<u>Table 50</u>) register in the same way as for Deep-sleep mode (see <u>Section 6.7.5.1</u>):

- The watchdog oscillator can be left running in Power-down mode if required for the WWDT.
- The BOD circuit can be left running in Power-down mode if required by the application.

#### 6.7.6.2 Programming Power-down mode

The following steps must be performed to enter Power-down mode:

- 1. The PM bits in the PCON register must be set to 0x2 (Table 59).
- 2. Select the power configuration in Power-down mode in the PDSLEEPCFG (Table 50) register.
- Select the power configuration after wake-up in the PDAWAKECFG (<u>Table 51</u>) register.
- 4. If any of the available wake-up interrupts are used for wake-up, enable the interrupts in the interrupt wake-up registers (Table 48, Table 49) and in the NVIC.
- 5. Select the IRC as the main clock. See <u>Table 30</u>.
- 6. Write one to the SLEEPDEEP bit in the ARM Cortex-M0+ SCR register (Table 56).
- 7. Use the ARM WFI instruction.

#### 6.7.6.3 Wake-up from Power-down mode

The microcontroller can wake up from Power-down mode in the same way as from Deep-sleep mode:

- Signal on one of the eight pin interrupts selected in <u>Table 47</u>. Each pin interrupt must also be enabled in the STARTERP0 register (<u>Table 48</u>) and in the NVIC.
- BOD signal, if the BOD is enabled in the PDSLEEPCFG register:
  - BOD interrupt using the interrupt wake-up register 1 (<u>Table 49</u>). The BOD interrupt must be enabled in the NVIC. The BOD interrupt must be selected in the BODCTRL register.
  - Reset from the BOD circuit. In this case, the BOD reset must be enabled in the BODCTRL register (Table 43).
- WWDT signal, if the watchdog oscillator is enabled in the PDSLEEPCFG register:

UM11021

- WWDT interrupt using the interrupt wake-up register 1 (<u>Table 49</u>). The WWDT interrupt must be enabled in the NVIC. The WWDT interrupt must be set in the WWDT MOD register.
- Reset from the watchdog timer. The WWDT reset must be set in the WWDT MOD register.
- Via any of the USART blocks. See <u>Section 13.3.2 "Configure the USART for</u> <u>wake-up"</u>.
- Via the I2C. See Section 15.3.3.
- Via any of the SPI blocks. See <u>Section 14.3.1</u>.

#### 6.7.7 Deep power-down mode

In Deep power-down mode, power and clocks are shut off to the entire chip with the exception of the WAKEUP pin and the self-wake-up timer.

During Deep power-down mode, the contents of the SRAM and registers are not retained except for a small amount of data which can be stored in the general purpose registers of the PMU block.

All functional pins are tri-stated in Deep power-down mode except for the WAKEUP pin. In this mode, you must pull the RESET pin HIGH externally.

**Remark:** Setting bit 3 in the PCON register (<u>Table 59</u>) prevents the part from entering Deep-power down mode.

#### 6.7.7.1 Power configuration in Deep power-down mode

Deep power-down mode has no configuration options. All clocks, the core, and all peripherals are powered down. Only the WAKEUP pin and the self-wake-up timer are powered.

#### 6.7.7.2 Programming Deep power-down mode using the WAKEUP pin:

The following steps must be performed to enter Deep power-down mode when using the WAKEUP pin for waking up:

- 1. Pull the WAKEUP pin externally HIGH.
- 2. Ensure that bit 3 in the PCON register (Table 59) is cleared.
- 3. Write 0x3 to the PM bits in the PCON register (see Table 59).
- 4. Store data to be retained in the general purpose registers (Section 6.6.2).
- 5. Write one to the SLEEPDEEP bit in the ARM Cortex-M0+ SCR register (Table 56).
- 6. Use the ARM WFI instruction.

#### 6.7.7.3 Wake-up from Deep power-down mode using the WAKEUP pin:

Pulling the WAKEUP pin LOW wakes up the LPC800 from Deep power-down, and the part goes through the entire reset process.

- 1. On the WAKEUP pin, transition from HIGH to LOW.
  - The PMU will turn on the on-chip voltage regulator. When the core voltage reaches the power-on-reset (POR) trip point, a system reset will be triggered and the chip re-boots.

- All registers except the DPDCTRL and GPREG0 to GPREG3 registers and PCON will be in their reset state.
- 2. Once the chip has booted, read the deep power-down flag in the PCON register (Table 59) to verify that the reset was caused by a wake-up event from Deep power-down and was not a cold reset.
- 3. Clear the deep power-down flag in the PCON register (Table 59).
- 4. (Optional) Read the stored data in the general purpose registers (Section 6.6.2).
- 5. Set up the PMU for the next Deep power-down cycle.

**Remark:** The **RESET** pin has no functionality in Deep power-down mode.

#### 6.7.7.4 Programming Deep power-down mode using the self-wake-up timer:

The following steps must be performed to enter Deep power-down mode when using the self-wake-up timer for waking up:

- Enable the low-power oscillator to run in Deep power-down mode by setting bits 2 and 3 in the DPDCTRL register to 1 (see <u>Table 61</u>)
- 2. Ensure that bit 3 in the PCON register (Table 59) is cleared.
- 3. Write 0x3 to the PM bits in the PCON register (see Table 59).
- 4. Store data to be retained in the general purpose registers (Section 6.6.2).
- 5. Write one to the SLEEPDEEP bit in the ARM Cortex-M0+ SCR register.
- 6. Start the self-wake-up timer by writing a value to the WKT COUNT register (Table 259).
- 7. Use the ARM WFI instruction.

#### 6.7.7.5 Wake-up from Deep power-down mode using the self-wake-up timer:

The part goes through the entire reset process when the self-wake-up timer times out:

- 1. When the WKT count reaches 0, the following happens:
  - The PMU will turn on the on-chip voltage regulator. When the core voltage reaches the power-on-reset (POR) trip point, a system reset will be triggered and the chip re-boots.
  - All registers except the DPDCTRL and GPREG0 to GPREG3 registers and PCON are in their reset state.
- Once the chip has booted, read the deep power-down flag in the PCON register (<u>Table 59</u>) to verify that the reset was caused by a wake-up event from Deep power-down and was not a cold reset.
- 3. Clear the deep power-down flag in the PCON register (Table 59).
- 4. (Optional) Read the stored data in the general purpose registers (Section 6.6.2).
- 5. Set up the PMU for the next Deep power-down cycle.

**Remark:** The RESET pin has no functionality in Deep power-down mode.

Chapter 7: LPC83x Switch matrix (SWM)

Rev. 1.1 — 5 October 2016

**User manual** 

# 7.1 How to read this chapter

The switch matrix is identical for all LPC83x parts.

# 7.2 Features

- · Flexible assignment of digital peripheral functions to pins
- Enable/disable of analog functions

# 7.3 Basic configuration

Once configured, no clocks are needed for the switch matrix to function. The system clock is needed only to write to or read from the pin assignment registers. After the switch matrix is configured, disable the clock to the switch matrix block in the SYSAHBCLKCTRL register.

Before activating a peripheral or enabling its interrupt, use the switch matrix to connect the peripheral to external pins.

The serial wire debug pins SWDIO and SWCLK are enabled by default on pins PIO0\_2 and PIO0\_3.

**Remark:** For the purpose of programming the pin functions through the switch matrix, every pin except the power and ground pins is identified in a package-independent way by its GPIO port pin number.

**Remark:** The switch matrix is reset by a system reset from the  $\overrightarrow{\text{RESET}}$  pin as well as all other resets.



7.3.1 Connect an internal signal to a package pin

The switch matrix connects all internal signals listed in the table of movable functions through the pin assignment registers to external pins on the package. External pins are identified by their default GPIO pin number PIO0\_n. Follow these steps to connect an internal signal FUNC to an external pin. An example of a movable function is the UART transmit signal TXD:

- 1. Find the pin function in the list of movable functions in <u>Table 63</u> or in the data sheet.
- 2. Use the LPC800 data sheet to decide which pin x on the LPC800 package to connect the pin function to.
- 3. Use the pin description table to find the default GPIO function PIO0\_n assigned to package pin x. m is the pin number.
- 4. Locate the pin assignment register for the function FUNC in the switch matrix register description.
- 5. Disable any special functions on pin PIO0\_n in the PINENABLE0 register.
- 6. Program the pin number n into the bits assigned to the pin function.

The pin function is now connected to pin x on the package.

### 7.3.2 Enable an analog input or other special function

The switch matrix enables functions that can only be assigned to one pin. Examples are analog inputs, all GPIO pins, and the debug SWD pins.

• If you want to assign a GPIO pin to a pin on any LPC800 package, disable any special function available on this pin in the PINENABLE0 register and do not assign any movable function to it.

By default, all pins except pins PIO0\_2, PIO0\_3, and PIO0\_5 are assigned to GPIO.

- For all other functions that are not in the table of movable functions, do the following:
  - a. Locate the function in the pin description table in the data sheet. This shows the package pin for this function.
  - b. Enable the function in the PINENABLE0 register. All other possible functions on this pins are now disabled.

### 7.3.3 Changing the pin function assignment

Pin function assignments can be changed "on-the-fly" from one peripheral to another while the part is running. To disconnect a peripheral from the pins and change the pin function assignment, follow these steps:

- 1. Enable the clock to the switch matrix.
- 2. Find the pin assign register for the current pin function. For example, register PINASSIGN0 for pin function U0\_RXD.
- 3. Set the corresponding bits in the PINASSIGN register to their default value 0xFF.
- 4. Clear all pending interrupts for the disconnected peripheral and ensure that the peripheral is in a defined state.
- 5. In the pin assign register for the new pin function, program the pin number.
- 6. Disable the clock to the switch matrix.

# 7.4 General description

The switch matrix connects internal signals (functions) to external pins. Functions are signals coming from or going to a single pin on the package and coming from or going to an on-chip peripheral block. Examples of functions are the GPIOs, the UART transmit output (TXD), or the clock output CLKOUT. Many peripherals have several functions that must be connected to external pins.

The switch matrix also enables the output driver for digital functions that are outputs. The electrical pin characteristics for both inputs and outputs (internal pull-up/down resistors, inverter, digital filter, open-drain mode) are configured by the IOCON block for each pin.

Most functions can be assigned through the switch matrix to any external pin that is not a power or ground pin. These functions are called movable functions.

A few functions like the crystal oscillator pins (XTALIN/XTALOUT) can only be assigned to one particular external pin with the appropriate electrical characteristics. These functions are called fixed-pin functions. If a fixed-pin function is not used, it can be replaced by any other movable function.

For fixed-pin analog functions, the switch matrix enables the analog input or output and disables the digital pad.

GPIOs are special fixed-pin functions. Each GPIO is assigned to one and only one external pin by default. External pins are therefore identified by their fixed-pin GPIO function. The level on a digital input is always reflected in the GPIO port register and in the pin interrupt/pattern match state, if selected, regardless of which (digital) function is assigned to the pin through the switch matrix.



**Remark:** From all movable and fixed-pin functions, you can assign multiple functions to the same pin but no more than one output or bidirectional function (see <u>Figure 8</u>). Use the following guidelines when assigning pins:

 It is allowed to connect one input signal on a pin to multiple internal inputs by programming the same pin number in more than one PINASSIGN register.
 Example:

You can enable the CLKIN input in the PINENABLE0 register on pin PIO0\_1 and also assign one ore more SCT inputs to pin PIO0\_1 through the PINASSIGN registers to feed the CLKIN into the SCT.

You can send the input on one pin to all SCT inputs to use as an SCT abort signal.

• It is allowed to let one digital output function control one or more digital inputs by programming the same pin number in the PINASSIGN register bit fields for the output and inputs.

Example:

You can loop back the USART transmit output to the receive input by assigning the same pin number to Un\_RXD and Un\_TXD.

• It is not allowed to connect more than one output or bidirectional function to a pin.

- When you assign any function to a pin through the switch matrix, the GPIO output becomes disabled.
- Enabling any analog fixed-pin function disables all digital functions on the same pin.

### 7.4.1 Movable functions

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

| Function name Type |     | Description                                               | SWM Pin assign<br>register | Reference |
|--------------------|-----|-----------------------------------------------------------|----------------------------|-----------|
| U0_TXD             | 0   | Transmitter output for USART0.                            | PINASSIGN0                 | Table 65  |
| U0_RXD             | I   | Receiver input for USART0.                                | PINASSIGN0                 | Table 65  |
| U0_RTS             | 0   | Request To Send output for USART0. PINASSIGN0             |                            | Table 65  |
| U0_CTS             | I   | Clear To Send input for USART0.                           | PINASSIGN0                 | Table 65  |
| U0_SCLK            | I/O | Serial clock input/output for USART0 in synchronous mode. | PINASSIGN1                 | Table 66  |
| SPI0_SCK           | I/O | Serial clock for SPI0.                                    | PINASSIGN3                 | Table 67  |
| SPI0_MOSI          | I/O | Master Out Slave In for SPI0.                             | PINASSIGN4                 | Table 68  |
| SPI0_MISO          | I/O | Master In Slave Out for SPI0.                             | PINASSIGN4                 | Table 68  |
| SPI0_SSEL0         | I/O | Slave select 0 for SPI0.                                  | PINASSIGN4                 | Table 68  |
| SPI0_SSEL1         | I/O | Slave select 0 for SPI1.                                  | PINASSIGN4                 | Table 68  |
| SPI0_SSEL2         | I/O | Slave select 0 for SPI2.                                  | PINASSIGN5                 | Table 69  |
| SPI0_SSEL3         | I/O | Slave select 0 for SPI3.                                  | PINASSIGN5                 | Table 69  |
| SPI1_SCK           | I/O | Serial clock for SPI1.                                    | PINASSIGN5                 | Table 69  |
| SPI1_MOSI          | I/O | Master Out Slave In for SPI1.                             | PINASSIGN5                 | Table 69  |
| SPI1_MISO          | I/O | Master In Slave Out for SPI1.                             | PINASSIGN6                 | Table 70  |
| SPI1_SSEL0         | I/O | Slave select 0 for SPI1.                                  | PINASSIGN6                 | Table 70  |
| SPI1_SSEL1         | I/O | Slave select 1 for SPI1.                                  | PINASSIGN6                 | Table 70  |
| SCT_PIN0           | I   | Pin input 0 to the SCT input multiplexer.                 | PINASSIGN6                 | Table 70  |
| SCT_PIN1           | I   | Pin input 1 to the SCT input multiplexer.                 | PINASSIGN7                 | Table 71  |
| SCT_PIN2           | I   | Pin input 2 to the SCT input multiplexer.                 | PINASSIGN7                 | Table 71  |
| SCT_PIN3           | I   | Pin input 3 to the SCT input multiplexer.                 | PINASSIGN7                 | Table 71  |
| SCT_OUT0           | 0   | SCT output 0.                                             | PINASSIGN7                 | Table 71  |
| SCT_OUT1           | 0   | SCT output 1.                                             | PINASSIGN8                 | Table 72  |
| SCT_OUT2           | 0   | SCT output 2.                                             | PINASSIGN8                 | Table 72  |
| SCT_OUT3           | 0   | SCT output 3.                                             | PINASSIGN8                 | Table 72  |
| SCT_OUT4           | 0   | SCT output 4.                                             | PINASSIGN8                 | Table 72  |
| SCT_OUT5           | 0   | SCT output 5.                                             | PINASSIGN9                 | Table 73  |
| ADC_PINTRIG0       | I   | ADC external pin trigger input 0.                         | PINASSIGN10                | Table 74  |
| ADC_PINTRIG1       | I   | ADC external pin trigger input 1.                         | PINASSIGN11                | Table 75  |
| CLKOUT             | 0   | Clock output.                                             | PINASSIGN11                | Table 75  |
| GPIO_INT_BMAT      | 0   | Output of the pattern match engine.                       | PINASSIGN11                | Table 75  |

### 7.4.2 Switch matrix register interface

The switch matrix consists of two blocks of pin-assignment registers PINASSIGN and PINENABLE. Every function has an assigned field (1-bit or 8-bit wide) within this bank of registers where you can program the external pin - identified by its GPIO function - you want the function to connect to.

GPIOs range from PIO0\_0 to PIO0\_28 and, for assignment through the pin-assignment registers, are numbered 0 to 28.

There are two types of functions which must be assigned to port pins in different ways:

1. Movable functions (PINASSIGN0 to 11):

All movable functions are digital functions. Assign movable functions to pin numbers through the 8 bits of the PINASSIGN register associated with this function. Once the function is assigned a pin PIO0\_n, it is connected through this pin to a physical pin on the package.

**Remark:** You can assign only one digital output function to an external pin at any given time.

Remark: You can assign more than one digital input function to one external pin.

2. Fixed-pin functions (PINENABLE0):

Some functions require pins with special characteristics and cannot be moved to other physical pins. Hence these functions are mapped to a fixed port pin. Examples of fixed-pin functions are the oscillator pins.

Each fixed-pin function is associated with one bit in the PINENABLE0 register which selects or deselects the function.

- If a fixed-pin function is deselected, any movable function can be assigned to its port and pin.
- If a fixed-pin function is deselected and no movable function is assigned to this pin, the pin is assigned its GPIO function.
- On reset, all fixed-pin functions are deselected.
- If a fixed-pin analog function is selected, its assigned pin cannot be used for any other function.

# 7.5 Register description

#### Table 64. Register overview: Switch matrix (base address 0x4000 C000)

| Name       | Access | Offset | Description                                                                     | Reset value | Reference |
|------------|--------|--------|---------------------------------------------------------------------------------|-------------|-----------|
| PINASSIGN0 | R/W    | 0x000  | Pin assign register 0. Assign movable functions U0_TXD, U0_RXD, U0_RTS, U0_CTS. | 0xFFFF FFFF | Table 65  |
| PINASSIGN1 | R/W    | 0x004  | Pin assign register 1. Assign movable functions U0_SCLK.                        | 0xFFFF FFFF | Table 66  |
| PINASSIGN3 | R/W    | 0x00C  | Pin assign register 3. Assign movable function SPI0_SCK.                        | 0xFFFF FFFF | Table 67  |

UM11021

| Name        | Access | Offset | Description                                                                                           | Reset value                     | Reference |  |
|-------------|--------|--------|-------------------------------------------------------------------------------------------------------|---------------------------------|-----------|--|
| PINASSIGN4  | R/W    | 0x010  | Pin assign register 4. Assign movable<br>functions SPI0_MOSI, SPI0_MISO,<br>SPI0_SSEL0, SPI0_SSEL1.   | functions SPI0_MOSI, SPI0_MISO, |           |  |
| PINASSIGN5  | R/W    | 0x014  | Pin assign register 5. Assign movable<br>functions SPI0_SSEL2, SPI0_SSEL3,<br>SPI1_SCK, SPI1_MOSI     | 0xFFFF FFFF                     | Table 69  |  |
| PINASSIGN6  | R/W    | 0x018  | Pin assign register 6. Assign movable<br>functions SPI1_MISO, SPI1_SSEL0,<br>SPI1_SSEL1, SCT0_IN0.    | 0xFFFF FFFF                     | Table 70  |  |
| PINASSIGN7  | R/W    | 0x01C  | Pin assign register 7. Assign movable<br>functions SCT_IN1, SCT_IN2, SCT_IN3,<br>SCT_OUT0.            | 0xFFFF FFFF                     | Table 71  |  |
| PINASSIGN8  | R/W    | 0x020  | Pin assign register 8. Assign movable<br>functions SCT_OUT1, SCT_OUT2,<br>SCT_OUT3, SCT_OUT4.         | 0xFFFF FFFF                     | Table 72  |  |
| PINASSIGN9  | R/W    | 0x024  | Pin assign register 9. Assign movable functions SCT_OUT5.                                             | 0xFFFF FFFF                     | Table 73  |  |
| PINASSIGN10 | R/W    | 0x028  | Pin assign register 10. Assign movable functions ADC_PINTRIG0.                                        | 0xFFFF FFFF                     | Table 74  |  |
| PINASSIGN11 | R/W    | 0x02C  | Pin assign register 11. Assign movable<br>functions ADC_PINTRIG1, CLKOUT,<br>GPIO_INT_BMAT            | 0xFFFF FFFF                     | Table 75  |  |
| PINENABLE0  | R/W    | 0x1C0  | Pin enable register 0. Enables fixed-pin<br>functions SWCLK, SWDIO, XTALIN,<br>XTALOUT, RESET, CLKIN. | 0xFFFF FECF                     | Table 76  |  |

#### Table 64. Register overview: Switch matrix (base address 0x4000 C000) ... continued

### 7.5.1 Pin assign register 0

#### Table 65. Pin assign register 0 (PINASSIGN0, address 0x4000 C000) bit description

| Bit   | Symbol   | Description                                                                                                                                                      | Reset<br>value |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | U0_TXD_O | U0_TXD function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 15:8  | U0_RXD_I | U0_RXD function assignment. The value is the pin number to be assigned to this function. The following pins are available: PIO0_0 (= 0) to PIO0_28 (= 0x1C).     | 0xFF           |
| 23:16 | U0_RTS_O | U0_RTS function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 31:24 | U0_CTS_I | U0_CTS function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |

### 7.5.2 Pin assign register 1

#### Table 66. Pin assign register 1 (PINASSIGN1, address 0x4000 C004) bit description

| Bit  | Symbol     | Description                                                                                                                                                       | Reset<br>value |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | U0_SCLK_IO | U0_SCLK function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 31:8 | -          | Reserved                                                                                                                                                          | -              |

### 7.5.3 Pin assign register 3

#### Table 67. Pin assign register 3 (PINASSIGN3, address 0x4000 C00C) bit description

| Bit   | Symbol      | Description                                                                                                                                                           | Reset<br>value |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | -           | Reserved                                                                                                                                                              | -              |
| 31:24 | SPI0_SCK_IO | SPI0_SCK function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= $0x1C$ ). | 0xFF           |

### 7.5.4 Pin assign register 4

#### Table 68. Pin assign register 4 (PINASSIGN4, address 0x4000 C010) bit description

| Bit   | Symbol            | Description                                                                                                                                                          | Reset<br>value |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | SPI0_MOSI_IO      | SPI0_MOSI function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C).  | 0xFF           |
| 15:8  | SPI0_MISO_IO      | SPI0_MISIO function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 23:16 | SPI0_SSEL0_I<br>O | SPI0_SSEL0 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 31:24 | SPI0_SSEL1_I<br>O | SPI0_SSEL1 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |

### 7.5.5 Pin assign register 5

#### Table 69. Pin assign register 5 (PINASSIGN5, address 0x4000 C014) bit description

| Bit   | Symbol            | Description                                                                                                                                                          | Reset<br>value |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | SPI0_SSEL2_I<br>O | SPI0_SSEL2 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 15:8  | SPI0_SSEL3_I<br>O | SPI0_SSEL3 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 23:16 | SPI1_SCK_IO       | SPI1_SCK function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C).   | 0xFF           |
| 31:24 | SPI1_MOSI_IO      | SPI1_MOSI function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C).  | 0xFF           |

### 7.5.6 Pin assign register 6

#### Table 70. Pin assign register 6 (PINASSIGN6, address 0x4000 C018) bit description

| Bit   | Symbol            | Description                                                                                                                                                          | Reset<br>value |
|-------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | SPI1_MISO_IO      | SPI1_MISO function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C).  | 0xFF           |
| 15:8  | SPI1_SSEL0_I<br>O | SPI1_SSEL0 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 23:16 | SPI1_SSEL1_I<br>O | SPI1_SSEL1 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 31:24 | SCT_PIN0_I        | SCT_PIN0 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C).   | 0xFF           |

### 7.5.7 Pin assign register 7

#### Table 71. Pin assign register 7 (PINASSIGN7, address 0x4000 C01C) bit description

| Bit | Symbol     | Description                                                                                                                                                        | Reset<br>value |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0 | SCT_PIN1_I | SCT_PIN1 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |

| Table 71. | Pin assign register | 7 (PINASSIGN7 | address 0x4000 | C01C) bit description |
|-----------|---------------------|---------------|----------------|-----------------------|
|-----------|---------------------|---------------|----------------|-----------------------|

| Bit   | Symbol     | Description                                                                                                                                                        | Reset<br>value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:8  | SCT_PIN2_I | SCT_PIN2 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 23:16 | SCT_PIN3_I | SCT_PIN3 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |
| 31:24 | SCT_OUT0_O | SCT_OUT0 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIO0_0$ (= 0) to $PIO0_28$ (= 0x1C). | 0xFF           |

### 7.5.8 Pin assign register 8

#### Table 72. Pin assign register 8 (PINASSIGN8, address 0x4000 C020) bit description

| Bit   | Symbol     | Description                                                                                                                                                              | Reset<br>value |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | SCT_OUT1_O | SCT_OUT1 function assignment. The value is the pin<br>number to be assigned to this function. The following pins<br>are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C). | 0xFF           |
| 15:8  | SCT_OUT2_O | SCT_OUT2 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C).       | 0xFF           |
| 23:16 | SCT_OUT3_O | SCT_OUT3 function assignment. The value is the pin<br>number to be assigned to this function. The following pins<br>are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C). | 0xFF           |
| 31:24 | SCT_OUT4_O | SCT_OUT4 function assignment. The value is the pin<br>number to be assigned to this function. The following pins<br>are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C). | 0xFF           |

### 7.5.9 Pin assign register 9

#### Table 73. Pin assign register 9 (PINASSIGN9, address 0x4000 C024) bit description

| Bit  | Symbol     | Description                                                                                                                                                              | Reset<br>value |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | SCT_OUT5_O | SCT_OUT5 function assignment. The value is the pin<br>number to be assigned to this function. The following pins<br>are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C). | 0xFF           |
| 31:8 | -          | Reserved                                                                                                                                                                 | -              |

### 7.5.10 Pin assign register 10

#### Table 74. Pin assign register 10 (PINASSIGN10, address 0x4000 C028) bit description

| Bit   | Symbol         | Description                                                                                                                                                            | Reset<br>value |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | -              | Reserved                                                                                                                                                               | -              |
| 31:24 | ADC_PINTRIG0_I | ADC_PINTRIG0 function assignment. The value is the pin number to be assigned to this function. The following pins are available: $PIOO_0$ (= 0) to $PIOO_28$ (= 0x1C). | 0xFF           |

### 7.5.11 Pin assign register 11

#### Table 75. Pin assign register 11 (PINASSIGN11, address 0x4000 C02C) bit description

| Bit   | Symbol          | Description                                                                                                                                                         | Reset<br>value |  |  |  |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|
| 7:0   | ADC_PINTRIG1_I  | ADC_PINTRIG1 function assignment. The value is the pin number to be assigned to this function. The following pins are available: PIO0_0 (= 0) to PIO0_28 (= 0x1C).  | 0xFF           |  |  |  |
| 15:8  | -               | Reserved                                                                                                                                                            | -              |  |  |  |
| 23:16 | CLKOUT_O        | Reserved                                                                                                                                                            |                |  |  |  |
| 31:24 | GPIO_INT_BMAT_O | GPIO_INT_BMAT function assignment. The value is the pin number to be assigned to this function. The following pins are available: PIO0_0 (= 0) to PIO0_28 (= 0x1C). | 0xFF           |  |  |  |

### 7.5.12 PINENABLE 0

### Table 76. Pin enable register 0 (PINENABLE0, address 0x4000 C1C0) bit description

| Bit | Symbol   | Value | Description                      | Reset<br>value |
|-----|----------|-------|----------------------------------|----------------|
| 3:0 | -        | -     | Reserved                         | -              |
| 4   | SWCLK    |       | SWCLK function select.           | 0              |
|     |          | 0     | SWCLK enabled on pin PIO0_3.     |                |
|     |          | 1     | SWCLK disabled.                  |                |
| 5   | SWDIO    |       | SWDIO function select.           | 0              |
|     |          | 0     | SWDIO enabled on pin PIO0_2.     |                |
|     |          | 1     | SWDIO disabled.                  |                |
| 6   | XTALIN   |       | XTALIN function select.          | 1              |
|     |          | 0     | XTALIN enabled on pin PIO0_8.    |                |
|     |          | 1     | XTALIN disabled.                 |                |
| 7   | XTALOUT  |       | XTALOUT function select.         | 1              |
|     |          | 0     | XTALOUT enabled on pin PIO0_9.   |                |
|     |          | 1     | XTALOUT disabled.                |                |
| 8   | RESETN   |       | RESETN function select.          | 0              |
|     |          | 0     | RESETN enabled on pin PIO0_5.    |                |
|     |          | 1     | RESETN disabled.                 |                |
| 9   | CLKIN    |       | CLKIN function select.           | 1              |
|     |          | 0     | CLKIN enabled on pin PIO0_1.     |                |
|     |          | 1     | CLKIN disabled.                  |                |
| 10  | -        | -     | Reserved                         | -              |
| 11  | I2C0_SDA |       | I2C0_SDA function select.        | 1              |
|     |          | 0     | I2C0_SDA enabled on pin PIO0_11. |                |
|     |          | 1     | I2C0_SDA disabled.               |                |
| 12  | I2C0_SCL |       | I2C0_SCL function select.        | 1              |
|     |          | 0     | I2C0_SCL enabled on pin PIO0_10. |                |

| Bit   | Symbol | Value | Description                    | Reset<br>value |
|-------|--------|-------|--------------------------------|----------------|
|       |        | 1     | I2C0_SCL disabled.             |                |
| 13    | ADC_0  |       | ADC_0 function select.         | 1              |
|       |        | 0     | ADC_0 enabled on pin PIO0_7.   |                |
|       |        | 1     | ADC_0 disabled.                |                |
| 14    | ADC_1  |       | ADC_1 function select.         | 1              |
|       |        | 0     | ADC_1 enabled on pin PIO0_6.   |                |
|       |        | 1     | ADC_1 disabled.                |                |
| 15    | ADC_2  |       | ADC_2 function select.         | 1              |
|       |        | 0     | ADC_2 enabled on pin PIO0_14.  |                |
|       |        | 1     | ADC_2 disabled.                |                |
| 16    | ADC_3  |       | ADC_3 function select.         | 1              |
|       |        | 0     | ADC_3 enabled on pin PIO0_23.  |                |
|       |        | 1     | ADC_3 disabled.                |                |
| 17    | ADC_4  |       | ADC_4 function select.         | 1              |
|       |        | 0     | ADC_4 enabled on pin PIO0_22.  |                |
|       |        | 1     | ADC_4 disabled.                |                |
| 18    | ADC_5  |       | ADC_5 function select.         | 1              |
|       |        | 0     | ADC_5 enabled on pin PIO0_21.  |                |
|       |        | 1     | ADC_5 disabled.                |                |
| 19    | ADC_6  |       | ADC_6 function select.         | 1              |
|       |        | 0     | ADC_6 enabled on pin PIO0_20.  |                |
|       |        | 1     | ADC_6 disabled.                |                |
| 20    | ADC_7  |       | ADC_7 function select.         | 1              |
|       |        | 0     | ADC_7 enabled on pin PIO0_19.  |                |
|       |        | 1     | ADC_7 disabled.                |                |
| 21    | ADC_8  |       | ADC_8 function select.         | 1              |
|       |        | 0     | ADC_8 enabled on pin PIO0_18.  |                |
|       |        | 1     | ADC_8 disabled.                |                |
| 22    | ADC_9  |       | ADC_9 function select.         | 1              |
|       |        | 0     | ADC_9 enabled on pin PIO0_17.  |                |
|       |        | 1     | ADC_9 disabled.                |                |
| 23    | ADC_10 |       | ADC_10 function select.        | 1              |
|       |        | 0     | ADC_10 enabled on pin PIO0_13. |                |
|       |        | 1     | ADC_10 disabled.               |                |
| 24    | ADC_11 |       | ADC_11 function select.        | 1              |
|       |        | 0     | ADC_11 enabled on pin PIO0_4.  |                |
|       |        | 1     | ADC_11 disabled.               |                |
| 31:25 | -      |       | Reserved.                      | 1              |

### Table 76. Pin enable register 0 (PINENABLE0, address 0x4000 C1C0) bit description

Chapter 8: LPC83x I/O configuration (IOCON)

Rev. 1.1 — 5 October 2016

**User manual** 

# 8.1 How to read this chapter

The IOCON block is identical for all LPC83x parts. Registers for pins that are not available on a specific package are reserved.

### Table 77.Pinout summary

| Package | Pins/configuration registers available                |
|---------|-------------------------------------------------------|
| TSSOP20 | PIO0_0 to PIO0_5; PIO0_8 to PIO0_15; PIO0_17; PIO0_23 |
| HVQFN33 | PIO0_0 to PIO0_28                                     |

# 8.2 Features

The following electrical properties are configurable for each pin:

- Pull-up/pull-down resistor
- Open-drain mode
- Hysteresis
- Digital glitch filter with programmable time constant
- Analog mode (for a subset of pins, see the LPC83x data sheet)

The true open-drain pins PIO0\_10 and PIO0\_11 can be configured for different I2C-bus speeds.

# 8.3 Basic configuration

Enable the clock to the IOCON in the SYSAHBCLKCTRL register (<u>Table 33</u>, bit 18). Once the pins are configured, you can disable the IOCON clock to conserve power.

**Remark:** If the open-drain pins PIO0\_10 and PIO0\_11 are not available on the package, prevent the pins from internally floating as follows: Set bits 10 and 11 in the GPIO DIR0 register to 1 to enable the output driver and write 1 to bits 10 and 11 in the GPIO CLR0 register to drive the outputs LOW internally.

# 8.4 General description

# 8.4.1 Pin configuration



### 8.4.2 Pin function

The pin function is determined entirely through the switch matrix. By default one of the GPIO functions is assigned to each pin. The switch matrix can assign all functions from the movable function table to any pin in the IOCON block or enable a special function like an analog input on a specific pin.

**Related links:** 

Table 63 "Movable functions (assign to pins PIO0\_0 to PIO0\_28 through switch matrix)"

### 8.4.3 Pin mode

The MODE bit in the IOCON register allows enabling or disabling an on-chip pull-up resistor for each pin. By default all pull-up resistors are enabled except for the I<sup>2</sup>C-bus pins PIO0\_10 and PIO0\_11, which do not have a programmable pull-up resistor.

The repeater mode enables the pull-up resistor if the pin is high and enables the pull-down resistor if the pin is low. This causes the pin to retain its last known state if it is configured as an input and is not driven externally. Repeater mode may typically be used to prevent a pin from floating (and potentially using significant power if it floats to an indeterminate state) if it is temporarily not driven.

### 8.4.4 Open-drain mode

An open-drain mode can be enabled for all digital I/O pins that are not the I2C-bus pins. This mode is not a true open-drain mode. The input cannot be pulled up above  $V_{DD}$ .

**Remark:** As opposed to the true open-drain I2C-bus pins, digital pins with configurable open-drain mode are **not** 5 V tolerant when  $V_{DD} = 0$ .

### 8.4.5 Analog mode

The switch matrix automatically configures the pin in analog mode whenever an analog input or output is selected as the pin's function.

### 8.4.6 I<sup>2</sup>C-bus mode

The I<sup>2</sup>C-bus pins PIO0\_10 and PIO0\_11 can be programmed to support a true open-drain mode independently of whether the I2C function is selected or another digital function. If the I<sup>2</sup>C function is selected, all three I<sup>2</sup>C modes, Standard mode, Fast-mode, and Fast-mode plus, are supported. A digital glitch filter can be configured for all functions. Pins PIO0\_10 and PIO0\_11 operate as high-current sink drivers (20 mA) independently of the programmed function.

**Remark:** Pins PIO0\_10 and PIO0\_11 are 5 V tolerant when  $V_{DD} = 0$  and when  $V_{DD}$  is at operating voltage level.

### 8.4.7 Programmable digital filter

All GPIO pins are equipped with a programmable, digital glitch filter. The filter rejects input pulses with a selectable duration of shorter than one, two, or three cycles of a filter clock (S\_MODE = 1, 2, or 3). For each individual pin, the filter clock can be selected from one of seven peripheral clocks PCLK0 to 6, which are derived from the main clock using the IOCONCLKDIV0 to 6 registers. The filter can also be bypassed entirely.

Any input pulses of duration  $T_{pulse}$  of either polarity will be rejected if:  $T_{pulse} < T_{PCLKn} \times S\_MODE$ 

Input pulses of one filter clock cycle longer may also be rejected:

 $T_{pulse} = T_{PCLKn} (S_MODE + 1)$ 

**Remark:** The filtering effect is accomplished by requiring that the input signal be stable for (S\_MODE +1) successive edges of the filter clock before being passed on to the chip. Enabling the filter results in delaying the signal to the internal logic and should be done only if specifically required by an application. For high-speed or time critical functions ensure that the filter is bypassed.

If the delay of the input signal must be minimized, select a faster PCLK and a higher sample mode (S\_MODE) to minimize the effect of the potential extra clock cycle.

UM11021

If the sensitivity to noise spikes must be minimized, select a slower PCLK and lower sample mode.

Related registers and links:

Table 42 "IOCON glitch filter clock divider registers 6 to 0 (IOCONCLKDIV[6:0], address 0x4004 8134 (IOCONCLKDIV6) to 0x004 814C (IOCONFILTCLKDIV0)) bit description"

# 8.5 Register description

Each port pin PIO0\_m has one IOCON register assigned to control the pin's function and electrical characteristics.

**Remark:** See <u>Table 79</u> for the IOCON register map ordered by pin name.

 Table 78.
 Register overview: I/O configuration (base address 0x4004 4000)

| Name    | Access | ccess Address Description<br>offset |                                                                                               | Reset value | Reference |  |
|---------|--------|-------------------------------------|-----------------------------------------------------------------------------------------------|-------------|-----------|--|
| PIO0_17 | R/W    | 0x000                               | I/O configuration for pin<br>PIO0_17/ADC_9                                                    | 0x0000 0090 | Table 80  |  |
| PIO0_13 | R/W    | 0x004                               | I/O configuration for pin<br>PIO0_13/ADC_10                                                   | 0x0000 0090 | Table 81  |  |
| PIO0_12 | R/W    | 0x008                               | I/O configuration for pin PIO0_12                                                             | 0x0000 0090 | Table 82  |  |
| PIO0_5  | R/W    | 0x00C                               | I/O configuration for pin PIO0_5/RESET                                                        | 0x0000 0090 | Table 83  |  |
| PIO0_4  | R/W    | 0x010                               | I/O configuration for pin<br>PIO0_4/ADC_11/TRSTN/WAKEUP                                       | 0x0000 0090 | Table 84  |  |
| PIO0_3  | R/W    | 0x014                               | I/O configuration for pin<br>PIO0_3/SWCLK                                                     | 0x0000 0090 | Table 85  |  |
| PIO0_2  | R/W    | 0x018                               | I/O configuration for pin PIO0_2/SWDIO                                                        | 0x0000 0090 | Table 86  |  |
| PIO0_11 | R/W    | 0x01C                               | I/O configuration for pin PIO0_11. This is the pin configuration for the true open-drain pin. | 0x0000 0080 | Table 87  |  |
| PIO0_10 | R/W    | 0x020                               | I/O configuration for pin PIO0_10. This is the pin configuration for the true open-drain pin. | 0x0000 0080 | Table 88  |  |
| PIO0_16 | R/W    | 0x024                               | I/O configuration for pin PIO0_16                                                             | 0x0000 0090 | Table 89  |  |
| PIO0_15 | R/W    | 0x028                               | I/O configuration for pin PIO0_15                                                             | 0x0000 0090 | Table 90  |  |
| PIO0_1  | R/W    | 0x02C                               | I/O configuration for pin PIO0_1/CLKIN                                                        | 0x0000 0090 | Table 91  |  |
| -       | -      | 0x030                               | Reserved                                                                                      | -           | -         |  |
| PIO0_9  | R/W    | 0x034                               | I/O configuration for pin<br>PIO0_9/XTALOUT                                                   | 0x0000 0090 | Table 92  |  |
| PIO0_8  | R/W    | 0x038                               | I/O configuration for pin PIO0_8/XTALIN                                                       | 0x0000 0090 | Table 93  |  |
| PIO0_7  | R/W    | 0x03C                               | I/O configuration for pin PIO0_7/ADC_0                                                        | 0x0000 0090 | Table 94  |  |
| PIO0_6  | R/W    | 0x040                               | I/O configuration for pin PIO0_6/ADC_1                                                        | 0x0000 0090 | Table 95  |  |
| PIO0_0  | R/W    | 0x044                               | I/O configuration for pin PIO0_0                                                              | 0x0000 0090 | Table 96  |  |
| PIO0_14 | R/W    | 0x048                               | I/O configuration for pin<br>PIO0_14/ADC_2                                                    | 0x0000 0090 | Table 97  |  |

UM11021

| Name    | Access | Address<br>offset | Description                                | Reset value | Reference |  |
|---------|--------|-------------------|--------------------------------------------|-------------|-----------|--|
| -       | -      | 0x04C             | Reserved.                                  | -           | -         |  |
| PIO0_28 | R/W    | 0x050             | I/O configuration for pin PIO0_28          | 0x0000 0090 | Table 98  |  |
| PIO0_27 | R/W    | 0x054             | I/O configuration for pin PIO0_27          | 0x0000 0090 | Table 99  |  |
| PIO0_26 | R/W    | 0x058             | I/O configuration for pin PIO0_26          | 0x0000 0090 | Table 100 |  |
| PIO0_25 | R/W    | 0x05C             | I/O configuration for pin PIO0_25          | 0x0000 0090 | Table 101 |  |
| PIO0_24 | R/W    | 0x060             | I/O configuration for pin PIO0_24          | 0x0000 0090 | Table 102 |  |
| PIO0_23 | R/W    | 0x064             | I/O configuration for pin<br>PIO0_23/ADC_3 | 0x0000 0090 | Table 103 |  |
| PIO0_22 | R/W    | 0x068             | I/O configuration for pin<br>PIO0_22/ADC_4 | 0x0000 0090 | Table 104 |  |
| PIO0_21 | R/W    | 0x06C             | I/O configuration for pin<br>PIO0_21/ADC_5 | 0x0000 0090 | Table 105 |  |
| PIO0_20 | R/W    | 0x070             | I/O configuration for pin<br>PIO0_20/ADC_6 | 0x0000 0090 | Table 106 |  |
| PIO0_19 | R/W    | 0x074             | I/O configuration for pin<br>PIO0_19/ADC_7 | 0x0000 0090 | Table 107 |  |
| PIO0_18 | R/W    | 0x078             | I/O configuration for pin<br>PIO0_18/ADC_8 | 0x0000 0090 | Table 108 |  |

#### Table 78. Register overview: I/O configuration (base address 0x4004 4000)

### Table 79. I/O configuration registers ordered by pin name

| Name    | Address<br>offset | True open-drain | Analog <sup>[1]</sup> | Digital filter | High-drive<br>output | Reference |
|---------|-------------------|-----------------|-----------------------|----------------|----------------------|-----------|
| PIO0_0  | 0x044             | no              | no                    | yes            | no                   | Table 96  |
| PIO0_1  | 0x02C             | no              | no                    | yes            | no                   | Table 91  |
| PIO0_2  | 0x018             | no              | no                    | yes            | yes                  | Table 86  |
| PIO0_3  | 0x014             | no              | no                    | yes            | yes                  | Table 85  |
| PIO0_4  | 0x010             | no              | yes                   | yes            | no                   | Table 84  |
| PIO0_5  | 0x00C             | no              | no                    | yes            | no                   | Table 83  |
| PIO0_6  | 0x040             | no              | yes                   | yes            | no                   | Table 95  |
| PIO0_7  | 0x03C             | no              | yes                   | yes            | no                   | Table 94  |
| PIO0_8  | 0x038             | no              | yes                   | yes            | no                   | Table 93  |
| PIO0_9  | 0x034             | no              | yes                   | yes            | no                   | Table 92  |
| PIO0_10 | 0x020             | yes             | no                    | yes            | no                   | Table 88  |
| PIO0_11 | 0x01C             | yes             | no                    | yes            | no                   | Table 87  |
| PIO0_12 | 0x008             | no              | no                    | yes            | yes                  | Table 82  |
| PIO0_13 | 0x004             | no              | yes                   | yes            | no                   | Table 81  |
| PIO0_14 | 0x048             | no              | yes                   | yes            | no                   | Table 97  |
| PIO0_15 | 0x028             | no              | no                    | yes            | no                   | Table 90  |
| PIO0_16 | 0x024             | no              | no                    | yes            | yes                  | Table 89  |
| PIO0_17 | 0x000             | no              | yes                   | yes            | no                   | Table 80  |
| PIO0_18 | 0x078             | no              | yes                   | yes            | no                   | Table 108 |
| PIO0_19 | 0x074             | no              | yes                   | yes            | no                   | Table 107 |

UM11021

© NXP Semiconductors N.V. 2016. All rights reserved.

| Name    | Address<br>offset | True open-drain | Analog <sup>[1]</sup> | Digital filter | High-drive<br>output | Reference |
|---------|-------------------|-----------------|-----------------------|----------------|----------------------|-----------|
| PIO0_20 | 0x070             | no              | yes                   | yes            | no                   | Table 106 |
| PIO0_21 | 0x06C             | no              | yes                   | yes            | no                   | Table 105 |
| PIO0_22 | 0x068             | no              | yes                   | yes            | no                   | Table 104 |
| PIO0_23 | 0x064             | no              | yes                   | yes            | no                   | Table 103 |
| PIO0_24 | 0x060             | no              | no                    | yes            | no                   | Table 102 |
| PIO0_25 | 0x05C             | no              | no                    | yes            | no                   | Table 101 |
| PIO0_26 | 0x058             | no              | no                    | yes            | no                   | Table 100 |
| PIO0_27 | 0x054             | no              | no                    | yes            | no                   | Table 99  |
| PIO0_28 | 0x050             | no              | no                    | yes            | no                   | Table 98  |

#### Table 79. I/O configuration registers ordered by pin name

[1] The analog pad is enabled when the analog function is selected in the switch matrix through the PINENABLE register.

### 8.5.1 PIO0\_17 register

#### Table 80. PIO0\_17 register (PIO0\_17, address 0x4004 4000) bit description

| Bit | Symbol | Value | Description                                                         | Reset<br>value |
|-----|--------|-------|---------------------------------------------------------------------|----------------|
| 2:0 | -      |       | Reserved.                                                           | 0              |
| 4:3 | MODE   |       | Selects function mode (on-chip pull-up/pull-down resistor control). | 0b10           |
|     |        | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                   |                |
|     |        | 0x1   | Pull-down resistor enabled.                                         |                |
|     |        | 0x2   | Pull-up resistor enabled.                                           |                |
|     |        | 0x3   | Repeater mode.                                                      |                |
| 5   | HYS    |       | Hysteresis.                                                         | 0              |
|     |        | 0     | Disable.                                                            |                |
|     |        | 1     | Enable.                                                             |                |
| 6   | INV    |       | Invert input                                                        | 0              |
|     |        | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0). |                |
|     |        | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).     |                |
| 9:7 | -      | -     | Reserved.                                                           | 0b001          |
| 10  | OD     |       | Open-drain mode.                                                    | 0              |
|     |        | 0     | Disable.                                                            |                |
|     |        | 1     | Open-drain mode enabled.                                            | 1              |
|     |        |       | Remark: This is not a true open-drain mode.                         |                |

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

#### Table 80. PIO0\_17 register (PIO0\_17, address 0x4004 4000) bit description

### 8.5.2 PIO0\_13 register

#### Table 81. PIO0\_13 register (PIO0\_13, address 0x4004 4004) bit description

| Bit | Symbol | Value | Description                                                         | Reset<br>value |
|-----|--------|-------|---------------------------------------------------------------------|----------------|
| 2:0 | -      |       | Reserved.                                                           | 0              |
| 4:3 | MODE   |       | Selects function mode (on-chip pull-up/pull-down resistor control). | 0b10           |
|     |        | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                   |                |
|     |        | 0x1   | Pull-down resistor enabled.                                         |                |
|     |        | 0x2   | Pull-up resistor enabled.                                           |                |
|     |        | 0x3   | Repeater mode.                                                      |                |
| 5   | HYS    |       | Hysteresis.                                                         | 0              |
|     |        | 0     | Disable.                                                            |                |
|     |        | 1     | Enable.                                                             |                |
| 6   | INV    |       | Invert input                                                        | 0              |
|     |        | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0). |                |
|     |        | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).     |                |
| 9:7 | -      | -     | Reserved.                                                           | 0b001          |

UM11021

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | _              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

### Table 81. PIO0\_13 register (PIO0\_13, address 0x4004 4004) bit description ...continued

### 8.5.3 PIO0\_12 register

### Table 82. PIO0\_12 register (PIO0\_12, address 0x4004 4008) bit description

| Bit | Symbol | Value | Description                                                         | Reset<br>value |
|-----|--------|-------|---------------------------------------------------------------------|----------------|
| 2:0 | -      |       | Reserved.                                                           | 0              |
| 4:3 | MODE   |       | Selects function mode (on-chip pull-up/pull-down resistor control). | 0b10           |
|     |        | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                   |                |
|     |        | 0x1   | Pull-down resistor enabled.                                         |                |
|     |        | 0x2   | Pull-up resistor enabled.                                           |                |
|     |        | 0x3   | Repeater mode.                                                      | _              |
| 5   | HYS    |       | Hysteresis.                                                         | 0              |
|     |        | 0     | Disable.                                                            | _              |
|     |        | 1     | Enable.                                                             | _              |
| 6   | INV    |       | Invert input                                                        | 0              |
|     |        | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0). | -              |
|     |        | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).     |                |

| Table 82. | PIO0_12 register | r (PIO0_12, address 0x4004 | 4008) bit description continued |
|-----------|------------------|----------------------------|---------------------------------|
|-----------|------------------|----------------------------|---------------------------------|

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | ]              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.4 PIO0\_5 register

### Table 83. PIO0\_5 register (PIO0\_5, address 0x4004 400C) bit description

| Bit | Symbol | Value | Description                                                         | Reset<br>value |
|-----|--------|-------|---------------------------------------------------------------------|----------------|
| 2:0 | -      |       | Reserved.                                                           | 0              |
| 4:3 | MODE   |       | Selects function mode (on-chip pull-up/pull-down resistor control). | 0b10           |
|     |        | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                   |                |
|     |        | 0x1   | Pull-down resistor enabled.                                         |                |
|     |        | 0x2   | Pull-up resistor enabled.                                           |                |
|     |        | 0x3   | Repeater mode.                                                      |                |
| 5   | HYS    |       | Hysteresis.                                                         | 0              |
|     |        | 0     | Disable.                                                            |                |
|     |        | 1     | Enable.                                                             |                |

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value    |
|-------|---------|-------|--------------------------------------------------------------------------------------------|-------------------|
| 6     | INV     |       | Invert input                                                                               | 0                 |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                   |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                   |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b00 <sup>2</sup> |
| 10    | OD      |       | Open-drain mode.                                                                           | 0                 |
|       |         | 0     | Disable.                                                                                   |                   |
|       |         | 1     | Open-drain mode enabled.                                                                   |                   |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                   |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0                 |
|       |         | 0x0   | Bypass input filter.                                                                       |                   |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                   |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                   |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                   |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0                 |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                   |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                   |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                   |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1                 |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1                 |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1                 |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1                 |
| 31:16 | -       | -     | Reserved.                                                                                  | 0                 |

Table 83. PIO0\_5 register (PIO0\_5, address 0x4004 400C) bit description ... continued

### 8.5.5 PIO0\_4 register

#### Table 84. PIO0\_4 register (PIO0\_4, address 0x4004 4010) bit description

| Bit | Symbol | Value | Description                                                         | Reset<br>value |
|-----|--------|-------|---------------------------------------------------------------------|----------------|
| 2:0 | -      |       | Reserved.                                                           | 0              |
| 4:3 | MODE   |       | Selects function mode (on-chip pull-up/pull-down resistor control). | 0b10           |
|     |        | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                   |                |
|     |        | 0x1   | Pull-down resistor enabled.                                         |                |
|     |        | 0x2   | Pull-up resistor enabled.                                           |                |
|     |        | 0x3   | Repeater mode.                                                      |                |

| Table 84. | . PIO0_4 register (PIO0_4, address 0x4004 4010) bit description | continued |
|-----------|-----------------------------------------------------------------|-----------|
|-----------|-----------------------------------------------------------------|-----------|

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.6 PIO0\_3 register

#### Table 85. PIO0\_3 register (PIO0\_3, address 0x4004 4014) bit description

| Bit | Symbol | Value |           | Reset<br>value |
|-----|--------|-------|-----------|----------------|
| 2:0 | -      |       | Reserved. | 0              |

| Table 85. | . PIO0_3 register (PIO0_3, address 0x4004 4014) bit description cont | tinued |
|-----------|----------------------------------------------------------------------|--------|
|-----------|----------------------------------------------------------------------|--------|

| Bit   | Symbol  | Value   | Description                                                                                | Reset<br>value |
|-------|---------|---------|--------------------------------------------------------------------------------------------|----------------|
| 4:3   | MODE    |         | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0     | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1     | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2     | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3     | Repeater mode.                                                                             |                |
| 5     | HYS     |         | Hysteresis.                                                                                | 0              |
|       |         | 0       | Disable.                                                                                   |                |
|       | 1       | Enable. |                                                                                            |                |
| 6     | INV     |         | Invert input.                                                                              | 0              |
|       |         | 0       | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1       | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7 - | -       | -       | Reserved.                                                                                  | 0b001          |
| 10    | OD      |         | Open-drain mode.                                                                           | 0              |
|       |         | 0       | Disable.                                                                                   |                |
|       |         | 1       | Open-drain mode enabled.                                                                   |                |
|       |         |         | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |         | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0     | Bypass input filter.                                                                       |                |
|       |         | 0x1     | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2     | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3     | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |         | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0     | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1     | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2     | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3     | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4     | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5     | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6     | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -       | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.7 PIO0\_2 register

#### Table 86. PIO0\_2 register (PIO0\_2, address 0x4004 4018) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input.                                                                              | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        | _              |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | 1              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | 1              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    | _              |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | 1              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | 1              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.8 PIO0\_11 register

#### Table 87. PIO0\_11 register (PIO0\_11, address 0x4004 401C) bit description

| Bit   | Symbol  | Value | Description                                                                                                                  | Reset<br>value |
|-------|---------|-------|------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0   | -       |       | Reserved.                                                                                                                    | 0              |
| 6 INV | INV     |       | Invert input                                                                                                                 | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                                                          |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                                                              |                |
| 7     | -       |       | Reserved.                                                                                                                    | 1              |
| 9:8   | I2CMODE |       | Selects I2C mode.                                                                                                            | 00             |
|       |         |       | Select Standard mode (I2CMODE = 00, default) or<br>Standard I/O functionality (I2CMODE = 01) if the pin<br>function is GPIO. |                |
|       |         | 0x0   | Standard mode/ Fast-mode I2C.                                                                                                |                |
|       |         | 0x1   | Standard GPIO functionality. Requires external pull-up for GPIO output function.                                             |                |
|       |         | 0x2   | Fast-mode Plus I2C                                                                                                           |                |
|       |         | 0x3   | Reserved.                                                                                                                    | -              |
| 10    | -       | -     | Reserved.                                                                                                                    | -              |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                                                  | 0              |
|       |         | 0x0   | Bypass input filter.                                                                                                         |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                                                      |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                                                    |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                                                  |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock. Value 0x7 is reserved.                                      | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                                                                |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                                                                |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                                                                |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                                                                | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                                                                |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                                                                |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                                                                |                |
| 31:16 | -       | -     | Reserved.                                                                                                                    | -              |

## 8.5.9 PIO0\_10 register

#### Table 88. PIO0\_10 register (PIO0\_10, address 0x4004 4020) bit description

| Bit   | Symbol  | Value | Description                                                                                                            | Reset<br>value |
|-------|---------|-------|------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0   | -       |       | Reserved.                                                                                                              | 0              |
| 6     | INV     |       | Invert input                                                                                                           | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                                                    |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                                                        |                |
| 7     | -       |       | Reserved.                                                                                                              | 1              |
| 9:8   | I2CMODE |       | Selects I2C mode.                                                                                                      | 00             |
|       |         |       | Select Standard mode (I2CMODE = 00, default) or Standard I/O functionality (I2CMODE = 01) if the pin function is GPIO. |                |
|       |         | 0x0   | Standard mode/ Fast-mode I2C.                                                                                          |                |
|       |         | 0x1   | Standard GPIO functionality. Requires external pull-up for GPIO output function.                                       |                |
|       |         | 0x2   | Fast-mode Plus I2C                                                                                                     |                |
|       |         | 0x3   | Reserved.                                                                                                              |                |
| 10    | -       | -     | Reserved.                                                                                                              | -              |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                                            | 0              |
|       |         | 0x0   | Bypass input filter.                                                                                                   |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                                                |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                                              |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                                            |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved.                             | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                                                          |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                                                          |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                                                          |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                                                          |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                                                          | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                                                          | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                                                          | 1              |
| 31:16 | -       | -     | Reserved.                                                                                                              | -              |

## 8.5.10 PIO0\_16 register

#### Table 89. PIO0\_16 register (PIO0\_16, address 0x4004 4024) bit description

| Bit   | Symbol  | Value   | Description                                                                                | Reset<br>value |
|-------|---------|---------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |         | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |         | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0     | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1     | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2     | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3     | Repeater mode.                                                                             |                |
| 5     | HYS     |         | Hysteresis.                                                                                | 0              |
|       |         | 0       | Disable.                                                                                   |                |
|       | 1       | Enable. |                                                                                            |                |
| 6 INV | INV     |         | Invert input                                                                               | 0              |
|       | INV     | 0       | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1       | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -       | Reserved.                                                                                  | 0b001          |
| 10    | OD      |         | Open-drain mode.                                                                           | 0              |
|       |         | 0       | Disable.                                                                                   | -              |
|       |         | 1       | Open-drain mode enabled.                                                                   | -              |
|       |         |         | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |         | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0     | Bypass input filter.                                                                       |                |
|       |         | 0x1     | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2     | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3     | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |         | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0     | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1     | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2     | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3     | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4     | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5     | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6     | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -       | Reserved.                                                                                  | 0              |

# 8.5.11 PIO0\_15 register

#### Table 90. PIO0\_15 register (PIO0\_15, address 0x4004 4028) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Enable.                                                                                    | -              |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            | _              |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.12 PIO0\_1 register

#### Table 91. PIO0\_1 register (PIO0\_1, address 0x4004 402C) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       | 6 INV   | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | 1              |
|       |         | 1     | Open-drain mode enabled.                                                                   | 1              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | 1              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | ]              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | ]              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.13 PIO0\_9 register

#### Table 92. PIO0\_9 register (PIO0\_9, address 0x4004 4034) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 10             |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 001            |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.14 PIO0\_8 register

#### Table 93. PIO0\_8 register (PIO0\_8, address 0x4004 4038) bit description

| Bit    | Symbol  | Value   | Description                                                                                | Reset<br>value |
|--------|---------|---------|--------------------------------------------------------------------------------------------|----------------|
| 2:0    | -       |         | Reserved.                                                                                  | 0              |
| 4:3    | MODE    |         | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|        |         | 0x0     | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|        |         | 0x1     | Pull-down resistor enabled.                                                                |                |
|        |         | 0x2     | Pull-up resistor enabled.                                                                  |                |
|        |         | 0x3     | Repeater mode.                                                                             |                |
| 5      | HYS     |         | Hysteresis.                                                                                | 0              |
| o (N)/ |         | 0       | Disable.                                                                                   |                |
|        | 1       | Enable. |                                                                                            |                |
| 6      | INV     |         | Invert input                                                                               | 0              |
|        |         | 0       | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        | _              |
|        |         | 1       | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            | -              |
| 9:7    | -       | -       | Reserved.                                                                                  | 0b001          |
| 10     | OD      |         | Open-drain mode.                                                                           | 0              |
|        |         | 0       | Disable.                                                                                   | _              |
|        |         | 1       | Open-drain mode enabled.                                                                   | _              |
|        |         |         | Remark: This is not a true open-drain mode.                                                |                |
| 12:11  | S_MODE  |         | Digital filter sample mode.                                                                | 0              |
|        |         | 0x0     | Bypass input filter.                                                                       |                |
|        |         | 0x1     | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|        |         | 0x2     | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|        |         | 0x3     | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13  | CLK_DIV |         | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|        |         | 0x0     | IOCONCLKDIV0.                                                                              | -              |
|        |         | 0x1     | IOCONCLKDIV1.                                                                              | _              |
|        |         | 0x2     | IOCONCLKDIV2.                                                                              | 1              |
|        |         | 0x3     | IOCONCLKDIV3.                                                                              | 1              |
|        |         | 0x4     | IOCONCLKDIV4.                                                                              | 1              |
|        |         | 0x5     | IOCONCLKDIV5.                                                                              | 1              |
|        |         | 0x6     | IOCONCLKDIV6.                                                                              | 1              |
| 31:16  | -       | -       | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.15 PIO0\_7 register

#### Table 94. PIO0\_7 register (PIO0\_7, address 0x4004 403C) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
| -     |         | 0     | Disable.                                                                                   | 1              |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    | _              |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.16 PIO0\_6 register

#### Table 95. PIO0\_6 register (PIO0\_6, address 0x4004 4040) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 10             |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          | _              |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
| 6     |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            | -              |
| 9:7   | -       | -     | Reserved.                                                                                  | 001            |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | _              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

**UM11021** 

### 8.5.17 PIO0\_0 register

#### Table 96. PIO0\_0 register (PIO0\_0, address 0x4004 4044) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

## 8.5.18 PIO0\_14 register

#### Table 97. PIO0\_14 register (PIO0\_14, address 0x4004 4048) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        | -              |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              |                |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              |                |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              |                |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              |                |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

## 8.5.19 PIO0\_28 register

#### Table 98. PIO0\_28 register (PIO0\_28, address 0x4004 4050) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | 1              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    | _              |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                | _              |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | 1              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | 1              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.20 PIO0\_27 register

#### Table 99. PIO0\_27 register (PIO0\_27, address 0x4004 4054) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | _              |
|       |         | 1     | Open-drain mode enabled.                                                                   | _              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | _              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | 1              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.21 PIO0\_26 register

#### Table 100. PIO0\_26 register (PIO0\_26, address 0x4004 4058) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | _              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | -              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

## 8.5.22 PIO0\_25 register

#### Table 101. PIO0\_25 register (PIO0\_25, address 0x4004 405C) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    | -              |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | -              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | -              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

## 8.5.23 PIO0\_24 register

#### Table 102. PIO0\_24 register (PIO0\_24, address 0x4004 4060) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   | _              |
|       |         | 1     | Enable.                                                                                    | _              |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | _              |
|       |         | 1     | Open-drain mode enabled.                                                                   | _              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       | _              |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | -              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

## 8.5.24 PIO0\_23 register

#### Table 103. PIO0\_23 register (PIO0\_23, address 0x4004 4064) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            | -              |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              |                |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.25 PIO0\_22 register

#### Table 104. PIO0\_22 register (PIO0\_22, address 0x4004 4068) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  | -              |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | 1              |
|       |         | 1     | Open-drain mode enabled.                                                                   | 1              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                | =              |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | 1              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | 1              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | 1              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.26 PIO0\_21 register

#### Table 105. PIO0\_21 register (PIO0\_21, address 0x4004 406C) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  | -              |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Enable.                                                                                    | -              |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        | _              |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Open-drain mode enabled.                                                                   |                |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    | _              |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  | _              |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                | _              |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | 1              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.27 PIO0\_20 register

#### Table 106. PIO0\_20 register (PIO0\_20, address 0x4004 4070) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  | -              |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | 1              |
|       |         | 1     | Open-drain mode enabled.                                                                   | 1              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              | -              |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | -              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.28 PIO0\_19 register

#### Table 107. PIO0\_19 register (PIO0\_19, address 0x4004 4074) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            | -              |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              | -              |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | -              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

# 8.5.29 PIO0\_18 register

#### Table 108. PIO0\_18 register (PIO0\_18, address 0x4004 4078) bit description

| Bit   | Symbol  | Value | Description                                                                                | Reset<br>value |
|-------|---------|-------|--------------------------------------------------------------------------------------------|----------------|
| 2:0   | -       |       | Reserved.                                                                                  | 0              |
| 4:3   | MODE    |       | Selects function mode (on-chip pull-up/pull-down resistor control).                        | 0b10           |
|       |         | 0x0   | Inactive (no pull-down/pull-up resistor enabled).                                          |                |
|       |         | 0x1   | Pull-down resistor enabled.                                                                |                |
|       |         | 0x2   | Pull-up resistor enabled.                                                                  |                |
|       |         | 0x3   | Repeater mode.                                                                             |                |
| 5     | HYS     |       | Hysteresis.                                                                                | 0              |
|       |         | 0     | Disable.                                                                                   |                |
|       |         | 1     | Enable.                                                                                    |                |
| 6     | INV     |       | Invert input                                                                               | 0              |
|       |         | 0     | Input not inverted (HIGH on pin reads as 1; LOW on pin reads as 0).                        |                |
|       |         | 1     | Input inverted (HIGH on pin reads as 0, LOW on pin reads as 1).                            |                |
| 9:7   | -       | -     | Reserved.                                                                                  | 0b001          |
| 10    | OD      |       | Open-drain mode.                                                                           | 0              |
|       |         | 0     | Disable.                                                                                   | -              |
|       |         | 1     | Open-drain mode enabled.                                                                   | -              |
|       |         |       | Remark: This is not a true open-drain mode.                                                |                |
| 12:11 | S_MODE  |       | Digital filter sample mode.                                                                | 0              |
|       |         | 0x0   | Bypass input filter.                                                                       |                |
|       |         | 0x1   | 1 clock cycle. Input pulses shorter than one filter clock are rejected.                    |                |
|       |         | 0x2   | 2 clock cycles. Input pulses shorter than two filter clocks are rejected.                  |                |
|       |         | 0x3   | 3 clock cycles. Input pulses shorter than three filter clocks are rejected.                |                |
| 15:13 | CLK_DIV |       | Select peripheral clock divider for input filter sampling clock.<br>Value 0x7 is reserved. | 0              |
|       |         | 0x0   | IOCONCLKDIV0.                                                                              |                |
|       |         | 0x1   | IOCONCLKDIV1.                                                                              |                |
|       |         | 0x2   | IOCONCLKDIV2.                                                                              | _              |
|       |         | 0x3   | IOCONCLKDIV3.                                                                              | 1              |
|       |         | 0x4   | IOCONCLKDIV4.                                                                              | 1              |
|       |         | 0x5   | IOCONCLKDIV5.                                                                              | 1              |
|       |         | 0x6   | IOCONCLKDIV6.                                                                              | 1              |
| 31:16 | -       | -     | Reserved.                                                                                  | 0              |

Chapter 9: LPC83x General Purpose I/O (GPIO)

Rev. 1.1 — 5 October 2016

**User manual** 

# 9.1 How to read this chapter

All GPIO registers refer to 32 pins on each port. Depending on the package type, not all pins are available, and the corresponding bits in the GPIO registers are reserved.

#### Table 109. GPIO pins available

| Package | GPIO Port 0                                           |
|---------|-------------------------------------------------------|
| TSSOP20 | PIO0_0 to PIO0_5; PIO0_8 to PIO0_15; PIO0_17; PIO0_23 |
| HVQFN33 | PIO0_0 to PIO0_28                                     |

# 9.2 Basic configuration

For the GPIO port registers, enable the clock to the GPIO port in the SYSAHBCLKCTRL register (Table 33).

# 9.3 Features

- GPIO pins can be configured as input or output by software.
- All GPIO pins default to inputs with interrupt disabled at reset.
- Pin registers allow pins to be sensed and set individually.
- Direction (input/output) can be set and cleared individually.

# 9.4 General description

The GPIO pins can be used in several ways to set pins as inputs or outputs and use the inputs as combinations of level and edge sensitive interrupts.

The GPIOs can be used as external interrupts together with the pin interrupt block.

The GPIO port registers configure each GPIO pin as input or output and read the state of each pin if the pin is configured as input or set the state of each pin if the pin is configured as output.

# 9.5 Register description

Note: In all GPIO registers, bits that are not shown are reserved.

GPIO port addresses can be read and written as bytes, halfwords, or words.

**Remark:** ext in this table and subsequent tables indicates that the data read after reset depends on the state of the pin, which in turn may depend on an external source.

#### Chapter 9: LPC83x General Purpose I/O (GPIO)

| Name      | Access | Address<br>offset | Description                                                    | Reset<br>value | Width         | Reference |
|-----------|--------|-------------------|----------------------------------------------------------------|----------------|---------------|-----------|
| B0 to B28 | R/W    | 0x0000 to 0x001C  | Byte pin registers port 0; pins<br>PIO0_0 to PIO0_28           | ext            | byte (8 bit)  | Table 111 |
| W0 to W28 | R/W    | 0x1000 to 0x1074  | Word pin registers port 0                                      | ext            | word (32 bit) | Table 112 |
| DIR0      | R/W    | 0x2000            | Direction registers port 0                                     | 0              | word (32 bit) | Table 113 |
| MASK0     | R/W    | 0x2080            | Mask register port 0                                           | 0              | word (32 bit) | Table 114 |
| PIN0      | R/W    | 0x2100            | Port pin register port 0                                       | ext            | word (32 bit) | Table 115 |
| MPIN0     | R/W    | 0x2180            | Masked port register port 0                                    | ext            | word (32 bit) | Table 116 |
| SET0      | R/W    | 0x2200            | Write: Set register for port 0<br>Read: output bits for port 0 | 0              | word (32 bit) | Table 117 |
| CLR0      | WO     | 0x2280            | Clear port 0                                                   | -              | word (32 bit) | Table 118 |
| NOT0      | WO     | 0x2300            | Toggle port 0                                                  | -              | word (32 bit) | Table 119 |
| DIRSET0   | WO     | 0x2380            | Set pin direction bits for port 0.                             | 0              | word (32 bit) | Table 120 |
| DIRCLR0   | WO     | 0x2400            | Clear pin direction bits for port 0.                           | -              | word (32 bit) | Table 121 |
| DIRNOT0   | WO     | 0x2480            | Toggle pin direction bits for port 0.                          | -              | word (32 bit) | Table 122 |

#### Table 110. Register overview: GPIO port (base address 0xA000 0000)

### 9.5.1 GPIO port byte pin registers

Each GPIO pin has a byte register in this address range. Software typically reads and writes bytes to access individual pins, but can read or write halfwords to sense or set the state of two pins, and read or write words to sense or set the state of four pins.

# Table 111. GPIO port byte pin registers (B[0:28], addresses 0xA000 0000 (B0) to 0xA000001C (B28)) bit description

| Bit | Symbol | Description                                                                                                                                                                                                                                         | Reset<br>value | Access |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 0   | PBYTE  | Read: state of the pin PIO0_n, regardless of direction,<br>masking, or alternate function, except that pins configured as<br>analog I/O always read as 0. One register for each port pin: n<br>= pin 0 to 28.<br>Write: loads the pin's output bit. | ext            | R/W    |
| 7:1 |        | Reserved (0 on read, ignored on write)                                                                                                                                                                                                              | 0              | -      |

### 9.5.2 GPIO port word pin registers

Each GPIO pin has a word register in this address range. Any byte, halfword, or word read in this range will be all zeros if the pin is low or all ones if the pin is high, regardless of direction, masking, or alternate function, except that pins configured as analog I/O always read as zeros. Any write will clear the pin's output bit if the value written is all zeros, else it will set the pin's output bit.

| Table 112. | GPIO port word pin registers (W[0:28], addresses 0xA000 1000 (W0) to 0xA000 |
|------------|-----------------------------------------------------------------------------|
|            | 1074 (W28)) bit description                                                 |

| Bit  | Symbol | Description                                                                                                                                                         | Reset<br>value | Access |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 31:0 | PWORD  | Read 0: pin PIOm_n is LOW.<br>Write 0: clear output bit.<br>Read 0xFFFF FFFF: pin PIOm_n is HIGH.<br>Write any value 0x0000 0001 to 0xFFFF FFFF: set output<br>bit. | ext            | R/W    |
|      |        | <b>Remark:</b> Only 0 or 0xFFFF FFFF can be read. Writing any value other than 0 will set the output bit.<br>One register for each port pin: $n = pin 0$ to 28.     |                |        |

#### 9.5.3 GPIO port direction registers

Each GPIO port has one direction register for configuring the port pins as inputs or outputs.

| Table 113. | <b>GPIO direction</b> | n port register | (DIR0, address 0xA00 | 0 2000) bit description |
|------------|-----------------------|-----------------|----------------------|-------------------------|
|------------|-----------------------|-----------------|----------------------|-------------------------|

| Bit   | Symbol | Description                                                                                                            | Reset<br>value | Access |
|-------|--------|------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | DIRP   | Selects pin direction for pin PIO0_n (bit 0 = PIO0_0, bit 1 = PIO0_1,, bit 28 = PIO0_28).<br>0 = input.<br>1 = output. | 0              | R/W    |
| 31:29 | -      | Reserved.                                                                                                              | 0              | -      |

### 9.5.4 GPIO port mask registers

These registers affect writing and reading the MPORT registers. Zeroes in these registers enable reading and writing; ones disable writing and result in zeros in corresponding positions when reading.

| Table 114. | <b>GPIO</b> mask port | register (MASK0 | , address 0xA000 | 2080) bit description |
|------------|-----------------------|-----------------|------------------|-----------------------|
|            |                       |                 |                  |                       |

| Bit   | Symbol | Description                                                                                                                                                                                                                                               | Reset<br>value | Access |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | MASKP  | Controls which bits corresponding to PIO0_n are active in the MPORT register (bit 0 = PIO0_0, bit 1 = PIO0_1,, bit 28 = PIO0_28).<br>0 = Read MPORT: pin state; write MPORT: load output bit.<br>1 = Read MPORT: 0; write MPORT: output bit not affected. | 0              | R/W    |
| 31:29 | -      | Reserved.                                                                                                                                                                                                                                                 | 0              | -      |

### 9.5.5 GPIO port pin registers

Reading these registers returns the current state of the pins read, regardless of direction, masking, or alternate functions, except that pins configured as analog I/O always read as 0s. Writing these registers loads the output bits of the pins written to, regardless of the Mask register.

| Bit   | Symbol | Description                                                                                                                                                                                   | Reset<br>value | Access |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | PORT   | Reads pin states or loads output bits (bit 0 = PIO0_0, bit 1 = PIO0_1,, bit 38 = PIO0_28).<br>0 = Read: pin is low; write: clear output bit.<br>1 = Read: pin is high; write: set output bit. | ext            | R/W    |
| 31:29 | -      | Reserved.                                                                                                                                                                                     | 0              | -      |

Table 115. GPIO port pin register (PIN0, address 0xA000 2100) bit description

## 9.5.6 GPIO masked port pin registers

These registers are similar to the PORT registers, except that the value read is masked by ANDing with the inverted contents of the corresponding MASK register, and writing to one of these registers only affects output register bits that are enabled by zeros in the corresponding MASK register

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                 | Reset<br>value | Access |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | MPORTP | Masked port register (bit 0 = PIO0_0, bit 1 =PIO0_1,, bit<br>28 = PIO0_28).<br>0 = Read: pin is LOW and/or the corresponding bit in the<br>MASK register is 1; write: clear output bit if the<br>corresponding bit in the MASK register is 0.<br>1 = Read: pin is HIGH and the corresponding bit in the<br>MASK register is 0; write: set output bit if the<br>corresponding bit in the MASK register is 0. | ext            | R/W    |
| 31:29 | -      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   | 0              | -      |

### 9.5.7 GPIO port set registers

Output bits can be set by writing ones to these registers, regardless of MASK registers. Reading from these register returns the port's output bits, regardless of pin directions.

| Table 117. | GPIO port set register | (SET0, address 0xA000 | 2200) bit description |
|------------|------------------------|-----------------------|-----------------------|
|------------|------------------------|-----------------------|-----------------------|

| Bit   | Symbol | Description                                                                                                                                                                  | Reset<br>value | Access |
|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | SETP   | Read or set output bits (bit 0 = PIO0_0, bit 1 =PIO0_1,,<br>bit 28 = PIO0_28).<br>0 = Read: output bit: write: no operation.<br>1 = Read: output bit; write: set output bit. | 0              | R/W    |
| 31:29 | -      | Reserved.                                                                                                                                                                    | 0              | -      |

### 9.5.8 GPIO port clear registers

Output bits can be cleared by writing ones to these write-only registers, regardless of MASK registers.

#### Chapter 9: LPC83x General Purpose I/O (GPIO)

| Bit   | Symbol | Description                                                                                                            | Reset<br>value | Access |
|-------|--------|------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | CLRP   | Clear output bits (bit 0 = PIO0_0, bit 1 =PIO0_1,,<br>bit 28 = PIO0_28).<br>0 = No operation.<br>1 = Clear output bit. | NA             | WO     |
| 31:29 | -      | Reserved.                                                                                                              | 0              | -      |

Table 118. GPIO port clear register (CLR0, address 0xA000 2280) bit description

## 9.5.9 GPIO port toggle registers

Output bits can be set by writing ones to these write-only registers, regardless of MASK registers.

| Table 110  | GPIO port toggle register (NO | T0 address 0x 000 2300  | ) bit description |
|------------|-------------------------------|-------------------------|-------------------|
| Table 119. | GFIO port toggie register (NO | IU, auuress uxauuu 2300 | ) bit description |

| Bit   | Symbol | Description                                                                                                              | Reset<br>value | Access |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | NOTP   | Toggle output bits (bit 0 = PIO0_0, bit 1 =PIO0_1,, bit 28 =<br>PIO0_28).<br>0 = no operation.<br>1 = Toggle output bit. | NA             | WO     |
| 31:29 | -      | Reserved.                                                                                                                | 0              | -      |

#### 9.5.10 GPIO port direction set registers

Direction bits can be set by writing ones to these registers.

#### Table 120. GPIO port direction set register (DIRSET0, address 0xA000 2380) bit description

| Bit   | Symbol | Description                                                                                                            | Reset<br>value | Access |
|-------|--------|------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  |        | Set direction bits (bit 0 = PIO0_0, bit 1 = PIO0_1,, bit 28 = PIO0_28).<br>0 = No operation.<br>1 = Set direction bit. | 0              | WO     |
| 31:29 | -      | Reserved.                                                                                                              | 0              | -      |

### 9.5.11 GPIO port direction clear registers

Direction bits can be cleared by writing ones to these write-only registers.

#### Table 121. GPIO port direction clear register (DIRCLR0, 0xA000 2400) bit description

| Bit   | Symbol  | Description                                                                                                                  | Reset<br>value | Access |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 28:0  | DIRCLRP | Clear direction bits (bit 0 = PIO0_0, bit 1 =PIO0_1,,<br>bit 28 = PIO0_28).<br>0 = No operation.<br>1 = Clear direction bit. | NA             | WO     |
| 31:29 | -       | Reserved.                                                                                                                    | 0              | -      |

### 9.5.12 GPIO port direction toggle registers

Direction bits can be set by writing ones to these write-only registers.

**User manual** 

|       | description |                                                                                                                                |                |        |  |  |  |  |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------|----------------|--------|--|--|--|--|
| Bit   | Symbol      | Description                                                                                                                    | Reset<br>value | Access |  |  |  |  |
| 28:0  | DIRNOTP     | Toggle direction bits (bit 0 = PIO0_0, bit 1 =PIO0_1,, bit<br>28 = PIO0_28).<br>0 = no operation.<br>1 = Toggle direction bit. | NA             | WO     |  |  |  |  |
| 31:29 | -           | Reserved.                                                                                                                      | 0              | -      |  |  |  |  |

# Table 122. GPIO port direction toggle register (DIRNOT0, address 0xA000 2480) bit description

# 9.6 Functional description

### 9.6.1 Reading pin state

Software can read the state of all GPIO pins except those selected for analog input or output in the "I/O Configuration" logic. A pin does not have to be selected for GPIO in "I/O Configuration" in order to read its state. There are four ways to read pin state:

- The state of a single pin can be read with 7 high-order zeros from a Byte Pin register.
- The state of a single pin can be read in all bits of a byte, halfword, or word from a Word Pin register.
- The state of multiple pins in a port can be read as a byte, halfword, or word from a PORT register.
- The state of a selected subset of the pins in a port can be read from a Masked Port (MPORT) register. Pins having a 1 in the port's Mask register will read as 0 from its MPORT register.

## 9.6.2 GPIO output

Each GPIO pin has an output bit in the GPIO block. These output bits are the targets of write operations to the pins. Two conditions must be met in order for a pin's output bit to be driven onto the pin:

- 1. The pin must be selected for GPIO operation in the switch matrix (this is the default), and
- 2. the pin must be selected for output by a 1 in its port's DIR register.

If either or both of these conditions is (are) not met, writing to the pin has no effect.

There are multiple ways to change GPIO output bits:

- Writing to a Byte Pin register loads the output bit from the least significant bit.
- Writing to a Word Pin register loads the output bit with the OR of all of the bits written. (This feature follows the definition of truth of a multi-bit value in programming languages.)
- Writing to a port's PORT register loads the output bits of all the pins written to.
- Writing to a port's MPORT register loads the output bits of pins identified by zeros in corresponding positions of the port's MASK register.
- Writing ones to a port's SET register sets output bits.

UM11021

- Writing ones to a port's CLR register clears output bits.
- Writing ones to a port's NOT register toggles/complements/inverts output bits.

The state of a port's output bits can be read from its SET register. Reading any of the registers described in <u>Section 9.6.1</u> returns the state of pins, regardless of their direction or alternate functions.

### 9.6.3 Masked I/O

A port's MASK register defines which of its pins should be accessible in its MPORT register. Zeroes in MASK enable the corresponding pins to be read from and written to MPORT. Ones in MASK force a pin to read as 0 and its output bit to be unaffected by writes to MPORT. When a port's MASK register contains all zeros, its PORT and MPORT registers operate identically for reading and writing.

Applications in which interrupts can result in Masked GPIO operation, or in task switching among tasks that do Masked GPIO operation, must treat code that uses the Mask register as a protected/restricted region. This can be done by interrupt disabling or by using a semaphore.

The simpler way to protect a block of code that uses a MASK register is to disable interrupts before setting the MASK register, and re-enable them after the last operation that uses the MPORT or MASK register.

More efficiently, software can dedicate a semaphore to the MASK registers, and set/capture the semaphore controlling exclusive use of the MASK registers before setting the MASK registers, and release the semaphore after the last operation that uses the MPORT or MASK registers.

### 9.6.4 GPIO direction

Each pin in a GPIO port can be configured as input or output using the DIR registers. The direction of individual pins can be set, cleared, or toggled using the DIRSET, DIRCLR, and DIRNOT registers.

## 9.6.5 Recommended practices

The following lists some recommended uses for using the GPIO port registers:

- For initial setup after Reset or re-initialization, write the PORT registers.
- To change the state of one pin, write a Byte Pin or Word Pin register.
- To change the state of multiple pins at a time, write the SET and/or CLR registers.
- To change the state of multiple pins in a tightly controlled environment like a software state machine, consider using the NOT register. This can require less write operations than SET and CLR.
- To read the state of one pin, read a Byte Pin or Word Pin register.
- To make a decision based on multiple pins, read and mask a PORT register.

Chapter 10: LPC83x Pin interrupts/pattern match engine

Rev. 1.1 — 5 October 2016

**User manual** 

# 10.1 How to read this chapter

The pin interrupt generator and the pattern match engine are available on all LPC83x parts.

# **10.2 Features**

- Pin interrupts
  - Up to eight pins can be selected from all GPIO 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.
- Pattern match engine
  - Up to eight pins can be selected from all GPIO pins to contribute to a boolean expression. The boolean expression consists of specified levels and/or transitions on various combinations of these pins.
  - Each bit slice minterm (product term) comprising the specified boolean expression can generate its own, dedicated interrupt request.
  - Any occurrence of a pattern match can be programmed to also generate an RXEV notification to the ARM CPU. The RXEV signal can be connected to a pin.
  - Pattern match can be used, in conjunction with software, to create complex state machines based on pin inputs.

# **10.3 Basic configuration**

- Pin interrupts:
  - Select up to eight external interrupt pins from all GPIO port pins in the SYSCON block (<u>Table 47</u>). The pin selection process is the same for pin interrupts and the pattern match engine. The two features are mutually exclusive.
  - Enable the clock to the pin interrupt register block in the SYSAHBCLKCTRL register (<u>Table 33</u>, bit 6).
  - If you want to use the pin interrupts to wake up the part from deep-sleep mode or power-down mode, enable the pin interrupt wake-up feature in the STARTERP0 register (<u>Table 48</u>).
  - Each selected pin interrupt is assigned to one interrupt in the NVIC (interrupts #24 to #31 for pin interrupts 0 to 7).
- Pattern match engine:
  - Select up to eight external pins from all GPIO port pins in the SYSCON block (<u>Table 47</u>). The pin selection process is the same for pin interrupts and the pattern match engine. The two features are mutually exclusive.

- Enable the clock to the pin interrupt register block in the SYSAHBCLKCTRL register (Table 33, bit 6).
- Each bit slice of the pattern match engine is assigned to one interrupt in the NVIC (interrupts #24 to #31 for slices 0 to 7).
- The combined interrupt from all slices or slice combinations can be connected to the ARM RXEV request and to pin function GPIO\_INT\_BMAT through the switch matrix movable function register (PINASSIGN11, <u>Table 75</u>).

# 10.3.1 Configure pins as pin interrupts or as inputs to the pattern match engine

Follow these steps to configure pins as pin interrupts:

- 1. Determine the pins that serve as pin interrupts on the LPC800 package. See the data sheet for determining the GPIO port pin number associated with the package pin.
- 2. For each pin interrupt, program the GPIO port pin number into one of the eight PINTSEL registers in the SYSCON block.

**Remark:** The port pin number serves to identify the pin to the PINTSEL register. Any function, including GPIO, can be assigned to this pin through the switch matrix.

3. Enable each pin interrupt in the NVIC.

Once the pin interrupts or pattern match inputs are configured, you can set up the pin interrupt detection levels or the pattern match boolean expression.

See <u>Section 5.6.28 "Pin interrupt select registers"</u> in the SYSCON block for the PINTSEL registers.

# **10.4 Pin description**

The inputs to the pin interrupt and pattern match engine are determined by the pin interrupt select registers in the SYSCON block. See <u>Section 5.6.28 "Pin interrupt select registers"</u>.

The pattern match engine output is assigned to an external pin through the switch matrix.

See <u>Section 7.3.1 "Connect an internal signal to a package pin"</u> for the steps that you need to follow to assign the GPIO pattern match function to a pin.

| Table 123. | Pin interrupt/pattern | match engine | pin description |
|------------|-----------------------|--------------|-----------------|
|------------|-----------------------|--------------|-----------------|

| Function      | Direction | Pin | Description                  | SWM register | Reference |
|---------------|-----------|-----|------------------------------|--------------|-----------|
| GPIO_INT_BMAT | 0         | any | GPIO pattern match<br>output | PINASSIGN11  | Table 75  |

# **10.5 General description**

Pins with configurable functions can serve as external interrupts or inputs to the pattern match engine. You can configure up to eight pins total using the PINTSEL registers in the SYSCON block for these features.

UM11021

### 10.5.1 Pin interrupts

From all available GPIO pins, up to eight pins can be selected in the system control block to serve as external interrupt pins (see <u>Table 47</u>). The external interrupt pins are connected to eight individual interrupts in the NVIC and are created based on rising or falling edges or on the input level on the pin.



## 10.5.2 Pattern match engine

The pattern match feature allows complex boolean expressions to be constructed from the same set of eight GPIO pins that were selected for the GPIO pin interrupts. Each term in the boolean expression is implemented as one slice of the pattern match engine. A slice consists of an input selector and a detect logic. The slice input selector selects one input from the available eight inputs with each input connected to a pin by the input's PINTSEL register.

The detect logic monitors the selected input continuously and creates a HIGH output if the input qualifies as detected. Several terms can be combined to a minterm by designating a slice as an endpoint of the expression. A pin interrupt for this slice is asserted when the minterm evaluates as true.

**UM11021** 



The detect logic of each slice can detect the following events on the selected input:

- Edge with memory (sticky): A rising edge, a falling edge, or a rising or falling edge that is detected at any time after the edge-detection mechanism has been cleared. The input qualifies as detected (the detect logic output remains HIGH) until the pattern match engine detect logic is cleared again.
- Event (non-sticky): Every time an edge (rising or falling) is detected, the detect logic output for this pin goes HIGH. This bit is cleared after one clock cycle, and the detect logic can detect another edge,
- Level: A HIGH or LOW level on the selected input.

Figure 12 shows the details of the edge detection logic for each slice.

You can combine a sticky event with non-sticky events to create a pin interrupt whenever a rising or falling edge occurs after a qualifying edge event.

You can create a time window during which rising or falling edges can create a pin interrupt by combining a level detect with an event detect. See Section 10.7.3 for details.



#### **10.5.2.1** Inputs and outputs of the pattern match engine

The connections between the pins and the pattern match engine are shown in Figure 11. All inputs to the pattern match engine are selected in the SYSCON block and can be GPIO port pins or another pin function depending on the switch matrix configuration. The pattern match logic continuously monitors the eight inputs and generates interrupts when any one or more minterms (product terms) of the specified boolean expression is matched. A separate interrupt request is generated for each individual minterm.

In addition, the pattern match module can be enabled to generate a Receive Event (RXEV) output to the ARM core when a boolean expression is true (i.e. when any minterm is matched).

The RXEV output is also be routed to GPIO\_INT\_BMAT pin. This allows the GPIO module to provide a rudimentary programmable logic capability employing up to eight inputs and one output.

The pattern match function utilizes the same eight interrupt request lines as the pin interrupts, so these two features are mutually exclusive as far as interrupt generation is concerned. A control bit is provided to select whether interrupt requests are generated in response to the standard pin interrupts or to pattern matches. Note that, if the pin interrupts are selected, the RXEV request to the CPU can still be enabled for pattern matches.

**Remark:** Pattern matching cannot be used to wake the part up from Deep-sleep or power-down mode. Pin interrupts must be selected in order to use the pins for wake-up.

#### **10.5.2.2** Boolean expressions

The pattern match module is constructed of eight bit-slice elements. Each bit slice is programmed to represent one component of one minterm (product term) within the boolean expression. The interrupt request associated with the last bit slice for a particular minterm will be asserted whenever that minterm is matched. (See bit slice drawing Figure 12).

The pattern match capability can be used to create complex software state machines. Each minterm (and its corresponding individual interrupt) represents a different transition event to a new state. Software can then establish the new set of conditions (that is a new boolean expression) that will cause a transition out of the current state.

#### Example:

Assume the expression:  $(IN0) \sim (IN1)(IN3)^{+} (IN1)(IN2) + (IN0) \sim (IN3) \sim (IN4)$  is specified through the registers PMSRC (<u>Table 136</u>) and PMCFG (<u>Table 137</u>). Each term in the boolean expression, (IN0),  $\sim$ (IN1), (IN3)<sup>^</sup>, etc., represents one bit slice of the pattern match engine.

- In the first minterm (IN0)~(IN1)(IN3)^, bit slice 0 monitors for a high-level on input (IN0), bit slice 1 monitors for a low level on input (IN1) and bit slice 2 monitors for a rising-edge on input (IN3). If this combination is detected, that is if all three terms are true, the interrupt associated with bit slice 2 (PININT2\_IRQ) will be asserted.
- In the second minterm (IN1)(IN2), bit slice 3 monitors input (IN1) for a high level, bit slice 4 monitors input (IN2) for a high level. If this combination is detected, the interrupt associated with bit slice 4 (PININT4\_IRQ) will be asserted.
- In the third minterm (IN0)~(IN3)~(IN4), bit slice 5 monitors input (IN0) for a high level, bit slice 6 monitors input (IN3) for a low level, and bit slice 7 monitors input (IN4) for a low level. If this combination is detected, the interrupt associated with bit slice 7(PININT7\_IRQ) will be asserted.

UM11021

 The ORed result of all three minterms asserts the RXEV request to the CPU and the GPIO\_INT\_BMAT output. That is, if any of the three minterms are true, the output is asserted.

Related links:

Section 10.7.2

# **10.6 Register description**

| Name   | Access | Address<br>offset | Description                                                          | Reset<br>value | Reference |
|--------|--------|-------------------|----------------------------------------------------------------------|----------------|-----------|
| ISEL   | R/W    | 0x000             | Pin Interrupt Mode register                                          | 0              | Table 125 |
| IENR   | R/W    | 0x004             | Pin interrupt level or rising edge interrupt enable register         | 0              | Table 126 |
| SIENR  | WO     | 0x008             | Pin interrupt level or rising edge interrupt set register            | NA             | Table 127 |
| CIENR  | WO     | 0x00C             | Pin interrupt level (rising edge interrupt) clear register           | NA             | Table 128 |
| IENF   | R/W    | 0x010             | Pin interrupt active level or falling edge interrupt enable register | 0              | Table 129 |
| SIENF  | WO     | 0x014             | Pin interrupt active level or falling edge interrupt set register    | NA             | Table 130 |
| CIENF  | WO     | 0x018             | Pin interrupt active level or falling edge interrupt clear register  | NA             | Table 131 |
| RISE   | R/W    | 0x01C             | Pin interrupt rising edge register                                   | 0              | Table 132 |
| FALL   | R/W    | 0x020             | Pin interrupt falling edge register                                  | 0              | Table 133 |
| IST    | R/W    | 0x024             | Pin interrupt status register                                        | 0              | Table 134 |
| PMCTRL | R/W    | 0x028             | Pattern match interrupt control register                             | 0              | Table 135 |
| PMSRC  | R/W    | 0x02C             | Pattern match interrupt bit-slice source register                    | 0              | Table 136 |
| PMCFG  | R/W    | 0x030             | Pattern match interrupt bit slice configuration register             | 0              | Table 137 |

 Table 124. Register overview: Pin interrupts and pattern match engine (base address:

 0xA000 4000)

## 10.6.1 Pin interrupt mode register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the ISEL register determines whether the interrupt is edge or level sensitive.

| Bit  | Symbol | Description                                                                                                                                                 | Reset<br>value | Access |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | PMODE  | Selects the interrupt mode for each pin interrupt. Bit n<br>configures the pin interrupt selected in PINTSELn.<br>0 = Edge sensitive<br>1 = Level sensitive | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                   | -              | -      |

### 10.6.2 Pin interrupt level or rising edge interrupt enable register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the IENR register enables the interrupt depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the rising edge interrupt is enabled.
- If the pin interrupt mode is level sensitive (PMODE = 1), the level interrupt is enabled. The IENF register configures the active level (HIGH or LOW) for this interrupt.

# Table 126. Pin interrupt level or rising edge interrupt enable register (IENR, address 0xA0004004) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                    | Reset<br>value | Access |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | ENRL   | Enables the rising edge or level interrupt for each pin<br>interrupt. Bit n configures the pin interrupt selected in<br>PINTSELn.<br>0 = Disable rising edge or level interrupt.<br>1 = Enable rising edge or level interrupt. | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                      | -              | -      |

## 10.6.3 Pin interrupt level or rising edge interrupt set register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the SIENR register sets the corresponding bit in the IENR register depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the rising edge interrupt is set.
- If the pin interrupt mode is level sensitive (PMODE = 1), the level interrupt is set.

# Table 127. Pin interrupt level or rising edge interrupt set register (SIENR, address 0xA0004008) bit description

| Bit  | Symbol  | Description                                                                                                                                                                               | Reset<br>value | Access |
|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | SETENRL | Ones written to this address set bits in the IENR, thus<br>enabling interrupts. Bit n sets bit n in the IENR register.<br>0 = No operation.<br>1 = Enable rising edge or level interrupt. | NA             | WO     |
| 31:8 | -       | Reserved.                                                                                                                                                                                 | -              | -      |

## 10.6.4 Pin interrupt level or rising edge interrupt clear register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the CIENR register clears the corresponding bit in the IENR register depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the rising edge interrupt is cleared.
- If the pin interrupt mode is level sensitive (PMODE = 1), the level interrupt is cleared.

| Bit  | Symbol | Description                                                                                                                                                                                            | Reset<br>value | Access |  |  |  |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|--|--|--|
| 7:0  | CENRL  | Ones written to this address clear bits in the IENR, thus<br>disabling the interrupts. Bit n clears bit n in the IENR<br>register.<br>0 = No operation.<br>1 = Disable rising edge or level interrupt. | NA             | WO     |  |  |  |
| 31:8 | -      | Reserved.                                                                                                                                                                                              | -              | -      |  |  |  |

# Table 128. Pin interrupt level or rising edge interrupt clear register (CIENR, address 0xA000 400C) bit description

## 10.6.5 Pin interrupt active level or falling edge interrupt enable register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the IENF register enables the falling edge interrupt or the configures the level sensitivity depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the falling edge interrupt is enabled.
- If the pin interrupt mode is level sensitive (PMODE = 1), the active level of the level interrupt (HIGH or LOW) is configured.

# Table 129. Pin interrupt active level or falling edge interrupt enable register (IENF, address 0xA000 4010) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                              | Reset<br>value | Access |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | ENAF   | Enables the falling edge or configures the active level interrupt<br>for each pin interrupt. Bit n configures the pin interrupt selected<br>in PINTSELn.<br>0 = Disable falling edge interrupt or set active interrupt level<br>LOW.<br>1 = Enable falling edge interrupt enabled or set active interrupt<br>level HIGH. | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                                                                                                                | -              | -      |

## 10.6.6 Pin interrupt active level or falling edge interrupt set register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the SIENF register sets the corresponding bit in the IENF register depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the falling edge interrupt is set.
- If the pin interrupt mode is level sensitive (PMODE = 1), the HIGH-active interrupt is selected.

| Bit  | Symbol  |                                                                                                                                                                                                                      | Reset<br>value | Access |  |  |  |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|--|--|--|
| 7:0  | SETENAF | Ones written to this address set bits in the IENF, thus<br>enabling interrupts. Bit n sets bit n in the IENF register.<br>0 = No operation.<br>1 = Select HIGH-active interrupt or enable falling edge<br>interrupt. | NA             | WO     |  |  |  |
| 31:8 | -       | Reserved.                                                                                                                                                                                                            | -              | -      |  |  |  |

# Table 130. Pin interrupt active level or falling edge interrupt set register (SIENF, address 0xA000 4014) bit description

## 10.6.7 Pin interrupt active level or falling edge interrupt clear register

For each of the 8 pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>), one bit in the CIENF register sets the corresponding bit in the IENF register depending on the pin interrupt mode configured in the ISEL register:

- If the pin interrupt mode is edge sensitive (PMODE = 0), the falling edge interrupt is cleared.
- If the pin interrupt mode is level sensitive (PMODE = 1), the LOW-active interrupt is selected.

# Table 131. Pin interrupt active level or falling edge interrupt clear register (CIENF, address0xA000 4018) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                   | Reset<br>value | Access |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | CENAF  | Ones written to this address clears bits in the IENF, thus<br>disabling interrupts. Bit n clears bit n in the IENF register.<br>0 = No operation.<br>1 = LOW-active interrupt selected or falling edge interrupt<br>disabled. | NA             | WO     |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                     | -              | -      |

## 10.6.8 Pin interrupt rising edge register

This register contains ones for pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>) on which a rising edge has been detected. Writing ones to this register clears rising edge detection. Ones in this register assert an interrupt request for pins that are enabled for rising-edge interrupts. All edges are detected for all pins selected by the PINTSELn registers, regardless of whether they are interrupt-enabled.

| Table 132 | Pin interrupt rising | j edge register (RIS | E, address 0xA000 | 401C) bit description |
|-----------|----------------------|----------------------|-------------------|-----------------------|
|-----------|----------------------|----------------------|-------------------|-----------------------|

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                            | Reset<br>value | Access |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | RDET   | Rising edge detect. Bit n detects the rising edge of the pin<br>selected in PINTSELn.<br>Read 0: No rising edge has been detected on this pin since<br>Reset or the last time a one was written to this bit.<br>Write 0: no operation.<br>Read 1: a rising edge has been detected since Reset or the<br>last time a one was written to this bit.<br>Write 1: clear rising edge detection for this pin. | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                              | -              | -      |

## 10.6.9 Pin interrupt falling edge register

This register contains ones for pin interrupts selected in the PINTSELn registers (see <u>Section 5.6.28</u>) on which a falling edge has been detected. Writing ones to this register clears falling edge detection. Ones in this register assert an interrupt request for pins that are enabled for falling-edge interrupts. All edges are detected for all pins selected by the PINTSELn registers, regardless of whether they are interrupt-enabled.

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                 | Reset<br>value | Access |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | FDET   | Falling edge detect. Bit n detects the falling edge of the pin<br>selected in PINTSELn.<br>Read 0: No falling edge has been detected on this pin since<br>Reset or the last time a one was written to this bit.<br>Write 0: no operation.<br>Read 1: a falling edge has been detected since Reset or the<br>last time a one was written to this bit.<br>Write 1: clear falling edge detection for this pin. | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   | -              | -      |

Table 133. Pin interrupt falling edge register (FALL, address 0xA000 4020) bit description

### 10.6.10 Pin interrupt status register

Reading this register returns ones for pin interrupts that are currently requesting an interrupt. For pins identified as edge-sensitive in the Interrupt Select register, writing ones to this register clears both rising- and falling-edge detection for the pin. For level-sensitive pins, writing ones inverts the corresponding bit in the Active level register, thus switching the active level on the pin.

| Table 134. | Pin interrupt status | s register (IST, addres | ss 0xA000 4024) bit descripti | on |
|------------|----------------------|-------------------------|-------------------------------|----|
|------------|----------------------|-------------------------|-------------------------------|----|

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset<br>value | Access |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 7:0  | PSTAT  | Pin interrupt status. Bit n returns the status, clears the edge<br>interrupt, or inverts the active level of the pin selected in<br>PINTSELn.<br>Read 0: interrupt is not being requested for this interrupt pin.<br>Write 0: no operation.<br>Read 1: interrupt is being requested for this interrupt pin.<br>Write 1 (edge-sensitive): clear rising- and falling-edge<br>detection for this pin.<br>Write 1 (level-sensitive): switch the active level for this pin (in<br>the IENF register). | 0              | R/W    |
| 31:8 | -      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -              | -      |

## 10.6.11 Pattern Match Interrupt Control Register

The pattern match control register contains one bit to select pattern-match interrupt generation (as opposed to pin interrupts which share the same interrupt request lines), and another to enable the RXEV output to the cpu. This register also allows the current state of any pattern matches to be read.

If the pattern match feature is not used (either for interrupt generation or for RXEV assertion) bits SEL\_PMATCH and ENA\_RXEV of this register should be left at 0 to conserve power.

UM11021

**Remark:** Set up the pattern-match configuration in the PMSRC and PMCFG registers before writing to this register to enable (or re-enable) the pattern-match functionality. This eliminates the possibility of spurious interrupts as the feature is being enabled.

 Table 135. Pattern match interrupt control register (PMCTRL, address 0xA000 4028)

 bit description

| Bit   | Symbol     | Value | Description                                                                                                                                                                                              | Reset<br>value                                                                |
|-------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| 0     | SEL_PMATCH |       | Specifies whether the 8 pin interrupts are controlled by<br>the pin interrupt function or by the pattern match<br>function.                                                                              | 0                                                                             |
|       |            | 0     | Pin interrupt. Interrupts are driven in response to the standard pin interrupt function                                                                                                                  | value<br>y 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 |
|       |            | 1     | Pattern match. Interrupts are driven in response to pattern matches.                                                                                                                                     | _                                                                             |
| 1     | ENA_RXEV   |       | Enables the RXEV output to the ARM cpu and/or to a GPIO output when the specified boolean expression evaluates to true.                                                                                  | 0                                                                             |
|       |            | 0     | Disabled. RXEV output to the cpu is disabled.                                                                                                                                                            |                                                                               |
|       |            | 1     | Enabled. RXEV output to the cpu is enabled.                                                                                                                                                              |                                                                               |
| 23:2  | -          |       | Reserved. Do not write 1s to unused bits.                                                                                                                                                                | 0                                                                             |
| 31:24 | PMAT       | -     | This field displays the current state of pattern matches.<br>A 1 in any bit of this field indicates that the<br>corresponding product term is matched by the current<br>state of the appropriate inputs. | 0x0                                                                           |

## 10.6.12 Pattern Match Interrupt Bit-Slice Source register

The bit-slice source register specifies the input source for each of the eight pattern match bit slices.

Each of the possible eight inputs is selected in the pin interrupt select registers in the SYSCON block. See <u>Section 5.6.28</u>. Input 0 corresponds to the pin selected in the PINTSEL0 register, input 1 corresponds to the pin selected in the PINTSEL1 register, and so forth.

**Remark:** Writing any value to either the PMCFG register or the PMSRC register, or disabling the pattern-match feature (by clearing both the SEL\_PMATCH and ENA\_RXEV bits in the PMCTRL register to zeros) will erase all edge-detect history.

| Table 136. | Pattern match bit-sl | ice source reaister | (PMSRC, addres | s 0xA000 402C | ) bit description |
|------------|----------------------|---------------------|----------------|---------------|-------------------|
|            |                      |                     |                |               |                   |

| Bit | Symbol   | Value | Description                                  | Reset value |
|-----|----------|-------|----------------------------------------------|-------------|
| 7:0 | Reserved |       | Software should not write 1s to unused bits. | 0           |

| Bit   | Symbol                   | Value                                                                                    | Description                                                                              | Reset value |
|-------|--------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------|
| 10:8  | SRC0                     |                                                                                          | Selects the input source for bit slice 0                                                 | 0           |
|       |                          | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 0. |             |
|       |                          | 0x1                                                                                      | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 0. |             |
|       |                          | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 0. | -           |
|       |                          | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 0. | _           |
|       |                          | 0x4                                                                                      | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 0. | -           |
|       |                          | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 0. |             |
|       |                          | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 0. |             |
|       |                          | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 0. |             |
| 13:11 | SRC1                     |                                                                                          | Selects the input source for bit slice 1                                                 | 0           |
|       |                          | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 1. |             |
|       |                          | 0x1                                                                                      | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 1. | -           |
|       |                          | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 1. |             |
|       |                          | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 1. |             |
|       | to bit sl<br>0x5 Input 5 | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 1. |                                                                                          |             |
|       |                          | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 1. |             |
|       |                          | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 1. |             |
|       |                          | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 1. | 0           |

#### Table 136. Pattern match bit-slice source register (PMSRC, address 0xA000 402C) bit description

| Bit   | Symbol | Value                                                                      | Description                                                                              | Reset value                                                                              |
|-------|--------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| 16:14 | SRC2   |                                                                            | Selects the input source for bit slice 2                                                 | 0                                                                                        |
|       |        | 0x0                                                                        | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x1                                                                        | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x2                                                                        | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x3                                                                        | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x4                                                                        | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x5                                                                        | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x6                                                                        | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 2. |                                                                                          |
|       |        | 0x7                                                                        | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 2. |                                                                                          |
| 19:17 | SRC3   | C3 Selects th                                                              | Selects the input source for bit slice 3                                                 | 0                                                                                        |
|       |        | 0x0                                                                        | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 3. |                                                                                          |
|       |        | 0x1 Input 1. Selects the pin selected in the PINTSEL1 r<br>to bit slice 3. | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 3. |                                                                                          |
|       |        | 0x2                                                                        | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 3. |                                                                                          |
|       |        | 0x3                                                                        | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 3. |                                                                                          |
|       | -      | 0x4                                                                        | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 3. |                                                                                          |
|       |        | 0x5                                                                        | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 3. |                                                                                          |
|       |        |                                                                            | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 3. |
|       |        | 0x7                                                                        | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 3. | 0                                                                                        |

#### Table 136. Pattern match bit-slice source register (PMSRC, address 0xA000 402C) bit description

| Bit   | Symbol                                                                                   | Value                                                                                    | Description                                                                              | Reset value |
|-------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------|
| 22:20 | SRC4                                                                                     |                                                                                          | Selects the input source for bit slice 4                                                 | 0           |
|       |                                                                                          | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 4. | -           |
|       |                                                                                          | 0x1                                                                                      | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x4                                                                                      | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 4. |             |
|       |                                                                                          | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 4. |             |
| 25:23 | SRC5                                                                                     |                                                                                          | Selects the input source for bit slice 5                                                 | 0           |
|       |                                                                                          | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 5. |             |
|       |                                                                                          | 0x1                                                                                      | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 5. |             |
|       |                                                                                          | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 5. |             |
|       |                                                                                          | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 5. |             |
|       | to bit slice 5.0x5Input 5. Selects the pin selected in the PINTSEL5 r<br>to bit slice 5. | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 5. |                                                                                          |             |
|       |                                                                                          | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 5. |             |
|       |                                                                                          | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 5. |             |
|       |                                                                                          | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 5. |             |

#### Table 136. Pattern match bit-slice source register (PMSRC, address 0xA000 402C) bit description

| Bit   | Symbol          | Value                                                                                    | Description                                                                              | Reset value |
|-------|-----------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------|
| 28:26 | SRC6            |                                                                                          | Selects the input source for bit slice 6                                                 | 0           |
|       |                 | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 6. |             |
|       |                 | 0x1 Input 1. Selects the pin selected in the PIN to bit slice 6.                         | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 6. |             |
|       |                 | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 6. | -           |
|       |                 | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 6. |             |
|       |                 | 0x4                                                                                      | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 6. |             |
|       |                 | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 6. |             |
|       |                 | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 6. |             |
|       |                 | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 6. |             |
| 31:29 | to bit slice 7. |                                                                                          | Selects the input source for bit slice 7                                                 | 0           |
|       |                 | 0x0                                                                                      | Input 0. Selects the pin selected in the PINTSEL0 register as the source to bit slice 7. | -           |
|       |                 | Input 1. Selects the pin selected in the PINTSEL1 register as the source to bit slice 7. |                                                                                          |             |
|       |                 | 0x2                                                                                      | Input 2. Selects the pin selected in the PINTSEL2 register as the source to bit slice 7. |             |
|       |                 | 0x3                                                                                      | Input 3. Selects the pin selected in the PINTSEL3 register as the source to bit slice 7. |             |
|       |                 | Input 4. Selects the pin selected in the PINTSEL4 register as the source to bit slice 7. |                                                                                          |             |
|       |                 | 0x5                                                                                      | Input 5. Selects the pin selected in the PINTSEL5 register as the source to bit slice 7. |             |
|       |                 | 0x6                                                                                      | Input 6. Selects the pin selected in the PINTSEL6 register as the source to bit slice 7. |             |
|       |                 | 0x7                                                                                      | Input 7. Selects the pin selected in the PINTSEL7 register as the source to bit slice 7. |             |

#### Table 136. Pattern match bit-slice source register (PMSRC, address 0xA000 402C) bit description

# 10.6.13 Pattern Match Interrupt Bit Slice Configuration register

The bit-slice configuration register configures the detect logic and contains bits to select from among eight alternative conditions for each bit slice that cause that bit slice to contribute to a pattern match. The seven LSBs of this register specify which bit-slices are the end-points of product terms in the boolean expression (i.e. where OR terms are to be inserted in the expression).

Two types of edge detection on each input are possible:

- Sticky: A rising edge, a falling edge, or a rising or falling edge that is detected at any time after the edge-detection mechanism has been cleared. The input qualifies as detected (the detect logic output remains HIGH) until the pattern match engine detect logic is cleared again.
- Non-sticky: Every time an edge (rising or falling) is detected, the detect logic output for this pin goes HIGH. This bit is cleared after one clock cycle, and the edge detect logic can detect another edge,

**Remark:** To clear the pattern match engine detect logic, write any value to either the PMCFG register or the PMSRC register, or disable the pattern-match feature (by clearing both the SEL\_PMATCH and ENA\_RXEV bits in the PMCTRL register to zeros). This will erase all edge-detect history.

To select whether a slice marks the final component in a minterm of the boolean expression, write a 1 in the corresponding PROD\_ENPTSn bit. Setting a term as the final component has two effects:

- 1. The interrupt request associated with this bit slice will be asserted whenever a match to that product term is detected.
- The next bit slice will start a new, independent product term in the boolean expression (i.e. an OR will be inserted in the boolean expression following the element controlled by this bit slice).

Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description

| Bit | Symbol           | Value                                                 | Description                                                                                                                            | Reset<br>value                         |  |
|-----|------------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|
| 0   | PROD_EN          |                                                       | Determines whether slice 0 is an endpoint.                                                                                             | 0                                      |  |
|     | DPTS0            | 0                                                     | No effect. Slice 0 is not an endpoint.                                                                                                 |                                        |  |
|     |                  | 1                                                     | endpoint. Slice 0 is the endpoint of a product term (minterm). Pin interrupt 0 in the NVIC is raised if the minterm evaluates as true. |                                        |  |
| 1   | PROD_EN          |                                                       | Determines whether slice 1 is an endpoint.                                                                                             | 0                                      |  |
|     | DPTS1            | 0                                                     | No effect. Slice 1 is not an endpoint.                                                                                                 |                                        |  |
|     |                  | 1                                                     | endpoint. Slice 1 is the endpoint of a product term (minterm). Pin interrupt 1 in the NVIC is raised if the minterm evaluates as true. |                                        |  |
| 2   | PROD_EN<br>DPTS2 |                                                       | Determines whether slice 2 is an endpoint.                                                                                             | 0                                      |  |
|     |                  | DPTS2                                                 | 0 No effect. Slice 2 is not an endpoint.                                                                                               | No effect. Slice 2 is not an endpoint. |  |
|     |                  | 1                                                     | endpoint. Slice 2 is the endpoint of a product term (minterm). Pin interrupt 2 in the NVIC is raised if the minterm evaluates as true. |                                        |  |
| 3   | PROD_EN          |                                                       | Determines whether slice 3 is an endpoint.                                                                                             | 0                                      |  |
|     | DPTS3            | <sup>3</sup> 0 No effect. Slice 3 is not an endpoint. | No effect. Slice 3 is not an endpoint.                                                                                                 |                                        |  |
|     |                  | 1                                                     | endpoint. Slice 3 is the endpoint of a product term (minterm). Pin interrupt 3 in the NVIC is raised if the minterm evaluates as true. |                                        |  |
| 4   | PROD_EN          |                                                       | Determines whether slice 4 is an endpoint.                                                                                             | 0                                      |  |
|     | DPTS4            | 0                                                     | No effect. Slice 4 is not an endpoint.                                                                                                 |                                        |  |
|     |                  | 1                                                     | endpoint. Slice 4 is the endpoint of a product term (minterm). Pin interrupt 4 in the NVIC is raised if the minterm evaluates as true. |                                        |  |

| Bit  | Symbol  | Value                                                                                                                                      | Description                                                                                                                                                                                                                                                              | Reset<br>value |
|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5    | PROD_EN |                                                                                                                                            | Determines whether slice 5 is an endpoint.                                                                                                                                                                                                                               | 0              |
|      | DPTS5   | 0                                                                                                                                          | No effect. Slice 5 is not an endpoint.                                                                                                                                                                                                                                   |                |
|      |         | 1                                                                                                                                          | endpoint. Slice 5 is the endpoint of a product term (minterm). Pin interrupt 5 in the NVIC is raised if the minterm evaluates as true.                                                                                                                                   |                |
| 6    | PROD_EN |                                                                                                                                            | Determines whether slice 6 is an endpoint.                                                                                                                                                                                                                               | 0              |
|      | DPTS6   | 0                                                                                                                                          | No effect. Slice 6 is not an endpoint.                                                                                                                                                                                                                                   |                |
|      |         | 1                                                                                                                                          | endpoint. Slice 6 is the endpoint of a product term (minterm). Pin interrupt 6 in the NVIC is raised if the minterm evaluates as true.                                                                                                                                   |                |
| 7    | -       |                                                                                                                                            | Reserved. Bit slice 7 is automatically considered a product end point.                                                                                                                                                                                                   | 0              |
| 10:8 | CFG0    |                                                                                                                                            | Specifies the match contribution condition for bit slice 0.                                                                                                                                                                                                              | 0b000          |
|      |         | 0x0                                                                                                                                        | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                |
|      |         | 0x1                                                                                                                                        | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                              |                |
|      |         | 0x2                                                                                                                                        | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                |
|      |         | 0x3                                                                                                                                        | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. | _              |
|      |         | 0x4 High level. Match (for this bit slice) occurs when there is a high level on the in specified for this bit slice in the PMSRC register. | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                |
|      |         | 0x5                                                                                                                                        | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                | -              |
|      |         | 0x6 Constant 0. This bit slice never contributes to a match (should b unused bit slices).                                                  | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                |
|      |         | 0x7                                                                                                                                        | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          |                |

#### Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description ... continued

| Bit   | Symbol | Value | Description                                                                                                                                                                                                                                                              | Reset<br>value                                                                                                                                                                                                                              |   |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 13:11 | CFG1   |       | Specifies the match contribution condition for bit slice 1.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |   |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |   |
|       |        | 0x1   | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                              | _                                                                                                                                                                                                                                           |   |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |   |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |                                                                                                                                                                                                                                             |   |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |   |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |   |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |   |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          | _                                                                                                                                                                                                                                           |   |
| 16:14 | CFG2   |       | Specifies the match contribution condition for bit slice 2.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |   |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |   |
|       |        |       | 0x1                                                                                                                                                                                                                                                                      | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. | _ |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |   |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |                                                                                                                                                                                                                                             |   |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |   |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                | ]                                                                                                                                                                                                                                           |   |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |   |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          |                                                                                                                                                                                                                                             |   |

## Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description ...continued

| Bit   | Symbol | Value | Description                                                                                                                                                                                                                                                              | Reset<br>value                                                                                                                                                                                                                              |  |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 19:17 | CFG3   |       | Specifies the match contribution condition for bit slice 3.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |  |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x1   | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                              | _                                                                                                                                                                                                                                           |  |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |  |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |                                                                                                                                                                                                                                             |  |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |  |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          | -                                                                                                                                                                                                                                           |  |
| 22:20 | CFG4   |       | Specifies the match contribution condition for bit slice 4.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |  |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        |       | 0x1                                                                                                                                                                                                                                                                      | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |  |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |  |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |                                                                                                                                                                                                                                             |  |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                | ]                                                                                                                                                                                                                                           |  |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |  |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          |                                                                                                                                                                                                                                             |  |

## Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description ...continued

| Bit   | Symbol | Value | Description                                                                                                                                                                                                                                                              | Reset<br>value                                                                                                                                                                                                                              |  |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 25:23 | CFG5   |       | Specifies the match contribution condition for bit slice 5.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |  |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x1   | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                              |                                                                                                                                                                                                                                             |  |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |  |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |                                                                                                                                                                                                                                             |  |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |  |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          |                                                                                                                                                                                                                                             |  |
| 28:26 | CFG6   |       | Specifies the match contribution condition for bit slice 6.                                                                                                                                                                                                              | 0b000                                                                                                                                                                                                                                       |  |
|       |        | 0x0   | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        |       | 0x1                                                                                                                                                                                                                                                                      | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. |  |
|       |        | 0x2   | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                            |                                                                                                                                                                                                                                             |  |
|       |        | 0x3   | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. | _                                                                                                                                                                                                                                           |  |
|       |        | 0x4   | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                             |  |
|       |        | 0x5   | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                | 1                                                                                                                                                                                                                                           |  |
|       |        | 0x6   | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices).                                                                                                                                                               |                                                                                                                                                                                                                                             |  |
|       |        | 0x7   | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle.                          |                                                                                                                                                                                                                                             |  |

## Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description ...continued

| Bit   | Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Value                                                                                                                                                                                                                                                                    | Description                                                                                                                                                                                                                                     | Reset<br>value                                                                                             |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|
| 31:29 | CFG7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                          | Specifies the match contribution condition for bit slice 7.                                                                                                                                                                                     | 0b000                                                                                                      |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0                                                                                                                                                                                                                                                                      | Constant HIGH. This bit slice always contributes to a product term match.                                                                                                                                                                       |                                                                                                            |  |
|       | <ul> <li>since the last time the edge detection for this bit slice was cleared when the PMCFG or the PMSRC registers are wr</li> <li>0x2</li> <li>Sticky falling edge. Match occurs if a falling edge on the sp since the last time the edge detection for this bit slice was cleared when the PMCFG or the PMSRC registers are wr</li> <li>0x3</li> <li>Sticky rising or falling edge. Match occurs if either a rising specified input has occurred since the last time the edge of was cleared. This bit is only cleared when the PMCFG or written to.</li> <li>0x4</li> <li>High level. Match (for this bit slice) occurs when there is a specified for this bit slice in the PMSRC register.</li> <li>0x5</li> <li>Low level. Match occurs when there is a low level on the specified bit slices).</li> <li>0x7</li> <li>Event. Non-sticky rising or falling edge. Match occurs on a rising or falling edge is first detected on the specified input</li> </ul> | Sticky rising edge. Match occurs if a rising edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.                              | _                                                                                                                                                                                                                                               |                                                                                                            |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x2                                                                                                                                                                                                                                                                      | Sticky falling edge. Match occurs if a falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to.   | _                                                                                                          |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Sticky rising or falling edge. Match occurs if either a rising or falling edge on the specified input has occurred since the last time the edge detection for this bit slice was cleared. This bit is only cleared when the PMCFG or the PMSRC registers are written to. | _                                                                                                                                                                                                                                               |                                                                                                            |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | High level. Match (for this bit slice) occurs when there is a high level on the input specified for this bit slice in the PMSRC register.                                                                                                                                |                                                                                                                                                                                                                                                 |                                                                                                            |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Low level. Match occurs when there is a low level on the specified input.                                                                                                                                                                                                |                                                                                                                                                                                                                                                 |                                                                                                            |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                          | 0x6                                                                                                                                                                                                                                             | Constant 0. This bit slice never contributes to a match (should be used to disable any unused bit slices). |  |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x7                                                                                                                                                                                                                                                                      | Event. Non-sticky rising or falling edge. Match occurs on an event - i.e. when either a rising or falling edge is first detected on the specified input (this is a non-sticky version of value 0x3). This bit is cleared after one clock cycle. |                                                                                                            |  |

#### Table 137. Pattern match bit slice configuration register (PMCFG, address 0xA000 4030) bit description ... continued

# **10.7 Functional description**

### 10.7.1 Pin interrupts

In this interrupt facility, up to 8 pins are identified as interrupt sources by the Pin Interrupt Select registers (PINTSEL0-7). All registers in the pin interrupt block contain 8 bits, corresponding to the pins called out by the PINTSEL0-7 registers. The ISEL register defines whether each interrupt pin is edge- or level-sensitive. The RISE and FALL registers detect edges on each interrupt pin, and can be written to clear (and set) edge detection. The IST register indicates whether each interrupt pin is currently requesting an interrupt, and this register can also be written to clear interrupts.

The other pin interrupt registers play different roles for edge-sensitive and level-sensitive pins, as described in <u>Table 138</u>.

|       |                                           | •                                  |
|-------|-------------------------------------------|------------------------------------|
| Name  | Edge-sensitive function                   | Level-sensitive function           |
| IENR  | Enables rising-edge interrupts.           | Enables level interrupts.          |
| SIENR | Write to enable rising-edge interrupts.   | Write to enable level interrupts.  |
| CIENR | Write to disable rising-edge interrupts.  | Write to disable level interrupts. |
| IENF  | Enables falling-edge interrupts.          | Selects active level.              |
| SIENF | Write to enable falling-edge interrupts.  | Write to select high-active.       |
| CIENF | Write to disable falling-edge interrupts. | Write to select low-active.        |

 Table 138. Pin interrupt registers for edge- and level-sensitive pins

### 10.7.2 Pattern Match engine example

Suppose the desired boolean pattern to be matched is: (IN1) + (IN1 \* IN2) + (~IN2 \* ~IN3 \* IN6fe) + (IN5 \* IN7ev)

with:

IN6fe = (sticky) falling-edge on input 6

IN7ev = (non-sticky) event (rising or falling edge) on input 7

Each individual term in the expression shown above is controlled by one bit-slice. To specify this expression, program the pattern match bit slice source and configuration register fields as follows:

- PMSRC register (<u>Table 136</u>):
  - Since bit slice 5 will be used to detect a sticky event on input 6, you can write a 1 to the SRC5 bits to clear any pre-existing edge detects on bit slice 5.
  - SRC0: 001 select input 1 for bit slice 0
  - SRC1: 001 select input 1 for bit slice 1
  - SRC2: 010 select input 2 for bit slice 2
  - SRC3: 010 select input 2 for bit slice 3
  - SRC4: 011 select input 3 for bit slice 4
  - SRC5: 110 select input 6 for bit slice 5
  - SRC6: 101 select input 5 for bit slice 6
  - SRC7: 111 select input 7 for bit slice 7
- PMCFG register (<u>Table 137</u>):
  - PROD\_ENDPTS0 = 1
  - PROD\_ENDPTS02 = 1
  - PROD\_ENDPTS5 = 1
  - All other slices are not product term endpoints and their PROD\_ENDPTS bits are
     0. Slice 7 is always a product term endpoint and does not have a register bit associated with it.
  - = 0100101 bit slices 0, 2, 5, and 7 are product-term endpoints. (Bit
    - slice 7 is an endpoint by default no associated register bit).
  - CFG0: 000 high level on the selected input (input 1) for bit slice 0
  - CFG1: 000 high level on the selected input (input 1) for bit slice 1
  - CFG2: 000 high level on the selected input (input 2) for bit slice 2
  - CFG3: 101 low level on the selected input (input 2) for bit slice 3
  - CFG4: 101 low level on the selected input (input 3) for bit slice 4
  - CFG5: 010 (sticky) falling edge on the selected input (input 6) for bit slice 5
  - CFG6: 000 high level on the selected input (input 5) for bit slice 6
  - CFG7: 111 event (any edge, non-sticky) on the selected input (input 7) for bit slice 7
- PMCTRL register (<u>Table 135</u>):

 Bit0: Setting this bit will select pattern matches to generate the pin interrupts in place of the normal pin interrupt mechanism.

For this example, pin interrupt 0 will be asserted when a match is detected on the first product term (which, in this case, is just a high level on input 1).

Pin interrupt 2 will be asserted in response to a match on the second product term.

Pin interrupt 5 will be asserted when there is a match on the third product term.

Pin interrupt 7 will be asserted on a match on the last term.

- Bit1: Setting this bit will cause the RxEv signal to the ARM CPU to be asserted whenever a match occurs on ANY of the product terms in the expression.
   Otherwise, the RXEV line will not be used.
- Bit31:24: At any given time, bits 0, 2, 5 and/or 7 may be high if the corresponding product terms are currently matching.
- The remaining bits will always be low.

### **10.7.3** Pattern match engine edge detect examples

| slice 0 (IN0re)<br>IN0                                                                                                      |                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| slice 1 (IN1ev)         IN1         NVIC pin interrupt 1         and GPIO_INT_BMAT output                                   | minterm<br>(IN0re)(IN1ev)<br>pin interrupt raised on<br>falling edge on input 1 any time<br>after IN0 has gone HIGH |
| SRC1 = 1, CFG1 = 0x7, PROD_ENPTS1 = 0x1 (non-sticky edge detection)                                                         | J                                                                                                                   |
| Figure shows pattern match functionality only and accurate timing is not implied. Inpusymmetry system clock for simplicity. | uts (INn) are shown synchronized to the                                                                             |
| Fig 13. Pattern match engine examples: sticky edge detect                                                                   |                                                                                                                     |

| slice 0 (IN0)           IN0           SRC0 = 0, CFG0 = 0x4, PROD_ENPTS0 = 0x0 (high level detection)                                                           |                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| slice 1 (IN1ev)       IN1       NVIC pin interrupt 1       and GPIO_INT_BMAT output                                                                            | minterm<br>(IN0)(IN1ev)<br>pin interrupt raised<br>on rising edge of IN1 during<br>the HIGH level of IN0 |
| SRC1 = 1, CFG1 = 0x7, PROD_ENPTS1 = 0x1 (non-sticky edge detection)<br>Figure shows pattern match functionality only and accurate timing is not implied. Input | ts (INn) are shown synchronized to the                                                                   |
| system clock for simplicity. Fig 14. Pattern match engine examples: Windowed non-sticky edge detect eva                                                        | luates as true                                                                                           |
|                                                                                                                                                                |                                                                                                          |
| slice 0 (IN0)         IN0         SRC0 = 0, CFG0 = 0x4, PROD_ENPTS0 = 0x0 (high level detection)         slice 1 (IN1ev)         IN1                           | minterm<br>(IN0)(IN1ev)                                                                                  |
| NVIC pin interrupt 1<br>and GPIO_INT_BMAT output<br>SRC1 = 1, CFG1 = 0x7, PROD_ENPTS1 = 0x1 (non-sticky edge detection)                                        | no pin interrupt raised<br>IN1 does not change while<br>IN0 level is HIGH                                |
| Figure shows pattern match functionality only and accurate timing is not implied. Input system clock for simplicity.                                           | ts (INn) are shown synchronized to the                                                                   |
| Fig 15. Pattern match engine examples: Windowed non-sticky edge detect eva                                                                                     | luates as false                                                                                          |

# UM11021

Chapter 11: LPC83x Input multiplexing and DMA trigger multiplexing (INPUT MUX, DMA TRIGMUX)

Rev. 1.1 — 5 October 2016

**User manual** 

# 11.1 How to read this chapter

SCT input multiplexing and DMA input multiplexing is available for all parts.

## **11.2 Features**

- Configures the inputs to the SCTimer/PWM.
- Configures the inputs to the DMA triggers.

# **11.3 Basic configuration**

- In the SYSAHBCLKCTRL register, enable the SCT clock to write to the INPUT MUX registers. See <u>Table 35</u>.
- In the SYSAHBCLKCTRL register, enable the DMA clock to write to the DMA TRIGMUX registers. See <u>Table 35</u>.

# **11.4 Pin description**

The input multiplexer has no dedicated pins. However, external pins can be selected as inputs to the SCT input multiplexer. Multiplexer inputs from external pins are assigned through the switch matrix to pins.

#### Table 139. INPUT MUX pin description

| Pin functions                             | Peripheral | Input mux reference |
|-------------------------------------------|------------|---------------------|
| SCT_PIN0, SCT_PIN1,<br>SCT_PIN2, SCT_PIN3 | SCT0       | Table 144           |

# **11.5 General description**

The inputs to the four SCTs, to the DMA trigger, to the eight pin interrupts, and to the frequency measure block are multiplexed to multiple input sources. The sources can be external pins, interrupts, or output signals of other peripherals.

The input multiplexing makes it possible to design complex event-driven processes without CPU intervention by connecting peripherals like the SCT and the ADC.

The DMA can use trigger input multiplexing to sequence DMA transactions without the use of interrupt service routines.

Chapter 11: LPC83x Input multiplexing and DMA trigger multiplexing

## 11.5.1 SCT input multiplexing



## 11.5.2 DMA trigger input multiplexing



# **11.6 Register description**

All input multiplexer registers reside on word address boundaries. Details of the registers appear in the description of each function.

All address offsets not shown in Table 141 are reserved and should not be written to.

Table 140. Register overview: Input multiplexing (base address 0x4002 8000)

| Name              | Access | Offset | Description                                 | Reset<br>value | Reference |
|-------------------|--------|--------|---------------------------------------------|----------------|-----------|
| DMA_ITRIG_INMUX0  | R/W    | 0x000  | Trigger select register for DMA channel 0.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX1  | R/W    | 0x004  | Trigger select register for DMA channel 1.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX2  | R/W    | 0x008  | Trigger select register for DMA channel 2.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX3  | R/W    | 0x00C  | Trigger select register for DMA channel 3.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX4  | R/W    | 0x010  | Trigger select register for DMA channel 4.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX5  | R/W    | 0x014  | Trigger select register for DMA channel 5.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX6  | R/W    | 0x018  | Trigger select register for DMA channel 6.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX7  | R/W    | 0x01C  | Trigger select register for DMA channel 7.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX8  | R/W    | 0x020  | Trigger select register for DMA channel 8.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX9  | R/W    | 0x024  | Trigger select register for DMA channel 9.  | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX10 | R/W    | 0x028  | Trigger select register for DMA channel 10. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX11 | R/W    | 0x02C  | Trigger select register for DMA channel 11. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX12 | R/W    | 0x030  | Trigger select register for DMA channel 12. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX13 | R/W    | 0x034  | Trigger select register for DMA channel 13. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX14 | R/W    | 0x038  | Trigger select register for DMA channel 14. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX15 | R/W    | 0x03C  | Trigger select register for DMA channel 15. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX16 | R/W    | 0x040  | Trigger select register for DMA channel 16. | 0x0F           | Table 142 |
| DMA_ITRIG_INMUX17 | R/W    | 0x044  | Trigger select register for DMA channel 17. | 0x0F           | Table 142 |

#### Table 141. Register overview: Input multiplexing (base address 0x4002 C000)

| Name             | Access | Offset | Description                                           | Reset<br>value | Reference |
|------------------|--------|--------|-------------------------------------------------------|----------------|-----------|
| DMA_INMUX_INMUX0 | R/W    | 0x000  | DMA output trigger selection to become DMA trigger 7. | 0x1F           | Table 143 |
| DMA_INMUX_INMUX1 | R/W    | 0x004  | DMA output trigger selection to become DMA trigger 8. | 0x1F           | Table 143 |
| SCT0_INMUX0      | R/W    | 0x020  | Input mux register for SCT input 0                    | 0x0F           | Table 144 |
| SCT0_INMUX1      | R/W    | 0x024  | Input mux register for SCT input 1                    | 0x0F           | Table 144 |
| SCT0_INMUX2      | R/W    | 0x028  | Input mux register for SCT input 2                    | 0x0F           | Table 144 |
| SCT0_INMUX3      | R/W    | 0x02C  | Input mux register for SCT input 3                    | 0x0F           | Table 144 |

### 11.6.1 DMA input trigger input mux registers 0 to 17

With the DMA input trigger input mux registers you can select one trigger input for each of the 18 DMA channels from multiple internal sources.

By default, none of the triggers are selected.

UM11021

#### Table 142. DMA input trigger Input mux registers 0 to 17 (DMA\_ITRIG\_INMUX[0:17], address 0x4002 80E0 (DMA\_ITRIG\_INMUX0) to 0x4002 8124 (DMA\_ITRIG\_INMUX17)) bit description

| Bit  | Symbol | Value | Description                                                                                            | Reset<br>value |
|------|--------|-------|--------------------------------------------------------------------------------------------------------|----------------|
| 3:0  | INP    |       | Trigger input number (decimal value) for DMA channel $n (n = 0 to 8)$ . All other values are reserved. | 0x0F           |
|      |        | 0x0   | ADC_SEQA_IRQ                                                                                           |                |
|      |        | 0x1   | ADC_SEQB_IRQ                                                                                           |                |
|      |        | 0x2   | SCT_DMA0                                                                                               |                |
|      |        | 0x3   | SCT_DMA1                                                                                               |                |
|      |        | 0x4   | Reserved                                                                                               |                |
|      |        | 0x5   | PININTO                                                                                                |                |
|      |        | 0x6   | PININT1                                                                                                |                |
|      |        | 0x7   | DMA trigger mux 0. (DMA_INMUX_INMUX0).                                                                 |                |
|      |        | 0x8   | DMA trigger mux 1. (DMA_INMUX_INMUX1)                                                                  |                |
| 31:4 | -      |       | Reserved.                                                                                              | -              |
|      |        |       |                                                                                                        |                |

### 11.6.2 DMA trigger input mux input registers 0 to 1

This register provides a multiplexer for inputs 7 to 8 of each DMA trigger input mux register DMA\_ITRIG\_INMUX. These inputs can be selected from the 18 trigger outputs generated by the DMA (one trigger output per channel).

By default, none of the triggers are selected.

#### Table 143. DMA input trigger input mux input registers 0 to 1 (DMA\_INMUX\_INMUX[0:1], address 0x4002 C000 (DMA\_INMUX\_INMUX0) to 0x4002 C004 (DMA\_INMUX\_INMUX1)) bit description

| Bit  | Symbol | Description                                                                | Reset value |
|------|--------|----------------------------------------------------------------------------|-------------|
| 4:0  | INP    | DMA trigger output number (decimal value) for DMA channel n (n = 0 to 17). | 0x1F        |
| 31:5 | -      | Reserved.                                                                  | -           |

### 11.6.3 SCT input mux registers 0 to 3

With the SCT0 Input mux registers you can select one input source for each SCT input from 8 external and internal sources.

The output of SCT Input mux register 0 selects the source for SCT0 input 0, the output of SCT0 Input mux register 1 selects the source for SCT0 input 1, and so forth up to SCT0 Input mux register 3, which selects the input for SCT0 input 3.

The value to be programmed in this register is the input number ranging from 0 for pin function SCT\_IN0 to 7 for the DEBUG\_HALTED signal from the ARM CoreSight debug signal.

Inputs 0 to 3 are connected to external pins through the switch matrix.

#### Chapter 11: LPC83x Input multiplexing and DMA trigger multiplexing

| Bit  | Symbol | Value | Description                                         | Reset<br>value |
|------|--------|-------|-----------------------------------------------------|----------------|
| 3:0  | INP_N  |       | Input number (decimal value) to SCT0 inputs 0 to 3. | 0x0F           |
|      |        | 0x0   | SCT_PIN0. Assign to pin using the switch matrix.    |                |
|      |        | 0x1   | SCT_PIN1. Assign to pin using the switch matrix.    |                |
|      |        | 0x2   | SCT_PIN2. Assign to pin using the switch matrix.    |                |
|      |        | 0x3   | SCT_PIN3. Assign to pin using the switch matrix.    |                |
|      |        | 0x4   | ADC_THCMP_IRQ                                       |                |
|      |        | 0x5   | Reserved                                            |                |
|      |        | 0x6   | ARM_TXEV                                            |                |
|      |        | 0x7   | DEBUG_HALTED                                        |                |
| 31:4 | -      |       | Reserved.                                           | -              |

# Table 144. SCT input mux registers 0 to 3 (SCT0\_INMUX[0:3], address 0x4002 C020 (SCT0\_INMUX0) to 0x4002 C02C (SCT0\_INMUX3)) bit description

# **UM11021**

Chapter 12: LPC83x DMA controller

Rev. 1.1 — 5 October 2016

**User manual** 

# 12.1 How to read this chapter

The DMA controller is available on all parts.

# 12.2 Features

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

# **12.3 Basic configuration**

Configure the DMA as follows:

- Use the SYSAHBCLKCTRL register (<u>Table 35</u>) to enable the clock to the DMA registers interface.
- The DMA interrupt is connected to slot #20 in the NVIC.
- Each DMA channel has one DMA request line associated and can also select one of nine input triggers through the input multiplexer registers DMA\_ITRIG\_INMUX[0:17].
- Trigger outputs are connected to DMA\_INMUX\_INMUX[0:3] as inputs to DMA triggers.

For details on the trigger input and output multiplexing, see <u>Section 11.5.2 "DMA trigger</u> input multiplexing".

## 12.3.1 Hardware triggers

Each DMA channel can use one trigger that is independent of the request input for this channel. The trigger input is selected in the DMA\_ITRIG\_INMUX registers. There are 20 possible internal trigger sources for each channel with each trigger signal issued by the output of a peripheral. In addition, the DMA trigger output can be routed to the trigger input of another channel through the trigger input multiplexing. See <u>Section 11.5.2 "DMA</u> trigger input multiplexing".

See <u>Table 145</u> for the connection of input multiplexers to DMA channels.

See <u>Table 142</u> for a list of possible trigger input sources.

## 12.3.2 Trigger outputs

Each channel of the DMA controller provides a trigger output. This allows the possibility of using the trigger outputs as a trigger source to a different channel in order to support complex transfers on selected peripherals. This kind of transfer can, for example, use more than one peripheral DMA request. An example use would be to input data to a holding buffer from one peripheral, and then output the data to another peripheral, with both transfers being paced by the appropriate peripheral DMA request. This kind of operation is called "chained operation" or "channel chaining".

### 12.3.3 DMA requests

DMA requests are directly connected to the peripherals. Each channel supports one DMA request line and one trigger input which is multiplexed to many possible input sources.

For each trigger multiplexer DMA\_ITRIG\_INMUXn, the following sources are supported:

- ADC sequence A interrupt ADC\_SEQA\_IRQ
- ADC sequence B interrupt ADC\_SEQB\_IRQ
- SCT DMA request 0 SCT\_DMA0
- SCT DMA request 1 SCT\_DMA1
- GPIO pin interrupt 0 (PININT0)
- GPIO pin interrupt 1 (PININT1)
- Two choices of one of the DMA output triggers

| DMA channel # | Request input | DMA trigger multiplexer |
|---------------|---------------|-------------------------|
| 0             | USART0_RX_DMA | DMA_ITRIG_INMUX0        |
| 1             | USART0_TX_DMA | DMA_ITRIG_INMUX1        |
| 2             | Reserved      | DMA_ITRIG_INMUX2        |
| 3             | Reserved      | DMA_ITRIG_INMUX3        |
| 4             | Reserved      | DMA_ITRIG_INMUX4        |
| 5             | Reserved      | DMA_ITRIG_INMUX5        |
| 6             | SPI0_RX_DMA   | DMA_ITRIG_INMUX6        |
| 7             | SPI0_TX_DMA   | DMA_ITRIG_INMUX7        |
| 8             | SPI1_RX_DMA   | DMA_ITRIG_INMUX8        |
| 9             | SPI1_TX_DMA   | DMA_ITRIG_INMUX9        |
| 10            | I2C0_SLV_DMA  | DMA_ITRIG_INMUX10       |
| 11            | I2C0_MST_DMA  | DMA_ITRIG_INMUX11       |
| 12            | Reserved      | DMA_ITRIG_INMUX12       |
| 13            | Reserved      | DMA_ITRIG_INMUX13       |
| 14            | Reserved      | DMA_ITRIG_INMUX14       |
| 15            | Reserved      | DMA_ITRIG_INMUX15       |
| 16            | Reserved      | DMA_ITRIG_INMUX16       |
| 17            | Reserved      | DMA_ITRIG_INMUX17       |

#### Table 145. DMA requests

UM11021

## 12.3.4 DMA in sleep mode

The DMA can operate and access all SRAM blocks in sleep mode.

# **12.4 Pin description**

The DMA controller has no configurable pins.

# 12.5 General description



### 12.5.1 DMA requests and triggers

An operation on a DMA channel can be initiated by either a DMA request or a trigger event. DMA requests come from peripherals and specifically indicate when a peripheral either needs input data to be read from it, or that output data may be sent to it. DMA requests are created by the UART, SPI, and I2C peripherals. A trigger initiates a DMA operation and can be a signal from an unrelated peripheral. Peripherals that generate triggers are the SCT and the ADC. In addition, the DMA triggers also create an trigger output that can trigger DMA transactions on another channel. Triggers can be used to send a character or a string to a UART or other serial output at a fixed time interval or when an event occurs.

A DMA channel using a trigger can respond by moving data from any memory address to any other memory address. This can include fixed peripheral data registers, or incrementing through RAM buffers. The amount of data moved by a single trigger event can range from a single transfer to many transfers. A transfer that is started by a trigger can still be paced using the channel's DMA request. This allows sending a string to a serial peripheral, for instance, without overrunning the peripheral's transmit buffer.

Each trigger input to the DMA has a corresponding output that can be used as a trigger input to another channel. The trigger outputs appear in the trigger source list for each channel and can be selected through the DMA\_INMUX registers as inputs to other channels.

### 12.5.2 DMA Modes

The DMA controller doesn't really have separate operating modes, but there are ways of using the DMA controller that have commonly used terminology in the industry.

Once the DMA controller is set up for operation, using any specific DMA channel requires initializing the registers associated with that channel (see <u>Table 145</u>), and supplying at least the channel descriptor, which is located somewhere in memory, typically in on-chip SRAM (see <u>Section 12.6.3</u>). The channel descriptor is shown in <u>Table 147</u>.

| Offset | Description             |
|--------|-------------------------|
| + 0x0  | Reserved                |
| + 0x4  | Source data end address |
| + 0x8  | Destination end address |
| + 0xC  | Link to next descriptor |

Table 146. Channel descriptor

The source and destination end addresses, as well as the link to the next descriptor are just memory addresses that can point to any valid address on the device. The starting address for both source and destination data is the specified end address minus the transfer length (XFERCOUNT \* the address increment as defined by SRCINC and DSTINC). The link to the next descriptor is used only if it is a linked transfer.

After the channel has had a sufficient number of DMA requests and/or triggers, depending on its configuration, the initial descriptor will be exhausted. At that point, if the transfer configuration directs it, the channel descriptor will be reloaded with data from memory pointed to by the "Link to next descriptor" entry of the initial channel descriptor. Descriptors loaded in this manner look slightly different the channel descriptor, as shown in <u>Table 147</u>. The difference is that a new transfer configuration is specified in the reload descriptor instead of being written to the XFERCFG register for that channel.

This process repeats as each descriptor is exhausted as long as reload is selected in the transfer configuration for each new descriptor.

| Offset | Description                                                                                                                                                                                                                                     |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| + 0x0  | Transfer configuration.                                                                                                                                                                                                                         |
| + 0x4  | Source end address. This points to the address of the last entry of the source address range if the address is incremented. The address to be used in the transfer is calculated from the end address, data width, and transfer size.           |
| + 0x8  | Destination end address. This points to the address of the last entry of the destination address range if the address is incremented. The address to be used in the transfer is calculated from the end address, data width, and transfer size. |
| + 0xC  | Link to next descriptor. If used, this address must be aligned to a multiple of 16 bytes (i.e., the size of a descriptor).                                                                                                                      |

#### Table 147. Reload descriptors

## 12.5.3 Single buffer

This generally applies to memory to memory moves, and peripheral DMA that occurs only occasionally and is set up for each transfer. For this kind of operation, only the initial channel descriptor shown in <u>Table 148</u> is needed.

#### Table 148. Channel descriptor for a single transfer

| Offset | Description                  |
|--------|------------------------------|
| + 0x0  | Reserved                     |
| + 0x4  | Source data end address      |
| + 0x8  | Destination data end address |
| + 0xC  | (not used)                   |

This case is identified by the Reload bit in the XFERCFG register = 0. When the DMA channel receives a DMA request or trigger (depending on how it is configured), it performs one or more transfers as configured, then stops. Once the channel descriptor is exhausted, additional DMA requests or triggers will have no effect until the channel configuration is updated by software.

## 12.5.4 Ping-Pong

Ping-pong is a special case of a linked transfer. It is described separately because it is typically used more frequently than more complicated versions of linked transfers.

A ping-pong transfer uses two buffers alternately. At any one time, one buffer is being loaded or unloaded by DMA operations. The other buffer has the opposite operation being handled by software, readying the buffer for use when the buffer currently being used by the DMA controller is full or empty. <u>Table 149</u> shows an example of descriptors for ping-pong from a peripheral to two buffers in memory.

| Channel Descriptor |                             |  | Descriptor B |                                 |  | Descriptor A |                                 |  |
|--------------------|-----------------------------|--|--------------|---------------------------------|--|--------------|---------------------------------|--|
| + 0x0              | (not used)                  |  | + 0x0        | Buffer B transfer configuration |  | + 0x0        | Buffer A transfer configuration |  |
| + 0x4              | Peripheral data end address |  | + 0x4        | Peripheral data end address     |  | + 0x4        | Peripheral data end address     |  |
| + 0x8              | Buffer A memory end address |  | + 0x8        | Buffer B memory end address     |  | + 0x8        | Buffer A memory end address     |  |
| + 0xC              | Address of descriptor B     |  | + 0xC        | Address of descriptor A         |  | + 0xC        | Address of descriptor B         |  |

#### Table 149. Example descriptors for ping-pong operation: peripheral to buffer

In this example, the channel descriptor is used first, with a first buffer in memory called buffer A. The configuration of the DMA channel must have been set to indicate a reload. Similarly, both descriptor A and descriptor B must also specify reload. When the channel descriptor is exhausted, descriptor B is loaded using the link to descriptor B, and a transfer interrupt informs the CPU that buffer A is available.

Descriptor B is then used until it is also exhausted, when descriptor A is loaded using the link to descriptor A contained in descriptor B. Then a transfer interrupt informs the CPU that buffer B is available for processing. The process repeats when descriptor A is exhausted, alternately using each of the 2 memory buffers.

### 12.5.5 Linked transfers (linked list)

A linked transfer can use any number of descriptors to define a complicated transfer. This can be configured such that a single transfer, a portion of a transfer, one whole descriptor, or an entire structure of links can be initiated by a single DMA request or trigger.

An example of a linked transfer could start out like the example for a ping-pong transfer (Table 149). The difference would be that descriptor B would not link back to descriptor A, but would continue on to another different descriptor. This could continue as long as desired, and can be ended anywhere, or linked back to any point to repeat a sequence of descriptors. Of course, any descriptor not currently in use can be altered by software as well.

### 12.5.6 Address alignment for data transfers

Transfers of 16 bit width require an address alignment to a multiple of 2 bytes. Transfers of 32 bit width require an address alignment to a multiple of 4 bytes. Transfers of 8 bit width can be at any address.

### 12.5.7 Channel chaining

Channel chaining is a feature which allows completion of a DMA transfer on channel x to trigger a DMA transfer on channel y. This feature can for example be used to have DMA channel x reading n bytes from UART to memory, and then have DMA channel y transferring the received bytes to the CRC engine, without any action required from the ARM core.

To use channel chaining, first configure DMA channels x and y as if no channel chaining would be used. Then:

• For channel x:

UM11021

- If channel x is configured to auto reload the descriptor on exhausting of the descriptor (bit RELOAD in the transfer configuration of the descriptor is set), then enable 'clear trigger on descriptor exhausted' by setting bit CLRTRIG in the channel's transfer configuration in the descriptor.
- For channel y:
  - Configure the input trigger input mux register (DMA\_ITRIG\_INMUX[0:17]) for channel y to use any of the available DMA trigger muxes (DMA trigger mux 0/1).
  - Configure the chosen DMA trigger mux to select DMA channel x.
  - Enable hardware triggering by setting bit HWTRIGEN in the channel configuration register.
  - Set the trigger type to edge sensitive by clearing bit TRIGTYPE in the channel configuration register.
  - Configure the trigger edge to falling edge by clearing bit TRIGPOL in the channel configuration register.

Note that after completion of channel x the descriptor may be reloaded (if configured so), but remains un-triggered. To configure the chain to auto-trigger itself, setup channels x and y for channel chaining as described above. In addition to that:

- A ping-pong configuration for both channel x and y is recommended, so that data currently moved by channel y is not altered by channel x.
- For channel x:
  - Configure the input trigger input mux register (DMA\_ITRIG\_INMUX[0:17]) for channel y to use the same DMA trigger mux as chosen for channel y.
  - Enable hardware triggering by setting bit HWTRIGEN in the channel configuration register.
  - Set the trigger type to edge sensitive by clearing bit TRIGTYPE in the channel configuration register.
  - Configure the trigger edge to falling edge by clearing bit TRIGPOL in the channel configuration register.

# **12.6 Register description**

The DMA registers are grouped into DMA control, interrupt and status registers and DMA channel registers. DMA transfers are controlled by a set of three registers per channel, the CFG, CTRLSTAT, and XFERCFG registers.

The reset value reflects the data stored in used bits only. It does not include the content of reserved bits.

| Name             | Access                              | Address<br>offset | Description                                      | Reset<br>Value | Reference |  |  |
|------------------|-------------------------------------|-------------------|--------------------------------------------------|----------------|-----------|--|--|
| Global control a | Global control and status registers |                   |                                                  |                |           |  |  |
| CTRL             | R/W                                 | 0x000             | DMA control.                                     | 0              | Table 151 |  |  |
| INTSTAT          | RO                                  | 0x004             | Interrupt status.                                | 0              | Table 152 |  |  |
| SRAMBASE         | R/W                                 | 0x008             | SRAM address of the channel configuration table. | 0              | Table 153 |  |  |

#### Table 150. Register overview: DMA controller (base address 0x5000 8000)

| Name             | Access | Address<br>offset | Description                                         | Reset<br>Value | Reference |
|------------------|--------|-------------------|-----------------------------------------------------|----------------|-----------|
| Shared registers | 1      |                   | 1                                                   |                |           |
| ENABLESET0       | RO/W1  | 0x020             | Channel Enable read and Set for all DMA channels.   | 0              | Table 155 |
| ENABLECLR0       | W1     | 0x028             | Channel Enable Clear for all DMA channels.          | NA             | Table 156 |
| ACTIVE0          | RO     | 0x030             | Channel Active status for all DMA channels.         | 0              | Table 157 |
| BUSY0            | RO     | 0x038             | Channel Busy status for all DMA channels.           | 0              | Table 158 |
| ERRINT0          | RO/W1  | 0x040             | Error Interrupt status for all DMA channels.        | 0              | Table 159 |
| INTENSET0        | RO/W1  | 0x048             | Interrupt Enable read and Set for all DMA channels. | 0              | Table 160 |
| INTENCLR0        | W1     | 0x050             | Interrupt Enable Clear for all DMA channels.        | NA             | Table 161 |
| INTA0            | RO/W1  | 0x058             | Interrupt A status for all DMA channels.            | 0              | Table 162 |
| INTB0            | RO/W1  | 0x060             | Interrupt B status for all DMA channels.            | 0              | Table 163 |
| SETVALID0        | W1     | 0x068             | Set ValidPending control bits for all DMA channels. | NA             | Table 164 |
| SETTRIG0         | W1     | 0x070             | Set Trigger control bits for all DMA channels.      | NA             | Table 165 |
| ABORT0           | W1     | 0x078             | 78 Channel Abort control for all DMA channels.      |                | Table 166 |
| Channel0 registe | rs     |                   |                                                     |                |           |
| CFG0             | R/W    | 0x400             | Configuration register for DMA channel 0.           |                | Table 167 |
| CTLSTAT0         | RO     | 0x404             | Control and status register for DMA channel 0.      |                | Table 169 |
| XFERCFG0         | R/W    | 0x408             | Transfer configuration register for DMA channel 0.  |                | Table 170 |
| Channel1 registe | rs     |                   | 1                                                   |                |           |
| CFG1             | R/W    | 0x410             | Configuration register for DMA channel 1.           |                | Table 167 |
| CTLSTAT1         | RO     | 0x414             | Control and status register for DMA channel 1.      |                | Table 169 |
| XFERCFG1         | R/W    | 0x418             | Transfer configuration register for DMA channel 1.  |                | Table 170 |
| Channel2 registe | rs     |                   | 1                                                   |                |           |
| CFG2             | R/W    | 0x420             | Configuration register for DMA channel 2.           |                | Table 167 |
| CTLSTAT2         | RO     | 0x424             | Control and status register for DMA channel 2.      |                | Table 169 |
| XFERCFG2         | R/W    | 0x428             | Transfer configuration register for DMA channel 2.  |                | Table 170 |
| Channel3 registe | rs     |                   | 1                                                   |                |           |
| CFG3             | R/W    | 0x430             | Configuration register for DMA channel 3.           |                | Table 167 |
| CTLSTAT3         | RO     | 0x434             | Control and status register for DMA channel 3.      |                | Table 169 |
| XFERCFG3         | R/W    | 0x438             | Transfer configuration register for DMA channel 3.  |                | Table 170 |
| Channel4 registe | rs     |                   |                                                     |                |           |
| CFG4             | R/W    | 0x440             | Configuration register for DMA channel 4.           |                | Table 167 |
| CTLSTAT4         | RO     | 0x444             | Control and status register for DMA channel 4.      |                | Table 169 |
| XFERCFG4         | R/W    | 0x448             | Transfer configuration register for DMA channel 4.  |                | Table 170 |
| Channel5 registe | rs     |                   | 1                                                   |                |           |
| CFG5             | R/W    | 0x450             | Configuration register for DMA channel 5.           |                | Table 167 |
| CTLSTAT5         | RO     | 0x454             | Control and status register for DMA channel 5.      |                | Table 169 |
| XFERCFG5         | R/W    | 0x458             | Transfer configuration register for DMA channel 5.  |                | Table 170 |
| Channel6 registe | rs     | 1                 | 1                                                   | I              |           |
| CFG6             | R/W    | 0x460             | Configuration register for DMA channel 6.           |                | Table 167 |
| CTLSTAT6         | RO     | 0x464             | Control and status register for DMA channel 6.      |                | Table 169 |

#### Table 150. Register overview: DMA controller (base address 0x5000 8000)

| Name           | Access                                                                                  | Address<br>offset | Description                                         | Reset<br>Value | Reference           Table 170 |
|----------------|-----------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------|----------------|-------------------------------|
| XFERCFG6       | R/W                                                                                     | 0x468             | Transfer configuration register for DMA channel 6.  |                |                               |
| Channel7 regis | sters                                                                                   | 1                 | 1                                                   |                |                               |
| CFG7           | R/W                                                                                     | 0x470             | Configuration register for DMA channel 7.           |                | Table 167                     |
| CTLSTAT7       | RO                                                                                      | 0x474             | Control and status register for DMA channel 7.      |                | Table 169                     |
| XFERCFG7       | R/W                                                                                     | 0x478             | Transfer configuration register for DMA channel 7.  |                | Table 170                     |
| Channel8 regis | sters                                                                                   | -                 |                                                     |                |                               |
| CFG8           | R/W                                                                                     | 0x480             | Configuration register for DMA channel 8.           |                | Table 167                     |
| CTLSTAT8       | RO                                                                                      | 0x484             | Control and status register for DMA channel 8.      |                | Table 169                     |
| XFERCFG8       | B8         R/W         0x488         Transfer configuration register for DMA channel 8. |                   |                                                     | Table 170      |                               |
| Channel9 regis | sters                                                                                   | -                 |                                                     |                |                               |
| CFG9           | R/W                                                                                     | 0x490             | Configuration register for DMA channel 9.           |                | Table 167                     |
| CTLSTAT9       | RO                                                                                      | 0x494             | Control and status register for DMA channel 9.      |                | Table 169                     |
| XFERCFG9       | R/W                                                                                     | 0x498             | Transfer configuration register for DMA channel 9.  |                | Table 170                     |
| Channel10 reg  | isters                                                                                  |                   |                                                     |                |                               |
| CFG10          | R/W                                                                                     | 0x4A0             | Configuration register for DMA channel 10.          |                | Table 167                     |
| CTLSTAT10      | RO                                                                                      | 0x4A4             | Control and status register for DMA channel 10.     |                | Table 169                     |
| XFERCFG10      | R/W                                                                                     | 0x4A8             | Transfer configuration register for DMA channel 10. |                | Table 170                     |
| Channel11 reg  | isters                                                                                  | -                 |                                                     |                |                               |
| CFG11          | R/W                                                                                     | 0x4B0             | Configuration register for DMA channel 11.          |                | Table 167                     |
| CTLSTAT11      | RO                                                                                      | 0x4B4             | Control and status register for DMA channel 11.     |                | Table 169                     |
| XFERCFG11      | R/W                                                                                     | 0x4B8             | Transfer configuration register for DMA channel 11. |                | Table 170                     |
| Channel12 reg  | isters                                                                                  | 1                 |                                                     |                |                               |
| CFG12          | R/W                                                                                     | 0x4C0             | Configuration register for DMA channel 12.          |                | Table 167                     |
| CTLSTAT12      | RO                                                                                      | 0x4C4             | Control and status register for DMA channel 12.     |                | Table 169                     |
| XFERCFG12      | R/W                                                                                     | 0x4C8             | Transfer configuration register for DMA channel 12. |                | Table 170                     |
| Channel13 reg  | isters                                                                                  | 1                 |                                                     |                |                               |
| CFG13          | R/W                                                                                     | 0x4D0             | Configuration register for DMA channel 13.          |                | Table 167                     |
| CTLSTAT13      | RO                                                                                      | 0x4D4             | Control and status register for DMA channel 13.     |                | Table 169                     |
| XFERCFG13      | R/W                                                                                     | 0x4D8             | Transfer configuration register for DMA channel 13. |                | Table 170                     |
| Channel14 reg  | isters                                                                                  |                   |                                                     |                |                               |
| CFG14          | R/W                                                                                     | 0x4E0             | Configuration register for DMA channel 14.          |                | Table 167                     |
| CTLSTAT14      | RO                                                                                      | 0x4E4             | Control and status register for DMA channel 14.     |                | Table 169                     |
| XFERCFG14      | R/W                                                                                     | 0x4E8             | Transfer configuration register for DMA channel 14. |                | Table 170                     |
| Channel15 reg  | isters                                                                                  |                   |                                                     |                | ÷                             |
| CFG15          | R/W                                                                                     | 0x4F0             | Configuration register for DMA channel 15.          |                | Table 167                     |
| CTLSTAT15      | RO                                                                                      | 0x4F4             | Control and status register for DMA channel 15.     |                | Table 169                     |
| XFERCFG15      | R/W                                                                                     | 0x4F8             | Transfer configuration register for DMA channel 15. |                | Table 170                     |
| Channel16 reg  | isters                                                                                  |                   |                                                     |                |                               |
| CFG16          | R/W                                                                                     | 0x500             | Configuration register for DMA channel 16.          |                | Table 167                     |
| CTLSTAT16      | RO                                                                                      | 0x504             | Control and status register for DMA channel 16.     |                | Table 169                     |

#### Table 150. Register overview: DMA controller (base address 0x5000 8000)

| Name             | Access | Address<br>offset | Description                                         | Reset<br>Value | Reference |
|------------------|--------|-------------------|-----------------------------------------------------|----------------|-----------|
| XFERCFG16        | R/W    | 0x508             | Transfer configuration register for DMA channel 16. |                | Table 170 |
| Channel17 regist | ers    |                   |                                                     |                |           |
| CFG17            | R/W    | 0x510             | Configuration register for DMA channel 17.          |                | Table 167 |
| CTLSTAT17        | RO     | 0x514             | Control and status register for DMA channel 17.     |                | Table 169 |
| XFERCFG17        | R/W    | 0x518             | Transfer configuration register for DMA channel 17. |                | Table 170 |

#### Table 150. Register overview: DMA controller (base address 0x5000 8000)

## 12.6.1 Control register

The CTRL register contains global the control bit for a enabling the DMA controller.

Table 151. Control register (CTRL, address 0x5000 8000) bit description

| Bit  | Symbol | Value | Description                                                                                                                                                                                 | Reset<br>value |
|------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | ENABLE |       | DMA controller master enable.                                                                                                                                                               | 0              |
|      |        | 0     | Disabled. The DMA controller is disabled. This clears any triggers that were asserted at the point when disabled, but does not prevent re-triggering when the DMA controller is re-enabled. |                |
|      |        | 1     | Enabled. The DMA controller is enabled.                                                                                                                                                     |                |
| 31:1 | -      |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                             | NA             |

### 12.6.2 Interrupt Status register

The Read-Only INTSTAT register provides an overview of DMA status. This allows quick determination of whether any enabled interrupts are pending. Details of which channels are involved are found in the interrupt type specific registers.

| Bit  | Symbol       | Value | Description                                                                              | Reset<br>value |
|------|--------------|-------|------------------------------------------------------------------------------------------|----------------|
| 0    | -            |       | Reserved. Read value is undefined, only zero should be written.                          | NA             |
| 1    | ACTIVEINT    |       | Summarizes whether any enabled interrupts are pending (except pending error interrupts). | 0              |
|      |              | 0     | Not pending. No enabled interrupts are pending.                                          |                |
|      |              | 1     | Pending. At least one enabled interrupt is pending.                                      |                |
| 2    | ACTIVEERRINT |       | Summarizes whether any error interrupts are pending.                                     | 0              |
|      |              | 0     | Not pending. No error interrupts are pending.                                            | -              |
|      |              | 1     | Pending. At least one error interrupt is pending.                                        | -              |
| 31:3 | -            |       | Reserved. Read value is undefined, only zero should be written.                          | NA             |

Table 152. Interrupt Status register (INTSTAT, address 0x5000 8004) bit description

### 12.6.3 SRAM Base address register

The SRAMBASE register must be configured with an address (preferably in on-chip SRAM) where DMA descriptors will be stored. Software must set up the descriptors for those DMA channels that will be used in the application.

| Table 153. SRAM Base address register (SRAMBASE | address 0x5000 8008) bit description |
|-------------------------------------------------|--------------------------------------|
|-------------------------------------------------|--------------------------------------|

| Bit  | Symbol | Description                                                                                                                   | Reset<br>value |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------|----------------|
| 8:0  | -      | Reserved. Read value is undefined, only zero should be written.                                                               | NA             |
| 31:9 | OFFSET | Address bits 31:9 of the beginning of the DMA descriptor table. For 18 channels, the table must begin on a 512 byte boundary. | 0              |

Each DMA channel has an entry for the channel descriptor in the SRAM table. The values for each channel start at the address offsets found in <u>Table 154</u>. Only the descriptors for channels defined at extraction are used. The contents of each channel descriptor are described in <u>Table 146</u>.

Table 154. Channel descriptor map

| Descriptor                            | Table offset |
|---------------------------------------|--------------|
| Channel descriptor for DMA channel 0  | 0x000        |
| Channel descriptor for DMA channel 1  | 0x010        |
| Channel descriptor for DMA channel 2  | 0x020        |
| Channel descriptor for DMA channel 3  | 0x030        |
| Channel descriptor for DMA channel 4  | 0x040        |
| Channel descriptor for DMA channel 5  | 0x050        |
| Channel descriptor for DMA channel 6  | 0x060        |
| Channel descriptor for DMA channel 7  | 0x070        |
| Channel descriptor for DMA channel 8  | 0x080        |
| Channel descriptor for DMA channel 9  | 0x090        |
| Channel descriptor for DMA channel 10 | 0x0A0        |
| Channel descriptor for DMA channel 11 | 0x0B0        |
| Channel descriptor for DMA channel 12 | 0x0C0        |
| Channel descriptor for DMA channel 13 | 0x0D0        |
| Channel descriptor for DMA channel 14 | 0x0E0        |
| Channel descriptor for DMA channel 15 | 0x0F0        |
| Channel descriptor for DMA channel 16 | 0x100        |
| Channel descriptor for DMA channel 17 | 0x110        |

### 12.6.4 Enable read and Set registers

The ENABLESET0 register determines whether each DMA channel is enabled or disabled. Disabling a DMA channel does not reset the channel in any way. A channel can be paused and restarted by clearing, then setting the Enable bit for that channel.

Reading ENABLESET0 provides the current state of all of the DMA channels represented by that register. Writing a 1 to a bit position in ENABLESET0 that corresponds to an implemented DMA channel sets the bit, enabling the related DMA channel. Writing a 0 to any bit has no effect. Enables are cleared by writing to ENABLECLR0.

# Table 155. Enable read and Set register 0 (ENABLESET0, address 0x5000 8020) bit description

|       | 400011 |                                                                        |             |
|-------|--------|------------------------------------------------------------------------|-------------|
| Bit   | Symbol | Description                                                            | Reset value |
| 17:0  | ENA    | Enable for DMA channels 17:0. Bit n enables or disables DMA channel n. | 0           |
|       |        | 0 = disabled.                                                          |             |
|       |        | 1 = enabled.                                                           |             |
| 31:18 | -      | Reserved.                                                              | -           |

## 12.6.5 Enable Clear register

The ENABLECLR0 register is used to clear the channel enable bits in ENABLESET0. This register is write-only.

#### Table 156. Enable Clear register 0 (ENABLECLR0, address 0x5000 8028) bit description

| Bit   | Symbol | Description                                                                                                       | Reset value |
|-------|--------|-------------------------------------------------------------------------------------------------------------------|-------------|
| 17:0  | CLR    | Writing ones to this register clears the corresponding bits in ENABLESET0. Bit n clears the channel enable bit n. | NA          |
| 31:18 | -      | Reserved.                                                                                                         | -           |

### 12.6.6 Active status register

The ACTIVE0 register indicates which DMA channels are active at the point when the read occurs. The register is read-only.

A DMA channel is considered active when a DMA operation has been started but not yet fully completed. The Active status will persist from a DMA operation being started, until the pipeline is empty after end of the last descriptor (when there is no reload). An active channel may be aborted by software by setting the appropriate bit in one of the Abort register (see <u>Section 12.6.15</u>).

#### Table 157. Active status register 0 (ACTIVE0, address 0x5000 8030) bit description

| Bit   | Symbol | Description                                                                                             | Reset<br>value |
|-------|--------|---------------------------------------------------------------------------------------------------------|----------------|
| 17:0  | ACT    | Active flag for DMA channel n. Bit n corresponds to DMA channel<br>n.<br>0 = not active.<br>1 = active. | 0              |
| 31:18 | -      | Reserved.                                                                                               | -              |

#### 12.6.7 Busy status register

The BUSY0 register indicates which DMA channels is busy at the point when the read occurs. This registers is read-only.

A DMA channel is considered busy when there is any operation related to that channel in the DMA controller's internal pipeline. This information can be used after a DMA channel is disabled by software (but still active), allowing confirmation that there are no remaining operations in progress for that channel.

#### Table 158. Busy status register 0 (BUSY0, address 0x5000 8038) bit description

| Bit   | Symbol | Description                                                                       | Reset<br>value |
|-------|--------|-----------------------------------------------------------------------------------|----------------|
| 17:0  | BSY    | Busy flag for DMA channel n. Bit n corresponds to DMA channel n.<br>0 = not busy. | 0              |
|       |        | 1 = busy.                                                                         |                |
| 31:18 | -      | Reserved.                                                                         | -              |

## 12.6.8 Error Interrupt register

The ERRINT0 register contains flags for each DMA channel's Error Interrupt. Any pending interrupt flag in the register will be reflected on the DMA interrupt output.

Reading the registers provides the current state of all DMA channel error interrupts. Writing a 1 to a bit position in ERRINTO that corresponds to an implemented DMA channel clears the bit, removing the interrupt for the related DMA channel. Writing a 0 to any bit has no effect.

| Bit   | Symbol | Description                                                                 | Reset<br>value |
|-------|--------|-----------------------------------------------------------------------------|----------------|
| 17:0  | ERR    | Error Interrupt flag for DMA channel n. Bit n corresponds to DMA channel n. | 0              |
|       |        | 0 = error interrupt is not active.                                          |                |
|       |        | 1 = error interrupt is active.                                              |                |
| 31:18 | -      | Reserved.                                                                   | -              |

Table 159. Error Interrupt register 0 (ERRINT0, address 0x5000 8040) bit description

### 12.6.9 Interrupt Enable read and Set register

The INTENSET0 register controls whether the individual Interrupts for DMA channels contribute to the DMA interrupt output.

Reading the registers provides the current state of all DMA channel interrupt enables. Writing a 1 to a bit position in INTENSET0 that corresponds to an implemented DMA channel sets the bit, enabling the interrupt for the related DMA channel. Writing a 0 to any bit has no effect. Interrupt enables are cleared by writing to INTENCLR0.

# Table 160. Interrupt Enable read and Set register 0 (INTENSET0, address 0x5000 8048) bit description

| Bit   | Symbol | Description                                                                          | Reset value |
|-------|--------|--------------------------------------------------------------------------------------|-------------|
| 17: 0 | INTEN  | Interrupt Enable read and set for DMA channel n. Bit n corresponds to DMA channel n. | 0           |
|       |        | 0 = interrupt for DMA channel is disabled.                                           |             |
|       |        | 1 = interrupt for DMA channel is enabled.                                            |             |
| 31:18 | -      | Reserved.                                                                            | -           |

### 12.6.10 Interrupt Enable Clear register

The INTENCLR0 register is used to clear interrupt enable bits in INTENSET0. The register is write-only.

# Table 161. Interrupt Enable Clear register 0 (INTENCLR0, address 0x5000 8050) bit description

| Bit   | Symbol | Description                                                                                                   | Reset value |
|-------|--------|---------------------------------------------------------------------------------------------------------------|-------------|
| 17:0  | CLR    | Writing ones to this register clears corresponding bits in the INTENSET0. Bit n corresponds to DMA channel n. | NA          |
| 31:18 | -      | Reserved.                                                                                                     | -           |

## 12.6.11 Interrupt A register

The IntA0 register contains the interrupt A status for each DMA channel. The status will be set when the SETINTA bit is 1 in the transfer configuration for a channel, when the descriptor becomes exhausted. Writing a 1 to a bit in these registers clears the related INTA flag. Writing 0 has no effect. Any interrupt pending status in this register will be reflected on the DMA interrupt output if it is enabled in the related INTENSET register.

**Remark:** The error status is not included in this register. The error status is reported in the ERRINT0 status register.

| Bit   | Symbol | Description                                                               | Reset value |
|-------|--------|---------------------------------------------------------------------------|-------------|
| 17:0  | IA     | Interrupt A status for DMA channel n. Bit n corresponds to DMA channel n. | 0           |
|       |        | 0 = the DMA channel interrupt A is not active.                            |             |
|       |        | 1 = the DMA channel interrupt A is active.                                |             |
| 31:18 | -      | Reserved.                                                                 | -           |

#### Table 162. Interrupt A register 0 (INTA0, address 0x5000 8058) bit description

## 12.6.12 Interrupt B register

The INTB0 register contains the interrupt B status for each DMA channel. The status will be set when the SETINTB bit is 1 in the transfer configuration for a channel, when the descriptor becomes exhausted. Writing a 1 to a bit in the register clears the related INTB flag. Writing 0 has no effect. Any interrupt pending status in this register will be reflected on the DMA interrupt output if it is enabled in the INTENSET register.

**Remark:** The error status is not included in this register. The error status is reported in the ERRINTO status register.

| Table 163 | . Interrupt E | 3 register 0 | (INTB0, | address | 0x5000 | 8060) | bit description |
|-----------|---------------|--------------|---------|---------|--------|-------|-----------------|
|-----------|---------------|--------------|---------|---------|--------|-------|-----------------|

| Bit   | Symbol | Description                                                               | Reset value |
|-------|--------|---------------------------------------------------------------------------|-------------|
| 17:0  | IB     | Interrupt B status for DMA channel n. Bit n corresponds to DMA channel n. | 0           |
|       |        | 0 = the DMA channel interrupt B is not active.                            |             |
|       |        | 1 = the DMA channel interrupt B is active.                                |             |
| 31:18 | -      | Reserved.                                                                 | -           |

## 12.6.13 Set Valid register

The SETVALID0 register allows setting the Valid bit in the CTRLSTAT register for one or more DMA channels. See <u>Section 12.6.17</u> for a description of the VALID bit.

The CFGVALID and SV (set valid) bits allow more direct DMA block timing control by software. Each Channel Descriptor, in a sequence of descriptors, can be validated by either the setting of the CFGVALID bit or by setting the channel's SETVALID flag. Normally, the CFGVALID bit is set. This tells the DMA that the Channel Descriptor is active and can be executed. The DMA will continue sequencing through descriptor blocks whose CFGVALID bit are set without further software intervention. Leaving a CFGVALID bit set to 0 allows the DMA sequence to pause at the Descriptor until software triggers the continuation. If, during DMA transmission, a Channel Descriptor is found with CFGVALID

set to 0, the DMA checks for a previously buffered SETVALID0 setting for the channel. If found, the DMA will set the descriptor valid, clear the SV setting, and resume processing the descriptor. Otherwise, the DMA pauses until the channels SETVALID0 bit is set.

Table 164. Set Valid 0 register (SETVALID0, address 0x5000 8068) bit description

| Bit   | Symbol | Description                                                             | Reset value |
|-------|--------|-------------------------------------------------------------------------|-------------|
| 17:0  | SV     | SETVALID control for DMA channel n. Bit n corresponds to DMA channel n. | NA          |
|       |        | 0 = no effect.                                                          |             |
|       |        | 1 = sets the VALIDPENDING control bit for DMA channel n.                |             |
| 31:18 | -      | Reserved.                                                               | -           |

## 12.6.14 Set Trigger register

The SETTRIGO register allows setting the TRIG bit in the CTRLSTAT register for one or more DMA channel. See <u>Section 12.6.17</u> for a description of the TRIG bit, and <u>Section 12.5.1</u> for a general description of triggering.

| Table 165. Set Trigger 0 register (SETTRIG0, address 0x5000 8070) bit description |
|-----------------------------------------------------------------------------------|
|-----------------------------------------------------------------------------------|

| Bit   | Symbol | Description                                                                    | Reset value |
|-------|--------|--------------------------------------------------------------------------------|-------------|
| 17:0  | TRIG   | Set Trigger control bit for DMA channel 0. Bit n corresponds to DMA channel n. | NA          |
|       |        | 0 = no effect.                                                                 |             |
|       |        | 1 = sets the TRIG bit for DMA channel n.                                       |             |
| 31:18 | -      | Reserved.                                                                      | -           |

### 12.6.15 Abort registers

The Abort0 register allows aborting operation of a DMA channel if needed. To abort a selected channel, the channel should first be disabled by clearing the corresponding Enable bit by writing a 1 to the proper bit ENABLECLR. Then wait until the channel is no longer busy by checking the corresponding bit in BUSY. Finally, write a 1 to the proper bit of ABORT. This prevents the channel from restarting an incomplete operation when it is enabled again.

| Bit   | Symbol    | Description                                                          | Reset<br>value |
|-------|-----------|----------------------------------------------------------------------|----------------|
| 17:0  | ABORTCTRL | Abort control for DMA channel 0. Bit n corresponds to DMA channel n. | NA             |
|       |           | 0 = no effect.                                                       |                |
|       |           | 1 = aborts DMA operations on channel n.                              |                |
| 31:18 | -         | Reserved.                                                            | -              |

## 12.6.16 Channel configuration registers

The CFGn register contains various configuration options for DMA channel n.

See Table 168 for a summary of trigger options.

Table 167. Configuration registers for channel 0 to 17 (CFG[0:17], addresses 0x5000 8400 (CFG0) to address 0x50008510 (CFG17)) bit description

| Bit | Symbol      | Value | Description                                                                                                                                                                                                                                                                                 | Reset<br>value |
|-----|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | PERIPHREQEN |       | This bit is reserved for channel 2, 3, 4, 5, and channels 12 to 17 because peripheral request is not available on these channels.                                                                                                                                                           | 0              |
|     |             | 0     | Disabled. Peripheral DMA requests are disabled.                                                                                                                                                                                                                                             |                |
|     |             | 1     | Enabled. Peripheral DMA requests are enabled.                                                                                                                                                                                                                                               |                |
| 1   | HWTRIGEN    |       | Hardware Triggering Enable for this channel.                                                                                                                                                                                                                                                | 0              |
|     |             | 0     | Disabled. Hardware triggering is not used.                                                                                                                                                                                                                                                  |                |
|     |             | 1     | Enabled. Use hardware triggering.                                                                                                                                                                                                                                                           |                |
| 3:2 | -           |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                             | NA             |
| 4   | TRIGPOL     |       | Trigger Polarity. Selects the polarity of a hardware trigger for this channel.                                                                                                                                                                                                              | 0              |
|     |             | 0     | Active low - falling edge. Hardware trigger is active low or falling edge triggered, based on TRIGTYPE.                                                                                                                                                                                     |                |
|     |             | 1     | Active high - rising edge. Hardware trigger is active high or rising edge triggered, based on TRIGTYPE.                                                                                                                                                                                     |                |
| 5   | TRIGTYPE    |       | Trigger Type. Selects hardware trigger as edge triggered or level triggered.                                                                                                                                                                                                                | 0              |
|     |             | 0     | Edge. Hardware trigger is edge triggered. Transfers will be initiated and completed, as specified for a single trigger.                                                                                                                                                                     |                |
|     |             | 1     | Level. Hardware trigger is level triggered. Note that when level triggering without burst (BURSTPOWER = 0) is selected, only hardware triggers should be used on that channel.                                                                                                              |                |
|     |             |       | Transfers continue as long as the trigger level is asserted. Once the trigger is de-asserted, the transfer will be paused until the trigger is, again, asserted. However, the transfer will not be paused until any remaining transfers within the current BURSTPOWER length are completed. |                |
| 6   | TRIGBURST   |       | Trigger Burst. Selects whether hardware triggers cause a single or burst transfer.                                                                                                                                                                                                          | 0              |
|     |             | 0     | Single transfer. Hardware trigger causes a single transfer.                                                                                                                                                                                                                                 |                |
|     |             | 1     | Burst transfer. When the trigger for this channel is set to edge triggered, a hardware trigger causes a burst transfer, as defined by BURSTPOWER.                                                                                                                                           |                |
|     |             |       | When the trigger for this channel is set to level triggered, a hardware trigger causes transfers to continue as long as the trigger is asserted, unless the transfer is complete.                                                                                                           |                |
| 7   | -           |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                             | NA             |

| Bit   | Symbol       | Value | Description                                                                                                                                                                                                                                                                                                                           | Reset<br>value |
|-------|--------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 11:8  | BURSTPOWER   |       | Burst Power is used in two ways. It always selects the address wrap size<br>when SRCBURSTWRAP and/or DSTBURSTWRAP modes are selected<br>(see descriptions elsewhere in this register).                                                                                                                                                | 0              |
|       |              |       | When the TRIGBURST field elsewhere in this register = 1, Burst Power selects how many transfers are performed for each DMA trigger. This can be used, for example, with peripherals that contain a FIFO that can initiate a DMA operation when the FIFO reaches a certain level.                                                      |                |
|       |              |       | 0000: Burst size = 1 ( $2^0$ ).                                                                                                                                                                                                                                                                                                       |                |
|       |              |       | 0001: Burst size = $2(2^1)$ .                                                                                                                                                                                                                                                                                                         |                |
|       |              |       | 0010: Burst size = 4 ( $2^2$ ).                                                                                                                                                                                                                                                                                                       |                |
|       |              |       | <br>1010: Burst size = 1024 ( $2^{10}$ ). This corresponds to the maximum supported transfer count.                                                                                                                                                                                                                                   |                |
|       |              |       | others: not supported.                                                                                                                                                                                                                                                                                                                |                |
|       |              |       | The total transfer length as defined in the XFERCOUNT bits in the XFERCFG register must be an even multiple of the burst size.                                                                                                                                                                                                        |                |
| 13:12 | -            |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                       | NA             |
| 14    | SRCBURSTWRAP |       | Source Burst Wrap. When enabled, the source data address for the DMA is "wrapped", meaning that the source address range for each burst will be the same. As an example, this could be used to read several sequential registers from a peripheral for each DMA burst, reading the same registers again for each burst.               | 0              |
|       |              | 0     | Disabled. Source burst wrapping is not enabled for this DMA channel.                                                                                                                                                                                                                                                                  |                |
|       |              | 1     | Enabled. Source burst wrapping is enabled for this DMA channel.                                                                                                                                                                                                                                                                       |                |
| 15    | DSTBURSTWRAP |       | Destination Burst Wrap. When enabled, the destination data address for the DMA is "wrapped", meaning that the destination address range for each burst will be the same. As an example, this could be used to write several sequential registers to a peripheral for each DMA burst, writing the same registers again for each burst. | 0              |
|       |              | 0     | Disabled. Destination burst wrapping is not enabled for this DMA channel.                                                                                                                                                                                                                                                             |                |
|       |              | 1     | Enabled. Destination burst wrapping is enabled for this DMA channel.                                                                                                                                                                                                                                                                  | 1              |
| 18:16 | CHPRIORITY   |       | Priority of this channel when multiple DMA requests are pending.                                                                                                                                                                                                                                                                      | 0              |
|       |              |       | Eight priority levels are supported.                                                                                                                                                                                                                                                                                                  |                |
|       |              |       | 0x0 = highest priority.                                                                                                                                                                                                                                                                                                               |                |
|       |              |       | 0x7 = lowest priority.                                                                                                                                                                                                                                                                                                                |                |
| 31:19 | -            |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                       | NA             |

# Table 167. Configuration registers for channel 0 to 17 (CFG[0:17], addresses 0x5000 8400 (CFG0) to address 0x50008510 (CFG17)) bit description

| TrigBurst | TrigType | TrigPol | Description                                                                                                                                                                                                        |
|-----------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | 0        | 0       | Hardware DMA trigger is falling edge sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap.                                                                    |
| 0         | 0        | 1       | Hardware DMA trigger is rising edge sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap.                                                                     |
| 0         | 1        | 0       | Hardware DMA trigger is low level sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap.                                                                       |
| 0         | 1        | 1       | Hardware DMA trigger is high level sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap.                                                                      |
| 1         | 0        | 0       | Hardware DMA trigger is falling edge sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap, and also determines how much data is transferred for each trigger. |
| 1         | 0        | 1       | Hardware DMA trigger is rising edge sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap, and also determines how much data is transferred for each trigger.  |
| 1         | 1        | 0       | Hardware DMA trigger is low level sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap, and also determines how much data is transferred for each trigger.    |
| 1         | 1        | 1       | Hardware DMA trigger is high level sensitive. The BURSTPOWER field controls address wrapping if enabled via SrcBurstWrap and/or DstBurstWrap, and also determines how much data is transferred for each trigger.   |

#### Table 168. Trigger setting summary

## 12.6.17 Channel control and status registers

The CTLSTATn register provides status flags specific to DMA channel n.

# Table 169. Control and Status registers for channel 0 to 17 (CTLSTAT[0:17], 0x5000 8404 (CTLSTAT0) to address 0x5000 8514 (CTLSTAT17)) bit description

| Bit  | Symbol       | Value | Description                                                                                                                                                                | Reset<br>value |
|------|--------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | VALIDPENDING |       | Valid pending flag for this channel. This bit is set when a 1 is written to the corresponding bit in the related SETVALID register when CFGVALID = 1 for the same channel. | 0              |
|      |              | 0     | No effect on DMA operation.                                                                                                                                                |                |
|      |              | 1     | Valid pending.                                                                                                                                                             |                |
| 1    | -            |       | Reserved. Read value is undefined, only zero should be written.                                                                                                            | NA             |
| 2    | TRIG         |       | Trigger flag. Indicates that the trigger for this channel is currently set. This bit is cleared at the end of an entire transfer or upon reload when $CLRTRIG = 1$ .       | 0              |
|      |              | 0     | Not triggered. The trigger for this DMA channel is not set. DMA operations will not be carried out.                                                                        |                |
|      |              | 1     | Triggered. The trigger for this DMA channel is set. DMA operations will be carried out.                                                                                    |                |
| 31:3 | -            |       | Reserved. Read value is undefined, only zero should be written.                                                                                                            | NA             |

## 12.6.18 Channel transfer configuration registers

The XFERCFGn register contains transfer related configuration information for DMA channel n. Using the Reload bit, this register can optionally be automatically reloaded when the current settings are exhausted (the full transfer count has been completed), allowing linked transfers with more than one descriptor to be performed.

See Section 12.7.1 "Trigger operation" for details on trigger operation.

# Table 170. Transfer Configuration registers for channel 0 to 17 (XFERCFG[0:17], addresses 0x5000 8408 (XFERCFG0) to 0x5000 8518 (XFERCFG17)) bit description

| Bit | Symbol   | Value | Description                                                                                                                                                                                                                                                  | Reset<br>Value |
|-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | CFGVALID |       | Configuration Valid flag. This bit indicates whether the current channel descriptor is valid and can potentially be acted upon, if all other activation criteria are fulfilled.                                                                              | 0              |
|     |          | 0     | Not valid. The channel descriptor is not considered valid until validated by an associated SETVALID0 setting.                                                                                                                                                |                |
|     |          | 1     | Valid. The current channel descriptor is considered valid.                                                                                                                                                                                                   |                |
| 1   | RELOAD   |       | Indicates whether the channel's control structure will be reloaded when the current descriptor is exhausted. Reloading allows ping-pong and linked transfers.                                                                                                | 0              |
|     |          | 0     | Disabled. Do not reload the channels' control structure when the current descriptor is exhausted.                                                                                                                                                            |                |
|     |          | 1     | Enabled. Reload the channels' control structure when the current descriptor is exhausted.                                                                                                                                                                    |                |
| 2   | SWTRIG   |       | Software Trigger.                                                                                                                                                                                                                                            | 0              |
|     |          | 0     | When written by software, the trigger for this channel is not set. A new trigger, as defined by the HWTRIGEN, TRIGPOL, and TRIGTYPE will be needed to start the channel.                                                                                     |                |
|     |          | 1     | When written by software, the trigger for this channel is set immediately. This feature should not be used with level triggering when TRIGBURST = 0.                                                                                                         |                |
| 3   | CLRTRIG  |       | Clear Trigger.                                                                                                                                                                                                                                               | 0              |
|     |          | 0     | Not cleared. The trigger is not cleared when this descriptor is exhausted. If there is a reload, the next descriptor will be started.                                                                                                                        |                |
|     |          | 1     | Cleared. The trigger is cleared when this descriptor is exhausted.                                                                                                                                                                                           |                |
| 4   | SETINTA  |       | Set Interrupt flag A for this channel. There is no hardware distinction between interrupt A and B. They can be used by software to assist with more complex descriptor usage. By convention, interrupt A may be used when only one interrupt flag is needed. | 0              |
|     |          | 0     | No effect.                                                                                                                                                                                                                                                   |                |
|     |          | 1     | Set. The INTA flag for this channel will be set when the current descriptor is exhausted.                                                                                                                                                                    |                |
| 5   | SETINTB  |       | Set Interrupt flag B for this channel. There is no hardware distinction between interrupt A and B. They can be used by software to assist with more complex descriptor usage. By convention, interrupt A may be used when only one interrupt flag is needed. | 0              |
|     |          | 0     | No effect.                                                                                                                                                                                                                                                   | 1              |
|     |          | 1     | Set. The INTB flag for this channel will be set when the current descriptor is exhausted.                                                                                                                                                                    |                |
| 7:6 | -        |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                              | NA             |

# Table 170. Transfer Configuration registers for channel 0 to 17 (XFERCFG[0:17], addresses 0x5000 8408 (XFERCFG0) to 0x5000 8518 (XFERCFG17)) bit description

| Bit   | Symbol    | Value | Description                                                                                                                                                                                                | Reset<br>Value |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 9:8   | WIDTH     |       | Transfer width used for this DMA channel.                                                                                                                                                                  | 0              |
|       |           | 0x0   | 8-bit transfers are performed (8-bit source reads and destination writes).                                                                                                                                 | -              |
|       |           | 0x1   | 16-bit transfers are performed (16-bit source reads and destination writes).                                                                                                                               | -              |
|       |           | 0x2   | 32-bit transfers are performed (32-bit source reads and destination writes).                                                                                                                               |                |
|       |           | 0x3   | Reserved setting, do not use.                                                                                                                                                                              |                |
| 11:10 | -         |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                            | NA             |
| 13:12 | SRCINC    |       | Determines whether the source address is incremented for each DMA transfer.                                                                                                                                | 0              |
|       |           | 0x0   | No increment. The source address is not incremented for each transfer. This is the usual case when the source is a peripheral device.                                                                      |                |
|       |           | 0x1   | 1 x width. The source address is incremented by the amount specified by Width for each transfer. This is the usual case when the source is memory.                                                         |                |
|       |           | 0x2   | 2 x width. The source address is incremented by 2 times the amount specified by Width for each transfer.                                                                                                   |                |
|       |           | 0x3   | 4 x width. The source address is incremented by 4 times the amount specified by Width for each transfer.                                                                                                   |                |
| 15:14 | DSTINC    |       | Determines whether the destination address is incremented for each DMA transfer.                                                                                                                           | 0              |
|       |           | 0x0   | No increment. The destination address is not incremented for each transfer. This is the usual case when the destination is a peripheral device.                                                            |                |
|       |           | 0x1   | 1 x width. The destination address is incremented by the amount specified by Width for each transfer. This is the usual case when the destination is memory.                                               |                |
|       |           | 0x2   | 2 x width. The destination address is incremented by 2 times the amount specified by Width for each transfer.                                                                                              |                |
|       |           | 0x3   | 4 x width. The destination address is incremented by 4 times the amount specified by Width for each transfer.                                                                                              | -              |
| 25:16 | XFERCOUNT |       | Total number of transfers to be performed, minus 1 encoded. The number of bytes transferred is: (XFERCOUNT + 1) x data width (as defined by the WIDTH field).                                              | 0              |
|       |           |       | <b>Remark:</b> The DMA controller uses this bit field during transfer to count down.<br>Hence, it cannot be used by software to read back the size of the transfer, for instance, in an interrupt handler. |                |
|       |           |       | 0x0 = a total of 1 transfer will be performed.                                                                                                                                                             |                |
|       |           |       | 0x1 = a total of 2 transfers will be performed.                                                                                                                                                            |                |
|       |           |       |                                                                                                                                                                                                            |                |
|       |           |       | 0x3FF = a total of 1,024 transfers will be performed.                                                                                                                                                      |                |
| 31:26 | -         |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                            | NA             |

# **12.7 Functional description**

# 12.7.1 Trigger operation

A trigger of some kind is always needed to start a transfer on a DMA channel. This can be a hardware or software trigger, and can be used in several ways. If a channel is configured with the SWTRIG bit equal to 0, the channel can be later triggered either by hardware or software. Software triggering is accomplished by writing a 1 to the appropriate bit in the SETTRIG register. Hardware triggering requires setup of the HWTRIGEN, TRIGPOL, TRIGTYPE, and TRIGBURST fields in the CFG register for the related channel. When a channel is initially set up, the SWTRIG bit in the XFERCFG register can be set, causing the transfer to begin immediately.

Once triggered, transfer on a channel will be paced by DMA requests if the PERIPHREQEN bit in the related CFG register is set. Otherwise, the transfer will proceed at full speed.

The TRIG bit in the CTLSTAT register can be cleared at the end of a transfer, determined by the value CLRTRIG (bit 0) in the XFERCFG register. When a 1 is found in CLRTRIG, the trigger is cleared when the descriptor is exhausted.

UM11021

# **UM11021**

Chapter 13: LPC83x USART0

Rev. 1.1 — 5 October 2016

**User manual** 

# 13.1 How to read this chapter

One USART is available on all parts depending on the switch matrix configuration.

# 13.2 Features

- 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 transceiver output enable.
- Parity generation and checking: odd, even, or none.
- Software selectable oversampling from 5 to 16 clocks in asynchronous mode.
- 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 with autobaud function.
- A fractional rate divider.
- 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.
- Loopback mode for testing of data and flow control.
- USART transmit and receive functions can operated with the system DMA controller.

# **13.3 Basic configuration**

Configure the USARTs for receiving and transmitting data:

- In the SYSAHBCLKCTRL register, set bit 3 to 5 (<u>Table 33</u>) to enable the clock to the register interface.
- Clear the USART peripheral resets using the PRESETCTRL register (Table 21).
- Enable or disable the USART interrupt in slots #3 in the NVIC. See <u>Table 4</u>.
- Configure the USART pin functions through the switch matrix.
- Configure the USART clock and baud rate. See <u>Section 13.3.1</u>.
- Send and receive lines are connected to DMA request lines. See <u>Table 145</u>.

For wake-up from deep-sleep and power-down modes the USART must be configured in synchronous mode. See <u>Section 13.3.2</u> for details.

## 13.3.1 Configure the USART clock and baud rate

The USART uses a peripheral clock (U\_PCLK) and, if needed, a fractional baud rate generator. The peripheral clock and the fractional divider for the baud rate calculation are set up in the SYSCON block as follows (see Figure 19):

 Configure the UART clock by writing a value FRGCLKDIV > 0 in the common USART fractional baud rate divider register. This is the divided main clock common to the USART.

Table 34 "USART clock divider register (UARTCLKDIV, address 0x4004 8094) bit description"

 If a fractional value is needed to obtain a particular baud rate, program the fractional divider. The fractional divider value is the fraction of MULT/DIV. The MULT and DIV values are programmed in the FRGCTRL register. The DIV value must be programmed with the fixed value of 256.

U\_PCLK = FRGCLKDIV/(1+(MULT/DIV))

The following rules apply for MULT and DIV:

- Always set DIV to 256 by programming the FRGCTRL register with the value of 0xFF.
- Set the MULT to any value between 0 and 255.

Table 38 "USART fractional generator divider value register (UARTFRGDIV, address 0x4004 80F0) bit description"

 In asynchronous mode: Configure the baud rate divider BRGVAL in the USART BRG register. The baud rate divider divides the USART peripheral clock by a factor of 16 multiplied by the baud rate value to provide the baud rate = U\_PCLK/16 x BRGVAL.

Section 13.6.9 "USART Baud Rate Generator register"

4. In synchronous mode: The serial clock is Un\_SCLK = U\_PCLK/BRGVAL.

#### Chapter 13: LPC83x USART0



For details on the clock configuration see:

Section 13.7.1 "Clocking and baud rates"

#### 13.3.2 Configure the USART for wake-up

The USART can wake up the system from sleep mode in asynchronous or synchronous mode on any enabled USART interrupt.

In Deep-sleep or power-down mode, you have two options for configuring USART for wake-up:

• If the USART is configured for synchronous slave mode, the USART block can create an interrupt on a received signal even when the USART block receives no clocks from the ARM core - that is in Deep-sleep or Power-down mode.

As long as the USART receives a clock signal from the master, it can receive up to one byte in the RXDAT register while in Deep-sleep or Power-down mode. Any interrupt raised as part of the receive data process can then wake up the part.

#### 13.3.2.1 Wake-up from Sleep mode

- Configure the USART in either asynchronous mode or synchronous mode. See <u>Table 173</u>.
- Enable the USART interrupt in the NVIC.
- Any USART interrupt wakes up the part from sleep mode. Enable the USART interrupt in the INTENSET register (Table 176).

#### 13.3.2.2 Wake-up from Deep-sleep or Power-down mode

- Configure the USART in synchronous slave mode. See <u>Table 173</u>. You must connect the SCLK function to a pin and connect the pin to the master.
- Enable the USART wake-up in the STARTERP1 register. See <u>Table 49 "Start logic 1</u> <u>interrupt wake-up enable register (STARTERP1, address 0x4004 8214) bit</u> description".
- Enable the USART interrupt in the NVIC.
- In the PDAWAKE register, configure all peripherals that need to be running when the part wakes up.
- The USART wakes up the part from Deep-sleep or Power-down mode on all events that cause an interrupt and are also enabled in the INTENSET register. Typical wake-up events are:
  - A start bit has been received.
  - The RXDAT buffer has received a byte.
  - Data is ready to be transmitted in the TXDAT buffer and a serial clock from the master has been received.
  - A change in the state of the CTS pin if the CTS function is connected and the DELTACTS interrupt is enabled. This event wakes up the part without the synchronous UART clock running.

**Remark:** By enabling or disabling the interrupt in the INTENSET register (<u>Table 176</u>), you can customize when the wake-up occurs in the USART receive/transmit protocol.

# **13.4 Pin description**

| Function | I/O | Туре               | Connect<br>to | Use register | Reference       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|----------|-----|--------------------|---------------|--------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| U0_TXD   | 0   | external<br>to pin | any pin       | PINASSIGN0   | <u>Table 65</u> | Transmitter output for USART0. Serial transmit data.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| U0_RXD   | I   | external<br>to pin | any pin       | PINASSIGN0   | Table 65        | Receiver input for USART0.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| U0_RTS   | 0   | external<br>to pin | any pin       | PINASSIGNO   | Table 65        | Request To Send output for USART0. This signal<br>supports inter-processor communication through the<br>use of hardware flow control. This feature is active<br>when the USART RTS signal is configured to appear<br>on a device pin.                                                                                                                                                                                                                                  |  |  |
| UO_CTS   | I   | external<br>to pin | any pin       | PINASSIGN0   | Table 65        | Clear To Send input for USART0. Active low signal<br>indicates that the external device that is in<br>communication with the USART is ready to accept<br>data. This feature is active when enabled by the<br>CTSEn bit in CFG register and when configured to<br>appear on a device pin. When de-asserted (high) by<br>the external device, the USART will complete<br>transmitting any character already in progress, then<br>stop until CTS is again asserted (low). |  |  |
| U0_SCLK  | I/O | external<br>to pin | any pin       | PINASSIGN1   | Table 66        | Serial clock input/output for USART0 n synchronous mode.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |

#### Table 171. USART pin description

**User manual** 

### **13.5 General description**

The USART receiver block monitors the serial input line, Un\_RXD, for valid input. The receiver shift register assembles characters as they are received, after which they are passed to the receiver buffer register to await access by the CPU or the DMA controller.

When RTS signal is configured as an RS-485 output enable, it is asserted at the beginning of an transmitted character, and de-asserted either at the end of the character, or after a one character delay (selected by software).

The USART transmitter block accepts data written by the CPU or DMA controllers and buffers the data in the transmit holding register. When the transmitter is available, the transmit shift register takes that data, formats it, and serializes it to the serial output, Un\_TXD.

The Baud Rate Generator block divides the incoming clock to create a 16x baud rate clock in the standard asynchronous operating mode. The BRG clock input source is the shared Fractional Rate Generator that runs from the common USART peripheral clock U\_PCLK).

In synchronous slave mode, data is transmitted and received using the serial clock directly. In synchronous master mode, data is transmitted and received using the baud rate clock without division.

Status information from the transmitter and receiver is saved and provided via the Stat register. Many of the status flags are able to generate interrupts, as selected by software.

**Remark:** The fractional value and the USART peripheral clock are shared between all USARTs.

### Chapter 13: LPC83x USART0

**UM11021** 



**User manual** 

# **13.6 Register description**

The reset value reflects the data stored in used bits only. It does not include the content of reserved bits.

| Name       | Access | Offset | Description                                                                                                                                                                                                                                     | Reset<br>value | Reference        |
|------------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| CFG I      | R/W    | 0x000  | USART Configuration register. Basic USART configuration settings that typically are not changed during operation.                                                                                                                               | 0              | Table 173        |
| CTL I      | R/W    | 0x004  | USART Control register. USART control settings that are more likely to change during operation.                                                                                                                                                 | 0              | <u>Table 174</u> |
| STAT       | R/W    | 0x008  | USART Status register. The complete status value can be read here. Writing ones clears some bits in the register. Some bits can be cleared by writing a 1 to them.                                                                              | 0x000E         | <u>Table 175</u> |
| INTENSET I | R/W    | 0x00C  | Interrupt Enable read and Set register. Contains an individual interrupt enable bit for each potential USART interrupt. A complete value may be read from this register. Writing a 1 to any implemented bit position causes that bit to be set. | 0              | Table 176        |
| INTENCLR   | W      | 0x010  | Interrupt Enable Clear register. Allows clearing any combination of bits in the INTENSET register. Writing a 1 to any implemented bit position causes the corresponding bit to be cleared.                                                      | -              | <u>Table 177</u> |
| RXDAT I    | R      | 0x014  | Receiver Data register. Contains the last character received.                                                                                                                                                                                   | -              | Table 178        |
| RXDATSTAT  | R      | 0x018  | Receiver Data with Status register. Combines the last<br>character received with the current USART receive status.<br>Allows DMA or software to recover incoming data and status<br>together.                                                   | -              | <u>Table 179</u> |
| TXDAT I    | R/W    | 0x01C  | Transmit Data register. Data to be transmitted is written here.                                                                                                                                                                                 | 0              | <u>Table 180</u> |
| BRG I      | R/W    | 0x020  | Baud Rate Generator register. 16-bit integer baud rate divisor value.                                                                                                                                                                           | 0              | Table 181        |
| INTSTAT    | R      | 0x024  | Interrupt status register. Reflects interrupts that are currently enabled.                                                                                                                                                                      | 0x0005         | Table 182        |
| OSR I      | R/W    | 0x028  | Oversample selection register for asynchronous communication.                                                                                                                                                                                   | 0xF            | Table 183        |
| ADDR I     | R/W    | 0x02C  | Address register for automatic address matching.                                                                                                                                                                                                | 0              | Table 184        |

### 13.6.1 USART Configuration register

The CFG register contains communication and mode settings for aspects of the USART that would normally be configured once in an application.

**Remark:** If software needs to change configuration values, the following sequence should be used: 1) Make sure the USART is not currently sending or receiving data. 2) Disable the USART by writing a 0 to the Enable bit (0 may be written to the entire register). 3) Write the new configuration value, with the ENABLE bit set to 1.

| Bit | Symbol    | Value                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset<br>Value |  |  |  |
|-----|-----------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|
| 0   | ENABLE    |                                               | USART Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0              |  |  |  |
|     |           | 0                                             | Disabled. The USART is disabled and the internal state<br>machine and counters are reset. While Enable = 0, all<br>USART interrupts and DMA transfers are disabled. When<br>Enable is set again, CFG and most other control bits remain<br>unchanged. For instance, when re-enabled, the USART will<br>immediately generate a TXRDY interrupt (if enabled in the<br>INTENSET register) or a DMA transfer request because the<br>transmitter has been reset and is therefore available. |                |  |  |  |
|     |           | 1                                             | Enabled. The USART is enabled for operation.                                                                                                                                                                                                                                                                                                                                                                                                                                           |                |  |  |  |
| 1   | -         |                                               | Reserved. Read value is undefined, only zero should be vritten.                                                                                                                                                                                                                                                                                                                                                                                                                        |                |  |  |  |
| 3:2 | DATALEN   |                                               | Selects the data size for the USART.                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 00             |  |  |  |
|     |           | 0x0                                           | 7 bit Data length.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                |  |  |  |
|     |           | 0x1                                           | 8 bit Data length.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                |  |  |  |
|     |           | 0x2                                           | 9 bit data length. The 9th bit is commonly used for addressing in multidrop mode. See the ADDRDET bit in the CTL register.                                                                                                                                                                                                                                                                                                                                                             |                |  |  |  |
|     |           | 0x3                                           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1              |  |  |  |
| 5:4 | PARITYSEL |                                               | Selects what type of parity is used by the USART.                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00             |  |  |  |
|     |           | 0x0                                           | No parity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |  |
|     |           | 0x1                                           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |  |  |  |
|     |           | number of 1s in a transmitted character is ev | Even parity. Adds a bit to each character such that the number of 1s in a transmitted character is even, and the number of 1s in a received character is expected to be even.                                                                                                                                                                                                                                                                                                          |                |  |  |  |
|     |           | 0x3                                           | Odd parity. Adds a bit to each character such that the number of 1s in a transmitted character is odd, and the number of 1s in a received character is expected to be odd.                                                                                                                                                                                                                                                                                                             |                |  |  |  |
| 6   | STOPLEN   |                                               | Number of stop bits appended to transmitted data. Only a single stop bit is required for received data.                                                                                                                                                                                                                                                                                                                                                                                | 0              |  |  |  |
|     |           | 0 1 stop bit.                                 | 1 stop bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                |  |  |  |
|     |           | 1                                             | 2 stop bits. This setting should only be used for asynchronous communication.                                                                                                                                                                                                                                                                                                                                                                                                          |                |  |  |  |
| 8:7 | -         |                                               | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                                                        | NA             |  |  |  |

Table 173. USART Configuration register (CFG, address 0x4006 4000 (USART0) bit description

| Table 173. USART Configuration register (CFG, address 0x4006 4000 (USART0) bit |  |
|--------------------------------------------------------------------------------|--|
| description continued                                                          |  |

| Bit   | Symbol  | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset<br>Value |  |  |
|-------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| 9     | CTSEN   |       | CTS Enable. Determines whether CTS is used for flow control. CTS can be from the input pin, or from the USART's own RTS if loopback mode is enabled.                                                                                                                                                                                                                                                                                                       | 0              |  |  |
|       |         | 0     | No flow control. The transmitter does not receive any automatic flow control signal.                                                                                                                                                                                                                                                                                                                                                                       |                |  |  |
|       |         | 1     | Flow control enabled. The transmitter uses the CTS input (or RTS output in loopback mode) for flow control purposes.                                                                                                                                                                                                                                                                                                                                       |                |  |  |
| 10    | -       |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                            |                |  |  |
| 11    | SYNCEN  |       | Selects synchronous or asynchronous operation.                                                                                                                                                                                                                                                                                                                                                                                                             | 0              |  |  |
|       |         | 0     | Asynchronous mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |
|       |         | 1     | Synchronous mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                                              |                |  |  |
| 12    | CLKPOL  |       | Selects the clock polarity and sampling edge of received data in synchronous mode.                                                                                                                                                                                                                                                                                                                                                                         | 0              |  |  |
|       |         | 0     | Falling edge. Un_RXD is sampled on the falling edge of SCLK.                                                                                                                                                                                                                                                                                                                                                                                               |                |  |  |
|       |         | 1     | Rising edge. Un_RXD is sampled on the rising edge of SCLK.                                                                                                                                                                                                                                                                                                                                                                                                 |                |  |  |
| 13    | -       |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                            |                |  |  |
| 14    | SYNCMST |       | Synchronous mode Master select.                                                                                                                                                                                                                                                                                                                                                                                                                            | 0              |  |  |
|       |         |       | Slave. When synchronous mode is enabled, the USART is a slave.                                                                                                                                                                                                                                                                                                                                                                                             |                |  |  |
|       |         | 1     | Master. When synchronous mode is enabled, the USART is a master.                                                                                                                                                                                                                                                                                                                                                                                           |                |  |  |
| 15    | LOOP    |       | Selects data loopback mode.                                                                                                                                                                                                                                                                                                                                                                                                                                | 0              |  |  |
|       |         | 0     | Normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                          |                |  |  |
|       |         | 1     | Loopback mode. This provides a mechanism to perform<br>diagnostic loopback testing for USART data. Serial data<br>from the transmitter (Un_TXD) is connected internally to<br>serial input of the receive (Un_RXD). Un_TXD and Un_RTS<br>activity will also appear on external pins if these functions<br>are configured to appear on device pins. The receiver RTS<br>signal is also looped back to CTS and performs flow control<br>if enabled by CTSEN. |                |  |  |
| 17:16 | -       |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                            | NA             |  |  |
| 18    | OETA    |       | Output Enable Turnaround time enable for RS-485 operation.                                                                                                                                                                                                                                                                                                                                                                                                 | 0              |  |  |
|       |         | 0     | De-asserted. If selected by OESEL, the Output Enable signal de-asserted at the end of the last stop bit of a transmission.                                                                                                                                                                                                                                                                                                                                 |                |  |  |
|       |         | 1     | Asserted. If selected by OESEL, the Output Enable signal remains asserted for 1 character time after then end the last stop bit of a transmission. OE will also remain asserted if another transmit begins before it is de-asserted.                                                                                                                                                                                                                       |                |  |  |

User manual

© NXP Semiconductors N.V. 2016. All rights reserved.

| Bit   | Symbol   | Value | Description                                                                                                                                                                                    | Reset<br>Value |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 19    | AUTOADDR |       | Automatic Address matching enable.                                                                                                                                                             | 0              |
|       |          | 0     | Disabled. When addressing is enabled by ADDRDET,<br>address matching is done by software. This provides the<br>possibility of versatile addressing (e.g. respond to more than<br>one address). | -              |
|       |          | 1     | Enabled. When addressing is enabled by ADDRDET,<br>address matching is done by hardware, using the value in<br>the ADDR register as the address to match.                                      |                |
| 20    | OESEL    |       | Output Enable Select.                                                                                                                                                                          | 0              |
|       |          | 0     | Flow control. The RTS signal is used as the standard flow control function.                                                                                                                    |                |
|       |          | 1     | Output enable. The RTS signal is taken over in order to provide an output enable signal to control an RS-485 transceiver.                                                                      |                |
| 21    | OEPOL    |       | Output Enable Polarity.                                                                                                                                                                        | 0              |
|       |          | 0     | Low. If selected by OESEL, the output enable is active low.                                                                                                                                    |                |
|       |          | 1     | High. If selected by OESEL, the output enable is active high.                                                                                                                                  |                |
| 22    | RXPOL    |       | Receive data polarity.                                                                                                                                                                         | 0              |
|       |          | 0     | Not changed. The RX signal is used as it arrives from the pin. This means that the RX rest value is 1, start bit is 0, data is not inverted, and the stop bit is 1.                            |                |
|       |          | 1     | Inverted. The RX signal is inverted before being used by the UART. This means that the RX rest value is 0, start bit is 1, data is inverted, and the stop bit is 0.                            | -              |
| 23    | TXPOL    |       | Transmit data polarity.                                                                                                                                                                        | 0              |
|       |          | 0     | Not changed. The TX signal is sent out without change. This means that the TX rest value is 1, start bit is 0, data is not inverted, and the stop bit is 1.                                    |                |
|       |          | 1     | Inverted. The TX signal is inverted by the UART before<br>being sent out. This means that the TX rest value is 0, start<br>bit is 1, data is inverted, and the stop bit is 0.                  |                |
| 31:24 | -        |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                | NA             |

# Table 173. USART Configuration register (CFG, address 0x4006 4000 (USART0) bit description ...continued

### 13.6.2 USART Control register

The CTL register controls aspects of USART operation that are more likely to change during operation.

| I | Bit | Symbol | Value |                                                                 | Reset<br>value |
|---|-----|--------|-------|-----------------------------------------------------------------|----------------|
| ( | 0   | -      |       | Reserved. Read value is undefined, only zero should be written. | NA             |

# UM11021

#### Chapter 13: LPC83x USART0

| Bit   | Symbol    | Value                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   | Rese<br>value |  |
|-------|-----------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--|
| 1     | TXBRKEN   |                                                                 | Break Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0             |  |
|       |           | 0                                                               | Normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                             |               |  |
|       |           | 1                                                               | Continuous break is sent immediately when this bit is set, and remains until this bit is cleared.                                                                                                                                                                                                                                                                                                                                             | _             |  |
|       |           |                                                                 | A break may be sent without danger of corrupting any<br>currently transmitting character if the transmitter is first<br>disabled (TXDIS in CTL is set) and then waiting for the<br>transmitter to be disabled (TXDISINT in STAT = 1) before<br>writing 1 to TXBRKEN.                                                                                                                                                                          |               |  |
| 2     | ADDRDET   |                                                                 | Enable address detect mode.                                                                                                                                                                                                                                                                                                                                                                                                                   | 0             |  |
|       |           | 0                                                               | Disabled. The USART presents all incoming data.                                                                                                                                                                                                                                                                                                                                                                                               |               |  |
|       |           | 1                                                               | Enabled. The USART receiver ignores incoming data that does not have the most significant bit of the data (typically the 9th bit) = 1. When the data MSB bit = 1, the receiver treats the incoming data normally, generating a received data interrupt. Software can then check the data to see if this is an address that should be handled. If it is, the ADDRDET bit is cleared by software and further incoming data is handled normally. |               |  |
| 5:3   | -         | Reserved. Read value is undefined, only zero should be written. |                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |  |
| 6     | TXDIS     |                                                                 | Transmit Disable.                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             |  |
|       |           | 0                                                               | Not disabled. USART transmitter is not disabled.                                                                                                                                                                                                                                                                                                                                                                                              |               |  |
|       |           | 1                                                               | Disabled. USART transmitter is disabled after any character currently being transmitted is complete. This feature can be used to facilitate software flow control.                                                                                                                                                                                                                                                                            |               |  |
| 7     | -         |                                                                 | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                               | NA            |  |
| 8     | CC        |                                                                 | Continuous Clock generation. By default, SCLK is only output while data is being transmitted in synchronous mode.                                                                                                                                                                                                                                                                                                                             | 0             |  |
|       |           | 0                                                               | Clock on character. In synchronous mode, SCLK cycles<br>only when characters are being sent on Un_TXD or to<br>complete a character that is being received.                                                                                                                                                                                                                                                                                   |               |  |
|       |           | 1                                                               | Continuous clock. SCLK runs continuously in synchronous mode, allowing characters to be received on Un_RxD independently from transmission on Un_TXD).                                                                                                                                                                                                                                                                                        |               |  |
| 9     | CLRCCONRX |                                                                 | Clear Continuous Clock.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0             |  |
|       |           | 0                                                               | No effect on the CC bit.                                                                                                                                                                                                                                                                                                                                                                                                                      | 1             |  |
|       |           | 1                                                               | Auto-clear. The CC bit is automatically cleared when a complete character has been received. This bit is cleared at the same time.                                                                                                                                                                                                                                                                                                            |               |  |
| 15:10 | -         |                                                                 | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                               | NA            |  |
|       |           |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |  |

#### Table 174. USART Control register (CTL, address 0x4006 4004 (USART0) bit description

#### Chapter 13: LPC83x USART0

| Bit   | Symbol   | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset<br>value |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 16    | AUTOBAUD |       | Autobaud enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0              |
|       |          | 0     | Disabled. UART is in normal operating mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                |
|       |          | 1     | Enabled. UART is in autobaud mode. This bit should only<br>be set when the UART is enabled in the CFG register and<br>the UART receiver is idle. The first start bit of RX is<br>measured and used the update the BRG register to match<br>the received data rate. AUTOBAUD is cleared once this<br>process is complete, or if there is an ABERR. This bit can<br>be cleared by software when set, but only when the UART<br>receiver is idle. Disabling the UART in the CFG register<br>also clears the AUTOBAUD bit. |                |
| 31:17 | -        |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NA             |

#### Table 174. USART Control register (CTL, address 0x4006 4004 (USART0) bit description

#### 13.6.3 USART Status register

The STAT register primarily provides a complete set of USART status flags for software to read. Flags other than read-only flags may be cleared by writing ones to corresponding bits of STAT. Interrupt status flags that are read-only and cannot be cleared by software, can be masked using the INTENCLR register (see <u>Table 177</u>).

The error flags for received noise, parity error, framing error, and overrun are set immediately upon detection and remain set until cleared by software action in STAT.

| Table 175. | USART Status | register (STAT  | address 0x4006 4008  | (USARTO  | ) bit description |
|------------|--------------|-----------------|----------------------|----------|-------------------|
|            | OUANT OLULUS | register (OTA), | uuui 033 074000 4000 | (OOAILIO |                   |

| Bit | Symbol    | Description                                                                                                                                                                                                                                                                                    | Reset<br>value | Access<br>[1] |
|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------|
| 0   | RXRDY     | Receiver Ready flag. When 1, indicates that data is available to be read from the receiver buffer. Cleared after a read of the RXDAT or RXDATSTAT registers.                                                                                                                                   | 0              | RO            |
| 1   | RXIDLE    | Receiver Idle. When 0, indicates that the receiver is currently in the process of receiving data. When 1, indicates that the receiver is not currently in the process of receiving data.                                                                                                       | 1              | RO            |
| 2   | TXRDY     | Transmitter Ready flag. When 1, this bit indicates that data may be written to the transmit buffer. Previous data may still be in the process of being transmitted. Cleared when data is written to TXDAT. Set when the data is moved from the transmit buffer to the transmit shift register. | 1              | RO            |
| 3   | TXIDLE    | Transmitter Idle. When 0, indicates that the transmitter is currently in the process of sending data. When 1, indicate that the transmitter is not currently in the process of sending data.                                                                                                   | 1              | RO            |
| 4   | CTS       | This bit reflects the current state of the CTS signal, regardless of the setting of the CTSEN bit in the CFG register. This will be the value of the CTS input pin unless loopback mode is enabled.                                                                                            | NA             | RO            |
| 5   | DELTACTS  | This bit is set when a change in the state is detected for the CTS flag above.<br>This bit is cleared by software.                                                                                                                                                                             | 0              | W1            |
| 6   | TXDISSTAT | Transmitter Disabled Interrupt flag. When 1, this bit indicates that the USART transmitter is fully idle after being disabled via the TXDIS in the CTL register (TXDIS = 1).                                                                                                                   | 0              | RO            |

| Bit   | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                                | Reset<br>value | Access<br>[1] |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------|
| 7     | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                            | NA             | NA            |
| 8     | OVERRUNINT   | Overrun Error interrupt flag. This flag is set when a new character is received while the receiver buffer is still in use. If this occurs, the newly received character in the shift register is lost.                                                                                                                                                                                                                     | 0              | W1            |
| 9     | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                            | NA             | NA            |
| 10    | RXBRK        | Received Break. This bit reflects the current state of the receiver break detection logic. It is set when the Un_RXD pin remains low for 16 bit times. Note that FRAMERRINT will also be set when this condition occurs because the stop bit(s) for the character would be missing. RXBRK is cleared when the Un_RXD pin goes high.                                                                                        | 0              | RO            |
| 11    | DELTARXBRK   | This bit is set when a change in the state of receiver break detection occurs.<br>Cleared by software.                                                                                                                                                                                                                                                                                                                     | 0              | W1            |
| 12    | START        | This bit is set when a start is detected on the receiver input. Its purpose is primarily to allow wake-up from Deep-sleep or Power-down mode immediately when a start is detected. Cleared by software.                                                                                                                                                                                                                    | 0              | W1            |
| 13    | FRAMERRINT   | Framing Error interrupt flag. This flag is set when a character is received with a missing stop bit at the expected location. This could be an indication of a baud rate or configuration mismatch with the transmitting source.                                                                                                                                                                                           | 0              | W1            |
| 14    | PARITYERRINT | Parity Error interrupt flag. This flag is set when a parity error is detected in a received character                                                                                                                                                                                                                                                                                                                      | 0              | W1            |
| 15    | RXNOISEINT   | Received Noise interrupt flag. Three samples of received data are taken in order to determine the value of each received data bit, except in synchronous mode. This acts as a noise filter if one sample disagrees. This flag is set when a received data bit contains one disagreeing sample. This could indicate line noise, a baud rate or character format mismatch, or loss of synchronization during data reception. | 0              | W1            |
| 16    | ABERR        | Autobaud Error. An autobaud error can occur if the BRG counts to its limit before the end of the start bit that is being measured, essentially an autobaud time-out.                                                                                                                                                                                                                                                       | 0              | W1            |
| 31:17 | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                            | NA             | NA            |

#### Table 175. USART Status register (STAT, address 0x4006 4008 (USART0) bit description

[1] RO = Read-only, W1 = write 1 to clear.

#### 13.6.4 USART Interrupt Enable read and set register

The INTENSET register is used to enable various USART interrupt sources. Enable bits in INTENSET are mapped in locations that correspond to the flags in the STAT register. The complete set of interrupt enables may be read from this register. Writing ones to implemented bits in this register causes those bits to be set. The INTENCLR register is used to clear bits in this register.

| Bit   | Symbol       | Description                                                                                                                                                     | Reset<br>Value |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0     | RXRDYEN      | When 1, enables an interrupt when there is a received character available to be read from the RXDAT register.                                                   | 0              |
| 1     | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                 | NA             |
| 2     | TXRDYEN      | When 1, enables an interrupt when the TXDAT register is available to take another character to transmit.                                                        | 0              |
| 3     | TXIDLEEN     | When 1, enables an interrupt when the transmitter becomes idle (TXIDLE = 1).                                                                                    | 0              |
| 4     | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                 | NA             |
| 5     | DELTACTSEN   | When 1, enables an interrupt when there is a change in the state of the CTS input.                                                                              | 0              |
| 6     | TXDISEN      | When 1, enables an interrupt when the transmitter is fully disabled as indicated by the TXDISINT flag in STAT. See description of the TXDISINT bit for details. | 0              |
| 7     | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                 | NA             |
| 8     | OVERRUNEN    | When 1, enables an interrupt when an overrun error occurred.                                                                                                    | 0              |
| 10:9  | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                 | NA             |
| 11    | DELTARXBRKEN | When 1, enables an interrupt when a change of state has occurred in the detection of a received break condition (break condition asserted or deasserted).       | 0              |
| 12    | STARTEN      | When 1, enables an interrupt when a received start bit has been detected.                                                                                       | 0              |
| 13    | FRAMERREN    | When 1, enables an interrupt when a framing error has been detected.                                                                                            | 0              |
| 14    | PARITYERREN  | When 1, enables an interrupt when a parity error has been detected.                                                                                             | 0              |
| 15    | RXNOISEEN    | When 1, enables an interrupt when noise is detected.                                                                                                            | 0              |
| 16    | ABERREN      | When 1, enables an interrupt when an autobaud error occurs.                                                                                                     | 0              |
| 31:17 | -            | Reserved. Read value is undefined, only zero should be written.                                                                                                 | NA             |

# Table 176. USART Interrupt Enable read and set register (INTENSET, address 0x4006 400C (USART0)) bit description

### 13.6.5 USART Interrupt Enable Clear register

The INTENCLR register is used to clear bits in the INTENSET register.

| Bit   | Symbol        | Description                                                      | Reset<br>Value |
|-------|---------------|------------------------------------------------------------------|----------------|
| 0     | RXRDYCLR      | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 1     | -             | Reserved. Read value is undefined, only zero should be written.  | NA             |
| 2     | TXRDYCLR      | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 3     | TXIDLECLR     | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 4     | -             | Reserved. Read value is undefined, only zero should be written.  | NA             |
| 5     | DELTACTSCLR   | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 6     | TXDISINTCLR   | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 7     | -             | Reserved. Read value is undefined, only zero should be written.  | NA             |
| 8     | OVERRUNCLR    | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 10:9  | -             | Reserved. Read value is undefined, only zero should be written.  | NA             |
| 11    | DELTARXBRKCLR | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 12    | STARTCLR      | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 13    | FRAMERRCLR    | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 14    | PARITYERRCLR  | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 15    | RXNOISECLR    | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 16    | ABERRCLR      | Writing 1 clears the corresponding bit in the INTENSET register. | 0              |
| 31:17 | -             | Reserved. Read value is undefined, only zero should be written.  | NA             |

# Table 177. USART Interrupt Enable clear register (INTENCLR, address 0x4006 4010 (USART0)) bit description

### 13.6.6 USART Receiver Data register

The RXDAT register contains the last character received before any overrun.

**Remark:** Reading this register changes the status flags in the RXDATSTAT register.

|      | description |                                                                                                                                                          |             |  |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|
| Bit  | Symbol      | Description                                                                                                                                              | Reset Value |  |
| 8:0  | RXDAT       | The USART Receiver Data register contains the next received character. The number of bits that are relevant depends on the USART configuration settings. | 0           |  |
| 31:9 | -           | Reserved, the value read from a reserved bit is not defined.                                                                                             | NA          |  |

# Table 178. USART Receiver Data register (RXDAT, address 0x4006 4014 (USART0) bit description

### 13.6.7 USART Receiver Data with Status register

The RXDATSTAT register contains the next complete character to be read and its relevant status flags. This allows getting all information related to a received character with one 16-bit read, which may be especially useful when the DMA is used with the USART receiver.

Remark: Reading this register changes the status flags.

| Table 179. | USART Receiver Data with Status register (RXDATSTAT, address 0x4006 4018 |
|------------|--------------------------------------------------------------------------|
|            | (USART0)) bit description                                                |

| Bit   | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                       | Reset<br>Value |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 8:0   | RXDAT     | The USART Receiver Data register contains the next received character. The number of bits that are relevant depends on the USART configuration settings.                                                                                                                                                                                                                          | 0              |
| 12:9  | -         | Reserved, the value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                      | NA             |
| 13    | FRAMERR   | Framing Error status flag. This bit is valid when there is a character<br>to be read in the RXDAT register and reflects the status of that<br>character. This bit will set when the character in RXDAT was<br>received with a missing stop bit at the expected location. This<br>could be an indication of a baud rate or configuration mismatch<br>with the transmitting source. | 0              |
| 14    | PARITYERR | Parity Error status flag. This bit is valid when there is a character to be read in the RXDAT register and reflects the status of that character. This bit will be set when a parity error is detected in a received character.                                                                                                                                                   | 0              |
| 15    | RXNOISE   | Received Noise flag. See description of the RXNOISEINT bit in Table 175.                                                                                                                                                                                                                                                                                                          | 0              |
| 31:16 | -         | Reserved, the value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                      | NA             |

#### 13.6.8 USART Transmitter Data Register

The TXDAT register is written in order to send data via the USART transmitter. That data will be transferred to the transmit shift register when it is available, and another character may then be written to TXDAT.

| Bit  | Symbol | Description                                                                                                                                                                                                                    | Reset<br>Value |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 8:0  | TXDAT  | Writing to the USART Transmit Data Register causes the data to be transmitted as soon as the transmit shift register is available and any conditions for transmitting data are met: CTS low (if CTSEN bit = 1), TXDIS bit = 0. | 0              |
| 31:9 | -      | Reserved. Only zero should be written.                                                                                                                                                                                         | NA             |

Table 180. USART Transmitter Data Register (TXDAT, address 0x4006 401C (USART0)) bit description

#### 13.6.9 USART Baud Rate Generator register

The Baud Rate Generator is a simple 16-bit integer divider controlled by the BRG register. The BRG register contains the value used to divide the base clock in order to produce the clock used for USART internal operations.

A 16-bit value allows producing standard baud rates from 300 baud and lower at the highest frequency of the device, up to 921,600 baud from a base clock as low as 14.7456 MHz.

Typically, the baud rate clock is 16 times the actual baud rate. This overclocking allows for centering the data sampling time within a bit cell, and for noise reduction and detection by taking three samples of incoming data.

Details on how to select the right values for BRG can be found in <u>Section 13.7.1</u>.

**Remark:** If software needs to change the baud rate, the following sequence should be used: 1) Make sure the USART is not currently sending or receiving data. 2) Disable the USART by writing a 0 to the Enable bit (0 may be written to the entire registers). 3) Write the new BRGVAL. 4) Write to the CFG register to set the Enable bit to 1.

| Table 181. | . USART Baud Rate Generator register (BRG, address 0x4006 4020 (USART0)) bit |
|------------|------------------------------------------------------------------------------|
|            | description                                                                  |

| Bit   | Symbol | Description                                                                                                           | Reset<br>Value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | BRGVAL | This value is used to divide the USART input clock to determine the baud rate, based on the input clock from the FRG. | 0              |
|       |        | 0 = The FRG clock is used directly by the USART function.                                                             |                |
|       |        | 1 = The FRG clock is divided by 2 before use by the USART function.                                                   |                |
|       |        | 2 = The FRG clock is divided by 3 before use by the USART function.                                                   |                |
|       |        | 0xFFFF = The FRG clock is divided by 65,536 before use by the USART function.                                         |                |
| 31:16 | -      | Reserved. Read value is undefined, only zero should be written.                                                       | NA             |

UM11021

### 13.6.10 USART Interrupt Status register

The read-only INTSTAT register provides a view of those interrupt flags that are currently enabled. This can simplify software handling of interrupts. See <u>Table 175</u> for detailed descriptions of the interrupt flags.

| Table 182. | USART Interrupt Status register (INTSTAT, address 0x4006 4024 (USART0)) bit |
|------------|-----------------------------------------------------------------------------|
|            | description                                                                 |

| Bit   | Symbol       | Description                                                                    | Reset<br>Value |
|-------|--------------|--------------------------------------------------------------------------------|----------------|
| 0     | RXRDY        | Receiver Ready flag.                                                           | 0              |
| 1     | -            | Reserved. Read value is undefined, only zero should be written.                | NA             |
| 2     | TXRDY        | Transmitter Ready flag.                                                        | 1              |
| 3     | TXIDLE       | Transmitter idle status.                                                       | 1              |
| 4     | -            | Reserved. Read value is undefined, only zero should be written.                | NA             |
| 5     | DELTACTS     | This bit is set when a change in the state of the CTS input is detected.       | 0              |
| 6     | TXDISINT     | Transmitter Disabled Interrupt flag.                                           | 0              |
| 7     | -            | Reserved. Read value is undefined, only zero should be written.                | NA             |
| 8     | OVERRUNINT   | Overrun Error interrupt flag.                                                  | 0              |
| 10:9  | -            | Reserved. Read value is undefined, only zero should be written.                | NA             |
| 11    | DELTARXBRK   | This bit is set when a change in the state of receiver break detection occurs. | 0              |
| 12    | START        | This bit is set when a start is detected on the receiver input.                | 0              |
| 13    | FRAMERRINT   | Framing Error interrupt flag.                                                  | 0              |
| 14    | PARITYERRINT | Parity Error interrupt flag.                                                   | 0              |
| 15    | RXNOISEINT   | Received Noise interrupt flag.                                                 | 0              |
| 16    | ABERR        | Autobaud Error flag.                                                           | 0              |
| 31:17 | -            | Reserved. Read value is undefined, only zero should be written.                | NA             |

#### 13.6.11 USART Oversample selection register

The OSR register allows selection of oversampling in asynchronous modes. The oversample value is the number of BRG clocks used to receive one data bit. The default is industry standard 16x oversampling.

Changing the oversampling can sometimes allow better matching of baud rates in cases where the peripheral clock rate is not a multiple of 16 times the expected maximum baud rate. For all modes where the OSR setting is used, the UART receiver takes three consecutive samples of input data in the approximate middle of the bit time. Smaller values of OSR can make the sampling position within a data bit less accurate and may potentially cause more noise errors or incorrect data.

Table 183. USART Oversample selection register (OSR, address 0x4006 4028 (USART0)) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                 | Reset<br>value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0  | OSRVAL | Oversample Selection Value.<br>0 to 3 = not supported<br>0x4 = 5 peripheral clocks are used to transmit and receive each data bit.<br>0x5 = 6 peripheral clocks are used to transmit and receive each data bit.<br><br>0xF= 16 peripheral clocks are used to transmit and receive each data | 0xF            |
| 31:4 | -      | bit.<br>Reserved, the value read from a reserved bit is not defined.                                                                                                                                                                                                                        | NA             |

#### 13.6.12 USART Address register

The ADDR register holds the address for hardware address matching in address detect mode with automatic address matching enabled.

Table 184. USART Address register (ADDR, address 0x4006 402C (USART0)) bit description

| Bit  | Symbol  |                                                                                                                                                                                        | Reset<br>value |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | ADDRESS | 8-bit address used with automatic address matching. Used when address detection is enabled (ADDRDET in $CTL = 1$ ) and automatic address matching is enabled (AUTOADDR in $CFG = 1$ ). | 0              |
| 31:8 | -       | Reserved, the value read from a reserved bit is not defined.                                                                                                                           | NA             |

# **13.7 Functional description**

#### 13.7.1 Clocking and baud rates

In order to use the USART, clocking details must be defined such as setting up the BRG, and typically also setting up the FRG. See <u>Figure 19</u>.

#### 13.7.1.1 Fractional Rate Generator (FRG)

The Fractional Rate Generator can be used to obtain more precise baud rates when the peripheral clock is not a good multiple of standard (or otherwise desirable) baud rates.

The FRG is typically set up to produce an integer multiple of the highest required baud rate, or a very close approximation. The BRG is then used to obtain the actual baud rate needed.

The FRG register controls the USART Fractional Rate Generator, which provides the base clock for the USART. The Fractional Rate Generator creates a lower rate output clock by suppressing selected input clocks. When not needed, the value of 0 can be set for the FRG, which will then not divide the input clock.

The FRG output clock is defined as the inputs clock divided by 1 + (MULT / 256), where MULT is in the range of 1 to 255. This allows producing an output clock that ranges from the input clock divided by 1+1/256 to 1+255/256 (just more than 1 to just less than 2). Any further division can be done specific to each USART block by the integer BRG divider contained in each USART.

The base clock produced by the FRG cannot be perfectly symmetrical, so the FRG distributes the output clocks as evenly as is practical. Since the USART normally uses 16x overclocking, the jitter in the fractional rate clock in these cases tends to disappear in the ultimate USART output.

For setting up the fractional divider use the following registers:

Table 34 "USART clock divider register (UARTCLKDIV, address 0x4004 8094) bit description", Table 38 "USART fractional generator divider value register (UARTFRGDIV, address 0x4004 80F0) bit description", and Table 39 "USART fractional generator multiplier value register (UARTFRGMULT, address 0x4004 80F4) bit description".

For details see Section 13.3.1 "Configure the USART clock and baud rate".

#### 13.7.1.2 Baud Rate Generator (BRG)

The Baud Rate Generator (see <u>Section 13.6.9</u>) is used to divide the base clock to produce a rate 16 times the desired baud rate. Typically, standard baud rates can be generated by integer divides of higher baud rates.

#### 13.7.1.3 Baud rate calculations

Base clock rates are 16x for asynchronous mode and 1x for synchronous mode.

#### 13.7.2 DMA

A DMA request is provided for each USART direction, and can be used in lieu of interrupts for transferring data by configuring the DMA controller appropriately. The DMA controller provides an acknowledgement signal that clears the related request when it completes handling a that request. The transmitter DMA request is asserted when the transmitter can accept more data. The receiver DMA request is asserted when received data is available to be read.

When DMA is used to perform USART data transfers, other mechanisms can be used to generate interrupts when needed. For instance, completion of the configured DMA transfer can generate an interrupt from the DMA controller. Also, interrupts for special conditions, such as a received break, can still generate useful interrupts.

#### 13.7.3 Synchronous mode

**Remark:** Synchronous mode transmit and receive operate at the incoming clock rate in slave mode and the BRG selected rate (not divided by 16) in master mode.

#### 13.7.4 Flow control

The USART supports both hardware and software flow control.

#### 13.7.4.1 Hardware flow control

The USART supports hardware flow control using RTS and/or CTS signalling. If RTS is configured to appear on a device pin so that it can be sent to an external device, it indicates to an external device the ability of the receiver to receive more data.

If connected to a pin, and if enabled to do so, the CTS input can allow an external device to throttle the USART transmitter.



Figure 21 shows an overview of RTS and CTS within the USART.

#### 13.7.4.2 Software flow control

Software flow control could include XON / XOFF flow control, or other mechanisms. these are supported by the ability to check the current state of the CTS input, and/or have an interrupt when CTS changes state (via the CTS and DELTACTS bits, respectively, in the STAT register), and by the ability of software to gracefully turn off the transmitter (via the TXDIS bit in the CTL register).

#### 13.7.5 Autobaud function

The autobaud functions attempts to measure the start bit time of the next received character. For this to work, the measured character must have a 1 in the least significant bit position, so that the start bit is bounded by a falling and rising edge. The measurement is made using the current clocking settings, including the oversampling configuration. The

result is that a value is stored in the BRG register that is as close as possible to the correct setting for the sampled character and the current clocking settings. The sampled character is provided in the RXDAT and RXDATSTAT registers, allowing software to double-check for the expected character.

Autobaud includes a time-out that is flagged by ABERR if no character is received at the expected time. It is recommended that autobaud only be enabled when the USART receiver is idle. Once enabled, either RXRDY or ABERR will be asserted at some point. The assertion of RXRDY clears the AUTOBAUD bit automatically. The assertion of ABERR clears the AUTOBAUD bit once the receive line goes inactive.

Autobaud has no meaning, and should not be enabled, if the USART is in synchronous mode.

**Remark:** Before using autobaud, set the BRG register to 0x0 (this is the default). This setting allows the autobaud function to handle all baud rates.

#### 13.7.6 RS-485 support

RS-485 support requires some form of address recognition and data direction control.

This USART has provisions for hardware address recognition (see the AUTOADDR bit in the CFG register in <u>Section 13.6.1</u> and the ADDR register in <u>Section 13.6.12</u>), as well as software address recognition (see the ADDRDET bit in the CTL register in <u>Section 13.6.2</u>).

Automatic data direction control with the RTS pin can be set up using the OESEL. OEPOL, and OETA bits in the CFG register (<u>Section 13.6.1</u>). Data direction control can also be implemented in software using a GPIO pin.

### 13.7.7 Oversampling

Typical industry standard UARTs use a 16x oversample clock to transmit and receive asynchronous data. This is the number of BRG clocks used for one data bit. The Oversample Select Register (OSR) allows this UART to use a 16x down to a 5x oversample clock. There is no oversampling in synchronous modes.

Reducing the oversampling can sometimes help in getting better baud rate matching when the baud rate is very high, or the peripheral clock is very low. For example, the closest actual rate near 115,200 baud with a 12 MHz peripheral clock and 16x oversampling is 107,143 baud, giving a rate error of 7%. Changing the oversampling to 15x gets the actual rate to 114,286 baud, a rate error of 0.8%. Reducing the oversampling to 13x gets the actual rate to 115,385 baud, a rate error of only 0.16%.

There is a cost for altering the oversampling. In asynchronous modes, the UART takes three samples of incoming data on consecutive oversample clocks, as close to the center of a bit time as can be done. When the oversample rate is reduced, the three samples spread out and occupy a larger proportion of a bit time. For example, with 5x oversampling, there is one oversample clock, then three data samples taken, then one more oversample clock before the end of the bit time. Since the oversample clock is running asynchronously from the input data, skew of the input data relative to the expected timing has little room for error. At 16x oversampling, there are several

oversample clocks before actual data sampling is done, making the sampling more robust. Generally speaking, it is recommended to use the highest oversampling where the rate error is acceptable in the system.

UM11021

# **UM11021**

Chapter 14: LPC83x SPI0/1

Rev. 1.1 — 5 October 2016

**User manual** 

# 14.1 How to read this chapter

The SPI interfaces are available on all parts depending on the switch matrix configuration.

# 14.2 Features

- Data transmits 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. This can be useful while setting up an SPI memory.
- Control information can optionally be written along with data. This allows very versatile operation, including frames of arbitrary length.
- Up to four Slave Select input/outputs with selectable polarity and flexible usage.
- Supports DMA transfers: SPIn transmit and receive functions can operated with the system DMA controller.

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

### 14.3 Basic configuration

Configure SPI0/1 using the following registers:

- In the SYSAHBCLKCTRL register, set bit 11 and 12 (<u>Table 33</u>) to enable the clock to the register interface.
- Clear the SPI0/1 peripheral resets using the PRESETCTRL register (<u>Table 21</u>).
- Enable/disable the SPI0/1 interrupts in interrupt slots #0 and 1 in the NVIC.
- Configure the SPI0/1 pin functions through the switch matrix. See Section 14.4.
- The peripheral clock for both SPIs is the system clock (see <u>Figure 4 "Clock</u> <u>generation"</u>).



#### 14.3.1 Configure the SPI for wake-up

In sleep mode, any signal that triggers an SPI interrupt can wake up the part, provided that the interrupt is enabled in the INTENSET register and the NVIC. As long as the SPI clock SPI\_PCLK remains active in sleep mode, the SPI can wake up the part independently of whether the SPI block is configured in master or slave mode.

In Deep-sleep or Power-down mode, the SPI clock is turned off as are all peripheral clocks. However, if the SPI is configured in slave mode and an external master on the provides the clock signal, the SPI can create an interrupt asynchronously. This interrupt, if enabled in the NVIC and in the SPI's INTENSET register, can then wake up the core.

#### 14.3.1.1 Wake-up from Sleep mode

- Configure the SPI in either master or slave mode. See Table 187.
- Enable the SPI interrupt in the NVIC.
- Any SPI interrupt wakes up the part from sleep mode. Enable the SPI interrupt in the INTENSET register (Table 190).

#### 14.3.1.2 Wake-up from Deep-sleep or Power-down mode

- Configure the SPI in slave mode. See <u>Table 187</u>. You must connect the SCK function to a pin and connect the pin to the master.
- Enable the SPI interrupt in the STARTERP1 register. See <u>Table 49 "Start logic 1</u> <u>interrupt wake-up enable register (STARTERP1, address 0x4004 8214) bit</u> <u>description</u>".
- In the PDAWAKE register, configure all peripherals that need to be running when the part wakes up.
- Enable the SPI interrupt in the NVIC.
- Enable the interrupt in the INTENSET register which configures the interrupt as wake-up event (Table 190). Examples are the following wake-up events:
  - A change in the state of the SSEL pins.
  - Data available to be received.
  - Receiver overrun.

### **14.4 Pin description**

The SPI signals are movable functions and are assigned to external pins through the switch matrix.

See <u>Section 7.3.1 "Connect an internal signal to a package pin"</u> to assign the SPI functions to pins on the part.

#### Table 185. SPI Pin Description

| Function   | I/O | Туре               | Connect<br>to | Use register | Reference | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-----|--------------------|---------------|--------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI0_SCK   | I/O | external<br>to pin | any pin       | PINASSIGN3   | Table 67  | Serial Clock. SCK is a clock signal used to<br>synchronize the transfer of data. It is driven by the<br>master and received by the slave. When the SPI<br>interface is used, the clock is programmable to be<br>active-high or active-low. SCK only switches during<br>a data transfer. It is driven whenever the Master bit<br>in CFG equals 1, regardless of the state of the<br>Enable bit.                                                                                                                                                                      |
| SPI0_MOSI  | I/O | external<br>to pin | any pin       | PINASSIGN4   | Table 68  | Master Out Slave In. The MOSI signal transfers<br>serial data from the master to the slave. When the<br>SPI is a master, it outputs serial data on this signal.<br>When the SPI is a slave, it clocks in serial data<br>from this signal. MOSI is driven whenever the<br>Master bit in SPInCfg equals 1, regardless of the<br>state of the Enable bit.                                                                                                                                                                                                              |
| SPI0_MISO  | I/O | external<br>to pin | any pin       | PINASSIGN4   | Table 68  | Master In Slave Out. The MISO signal transfers<br>serial data from the slave to the master. When the<br>SPI is a master, serial data is input from this signal.<br>When the SPI is a slave, serial data is output to this<br>signal. MISO is driven when the SPI block is<br>enabled, the Master bit in CFG equals 0, and when<br>the slave is selected by one or more SSEL signals.                                                                                                                                                                                |
| SPI0_SSEL0 | I/O | external<br>to pin | any pin       | PINASSIGN4   | Table 68  | Slave Select 0. When the SPI interface is a master,<br>it will drive the SSEL signals to an active state<br>before the start of serial data and then release<br>them to an inactive state after the serial data has<br>been sent. By default, this signal is active low but<br>can be selected to operate as active high. When<br>the SPI is a slave, any SSEL in an active state<br>indicates that this slave is being addressed. The<br>SSEL pin is driven whenever the Master bit in the<br>CFG register equals 1, regardless of the state of<br>the Enable bit. |
| SPI0_SSEL1 | I/O | external<br>to pin | any pin       | PINASSIGN4   | Table 68  | Slave Select 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI0_SSEL2 | I/O | external<br>to pin | any pin       | PINASSIGN5   | Table 69  | Slave Select 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI0_SSEL3 | I/O | external<br>to pin | any pin       | PINASSIGN5   | Table 69  | Slave Select 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI1_SCK   | I/O | external<br>to pin | any pin       | PINASSIGN5   | Table 69  | Serial Clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SPI1_MOSI  | I/O | external<br>to pin | any pin       | PINASSIGN5   | Table 69  | Master Out Slave In.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| SPI1_MISO  | I/O | external<br>to pin | any pin       | PINASSIGN6   | Table 70  | Master In Slave Out.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| SPI1_SSEL0 | I/O | external<br>to pin | any pin       | PINASSIGN6   | Table 70  | Slave Select 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SPI1_SSEL1 | I/O | external<br>to pin | any pin       | PINASSIGN6   | Table 70  | Slave Select 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

UM11021

# 14.5 General description



# 14.6 Register description

The Reset Value reflects the data stored in used bits only. It does not include reserved bits content.

# Table 186. Register overview: SPI (base address 0x4005 8000 (SPI0) and 0x4005 C000 (SPI1))

| Name | Access | Offset | Description                                                                      | Reset<br>value | Reference        |
|------|--------|--------|----------------------------------------------------------------------------------|----------------|------------------|
| CFG  | R/W    | 0x000  | SPI Configuration register                                                       | 0              | Table 187        |
| DLY  | R/W    | 0x004  | SPI Delay register                                                               | 0              | Table 188        |
| STAT | R/W    | 0x008  | SPI Status. Some status flags can be cleared by writing a 1 to that bit position | 0x0102         | <u>Table 189</u> |

# Table 186. Register overview: SPI (base address 0x4005 8000 (SPI0) and 0x4005 C000 (SPI1)) ...continued

| Name     | Access | Offset | Description                                                                                                                                                | Reset<br>value | Reference        |
|----------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| INTENSET | R/W    | 0x00C  | SPI Interrupt Enable read and Set. A complete value may be read from this register. Writing a 1 to any implemented bit position causes that bit to be set. | 0              | <u>Table 190</u> |
| INTENCLR | W      | 0x010  | SPI Interrupt Enable Clear. Writing a 1 to any implemented bit position causes the corresponding bit in INTENSET to be cleared.                            | NA             | <u>Table 191</u> |
| RXDAT    | R      | 0x014  | SPI Receive Data                                                                                                                                           | NA             | Table 192        |
| TXDATCTL | R/W    | 0x018  | SPI Transmit Data with Control                                                                                                                             | 0              | Table 193        |
| TXDAT    | R/W    | 0x01C  | SPI Transmit Data                                                                                                                                          | 0              | Table 194        |
| TXCTL    | R/W    | 0x020  | SPI Transmit Control                                                                                                                                       | 0              | Table 195        |
| DIV      | R/W    | 0x024  | SPI clock Divider                                                                                                                                          | 0              | Table 196        |
| INTSTAT  | R      | 0x028  | SPI Interrupt Status                                                                                                                                       | 0x02           | Table 197        |

#### 14.6.1 SPI Configuration register

The CFG register contains information for the general configuration of the SPI. Typically, this information is not changed during operation. Some configurations, such as CPOL, CPHA, and LSBF should not be made while the SPI is not fully idle. See the description of the master idle status (MSTIDLE in <u>Table 189</u>) for more information.

**Remark:** If the interface is re-configured from Master mode to Slave mode or the reverse (an unusual case), the SPI should be disabled and re-enabled with the new configuration.

Table 187. SPI Configuration register (CFG, addresses 0x4005 8000 (SPI0), 0x4005 C000 (SPI1)) bit description

| Bit | Symbol | Value  | Description                                                                                                      | Reset<br>value      |   |
|-----|--------|--------|------------------------------------------------------------------------------------------------------------------|---------------------|---|
| 0 6 | ENABLE |        | SPI enable.                                                                                                      | 0                   |   |
|     |        | 0      | Disabled. The SPI is disabled and the internal state machine and counters are reset.                             |                     |   |
|     |        | 1      | Enabled. The SPI is enabled for operation.                                                                       |                     |   |
| 1   | -      |        | Reserved. Read value is undefined, only zero should be written.                                                  | NA                  |   |
| 2   | MASTER | MASTER |                                                                                                                  | Master mode select. | 0 |
|     |        | 0      | Slave mode. The SPI will operate in slave mode. SCK, MOSI, and the SSEL signals are inputs, MISO is an output.   |                     |   |
|     |        | 1      | Master mode. The SPI will operate in master mode. SCK, MOSI, and the SSEL signals are outputs, MISO is an input. |                     |   |
| 3   | LSBF   |        | LSB First mode enable.                                                                                           | 0                   |   |
|     |        | 0      | Standard. Data is transmitted and received in standard MSB first order.                                          |                     |   |
|     |        | 1      | Reverse. Data is transmitted and received in reverse order (LSB first).                                          |                     |   |

| Bit   | Symbol | Value | Description                                                                                                                                                                   | Reset<br>value |
|-------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 4     | CPHA   |       | Clock Phase select.                                                                                                                                                           | 0              |
|       |        | 0     | Change. The SPI captures serial data on the first clock transition of the transfer (when the clock changes away from the rest state). Data is changed on the following edge.  |                |
|       |        | 1     | Capture. The SPI changes serial data on the first clock transition of the transfer (when the clock changes away from the rest state). Data is captured on the following edge. |                |
| 5     | CPOL   |       | Clock Polarity select.                                                                                                                                                        | 0              |
|       |        | 0     | Low. The rest state of the clock (between transfers) is low.                                                                                                                  |                |
|       |        | 1     | High. The rest state of the clock (between transfers) is high.                                                                                                                |                |
| 6     | -      |       | Reserved. Read value is undefined, only zero should be written.                                                                                                               | NA             |
| 7     | LOOP   |       | Loopback mode enable. Loopback mode applies only to Master mode, and connects transmit and receive data connected together to allow simple software testing.                  | 0              |
|       |        | 0     | Disabled.                                                                                                                                                                     |                |
|       |        | 1     | Enabled.                                                                                                                                                                      |                |
| 8     | SPOL0  |       | SSEL0 Polarity select.                                                                                                                                                        | 0              |
|       |        | 0     | Low. The SSEL0 pin is active low. The value in the SSEL0 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL0 is not inverted relative to the pins.            |                |
|       |        | 1     | High. The SSEL0 pin is active high. The value in the SSEL0 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL0 is inverted relative to the pins.              |                |
| 9     | SPOL1  |       | SSEL1 Polarity select.                                                                                                                                                        | 0              |
|       |        | 0     | Low. The SSEL1 pin is active low. The value in the SSEL1 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL1 is not inverted relative to the pins.            |                |
|       |        | 1     | High. The SSEL1 pin is active high. The value in the SSEL1 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL1 is inverted relative to the pins.              |                |
| 10    | SPOL2  |       | SSEL2 Polarity select.                                                                                                                                                        | 0              |
|       |        | 0     | Low. The SSEL2 pin is active low. The value in the SSEL2 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL2 is not inverted relative to the pins.            |                |
|       |        | 1     | High. The SSEL2 pin is active high. The value in the SSEL2 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL2 is inverted relative to the pins.              |                |
| 11    | SPOL3  |       | SSEL3 Polarity select.                                                                                                                                                        | 0              |
|       |        | 0     | Low. The SSEL3 pin is active low. The value in the SSEL3 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL3 is not inverted relative to the pins.            |                |
|       |        | 1     | High. The SSEL3 pin is active high. The value in the SSEL3 fields of the RXDAT, TXDATCTL, and TXCTL registers related to SSEL3 is inverted relative to the pins.              |                |
| 31:12 | -      |       | Reserved. Read value is undefined, only zero should be written.                                                                                                               | NA             |

# Table 187. SPI Configuration register (CFG, addresses 0x4005 8000 (SPI0), 0x4005 C000 (SPI1)) bit description ...continued

#### 14.6.2 SPI Delay register

The DLY register controls several programmable delays related to SPI signalling. These delays apply only to master mode, and are all stated in SPI clocks.

Timing details are shown in:

Section 14.7.2.1 "Pre\_delay and Post\_delay"

Section 14.7.2.2 "Frame\_delay"

| Bit   | Symbol         | Description                                                                                                                            | Reset<br>value |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   | PRE_DELAY      | Controls the amount of time between SSEL assertion and the beginning of a data transfer.                                               | 0              |
|       |                | There is always one SPI clock time between SSEL assertion and the first clock edge.<br>This is not considered part of the pre-delay.   |                |
|       |                | 0x0 = No additional time is inserted.                                                                                                  |                |
|       |                | 0x1 = 1 SPI clock time is inserted.                                                                                                    |                |
|       |                | 0x2 = 2 SPI clock times are inserted.                                                                                                  |                |
|       |                |                                                                                                                                        |                |
|       |                | 0xF = 15 SPI clock times are inserted.                                                                                                 |                |
| 7:4   | POST_DELAY     | Controls the amount of time between the end of a data transfer and SSEL deassertion.                                                   | 0              |
|       |                | 0x0 = No additional time is inserted.                                                                                                  |                |
|       |                | 0x1 = 1 SPI clock time is inserted.                                                                                                    |                |
|       |                | 0x2 = 2 SPI clock times are inserted.                                                                                                  |                |
|       |                |                                                                                                                                        |                |
|       |                | 0xF = 15 SPI clock times are inserted.                                                                                                 |                |
| 11:8  | FRAME_DELAY    | If the EOF flag is set, controls the minimum amount of time between the current frame and the next frame (or SSEL deassertion if EOT). | 0              |
|       |                | 0x0 = No additional time is inserted.                                                                                                  |                |
|       |                | 0x1 = 1 SPI clock time is inserted.                                                                                                    |                |
|       |                | 0x2 = 2 SPI clock times are inserted.                                                                                                  |                |
|       |                |                                                                                                                                        |                |
|       |                | 0xF = 15 SPI clock times are inserted.                                                                                                 |                |
| 15:12 | TRANSFER_DELAY | Controls the minimum amount of time that the SSEL is deasserted between transfers.                                                     | 0              |
|       |                | 0x0 = The minimum time that SSEL is deasserted is 1 SPI clock time. (Zero added time.)                                                 |                |
|       |                | 0x1 = The minimum time that SSEL is deasserted is 2 SPI clock times.                                                                   |                |
|       |                | 0x2 = The minimum time that SSEL is deasserted is 3 SPI clock times.                                                                   |                |
|       |                |                                                                                                                                        |                |
|       |                | 0xF = The minimum time that SSEL is deasserted is 16 SPI clock times.                                                                  |                |
| 31:16 | -              | Reserved. Read value is undefined, only zero should be written.                                                                        | NA             |

Section 14.7.2.3 "Transfer\_delay"

**UM11021** 

#### 14.6.3 SPI Status register

The STAT register provides SPI status flags for software to read, and a control bit for forcing an end of transfer. Flags other than read-only flags may be cleared by writing ones to corresponding bits of STAT.

STAT contains 2 error flags (in slave mode only): RXOV and TXUR. These are receiver overrun and transmit underrun, respectively. If either of these errors occur during operation, the SPI should be disabled, then re-enabled in order to make sure all internal states are cleared before attempting to resume operation.

In this register, the following notation is used: RO = Read-only, W1 = write 1 to clear.

Table 189. SPI Status register (STAT, addresses 0x4005 8008 (SPI0), 0x4005 C008 (SPI1)) bit description

| Bit | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                              | Reset<br>value | Access<br>[1] |
|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------|
| 0   | RXRDY   | Receiver Ready flag. When 1, indicates that data is available to be read from the receiver buffer. Cleared after a read of the RXDAT register.                                                                                                                                                                                                                                                                           | 0              | RO            |
| 1   | TXRDY   | Transmitter Ready flag. When 1, this bit indicates that data may be written to the transmit buffer. Previous data may still be in the process of being transmitted. Cleared when data is written to TXDAT or TXDATCTL until the data is moved to the transmit shift register.                                                                                                                                            | 1              | RO            |
| 2   | RXOV    | Receiver Overrun interrupt flag. This flag applies only to slave mode (Master = 0). This flag is set when the beginning of a received character is detected while the receiver buffer is still in use. If this occurs, the receiver buffer contents are preserved, and the incoming data is lost. Data received by the SPI should be considered undefined if RxOv is set.                                                | 0              | W1            |
| 3   | TXUR    | Transmitter Underrun interrupt flag. This flag applies only to slave mode (Master = 0). In this case, the transmitter must begin sending new data on the next input clock if the transmitter is idle. If that data is not available in the transmitter holding register at that point, there is no data to transmit and the TXUR flag is set. Data transmitted by the SPI should be considered undefined if TXUR is set. | 0              | W1            |
| 4   | SSA     | Slave Select Assert. This flag is set whenever any slave select transitions from deasserted to asserted, in both master and slave modes. This allows determining when the SPI transmit/receive functions become busy, and allows waking up the device from reduced power modes when a slave mode access begins. This flag is cleared by software.                                                                        | 0              | W1            |
| 5   | SSD     | Slave Select Deassert. This flag is set whenever any asserted slave selects transition to deasserted, in both master and slave modes. This allows determining when the SPI transmit/receive functions become idle. This flag is cleared by software.                                                                                                                                                                     | 0              | W1            |
| 6   | STALLED | Stalled status flag. This indicates whether the SPI is currently in a stall condition.                                                                                                                                                                                                                                                                                                                                   | 0              | RO            |

| T.I.I. 400 | ODLOG COTAT               |                             |                      | DIAN I TO LOOK AND AND A |
|------------|---------------------------|-----------------------------|----------------------|--------------------------|
| Table 189. | SPI Status register (STAT | , addresses 0x4005 8008 (SI | PIU), 0X4005 C008 (S | PI1)) bit description    |

| Bit  | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset<br>value | Access<br>[1] |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------|
| 7    | ENDTRANSFER | End Transfer control bit. Software can set this bit to force an end to the current transfer when the transmitter finishes any activity already in progress, as if the EOT flag had been set prior to the last transmission. This capability is included to support cases where it is not known when transmit data is written that it will be the end of a transfer. The bit is cleared when the transmitter becomes idle as the transfer comes to an end. Forcing an end of transfer in this manner causes any specified FRAME_DELAY and TRANSFER_DELAY to be inserted. | 0              | RO/W1         |
| 8    | MSTIDLE     | Master idle status flag. This bit is 1 whenever the SPI master function is fully idle. This means that the transmit holding register is empty and the transmitter is not in the process of sending data.                                                                                                                                                                                                                                                                                                                                                                | 1              | RO            |
| 31:9 | -           | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NA             | NA            |

[1] RO = Read-only, W1 = write 1 to clear.

#### 14.6.4 SPI Interrupt Enable read and Set register

The INTENSET register is used to enable various SPI interrupt sources. Enable bits in INTENSET are mapped in locations that correspond to the flags in the STAT register. The complete set of interrupt enables may be read from this register. Writing ones to implemented bits in this register causes those bits to be set. The INTENCLR register is used to clear bits in this register. See Table 189 for details of the interrupts.

# Table 190. SPI Interrupt Enable read and Set register (INTENSET, addresses 0x4005 800C (SPI0), 0x4005 C00C (SPI1)) bit description

| Bit | Symbol  | Value | Description                                                                                                                                                                                                          | Reset<br>value |
|-----|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | RXRDYEN |       | Determines whether an interrupt occurs when receiver data is available.                                                                                                                                              | 0              |
|     |         | 0     | No interrupt will be generated when receiver data is available.                                                                                                                                                      | _              |
|     |         | 1     | An interrupt will be generated when receiver data is available in the RXDAT register.                                                                                                                                | _              |
| 1   | TXRDYEN |       | Determines whether an interrupt occurs when the transmitter holding register is available.                                                                                                                           | 0              |
|     |         | 0     | No interrupt will be generated when the transmitter holding register is available.                                                                                                                                   |                |
|     |         | 1     | An interrupt will be generated when data may be written to TXDAT.                                                                                                                                                    |                |
| 2   | RXOVEN  |       | Determines whether an interrupt occurs when a receiver overrun occurs. This happens in slave mode when there is a need for the receiver to move newly received data to the RXDAT register when it is already in use. | 0              |
|     |         |       | The interface prevents receiver overrun in Master mode by not allowing a new transmission to begin when a receiver overrun would otherwise occur.                                                                    |                |
|     |         | 0     | No interrupt will be generated when a receiver overrun occurs.                                                                                                                                                       |                |
|     |         | 1     | An interrupt will be generated if a receiver overrun occurs.                                                                                                                                                         |                |
| 3   | TXUREN  |       | Determines whether an interrupt occurs when a transmitter underrun occurs. This happens in slave mode when there is a need to transmit data when none is available.                                                  | 0              |
|     |         | 0     | No interrupt will be generated when the transmitter underruns.                                                                                                                                                       |                |
|     |         | 1     | An interrupt will be generated if the transmitter underruns.                                                                                                                                                         |                |

| Bit  | Symbol | Value | Description                                                                                   | Reset<br>value |
|------|--------|-------|-----------------------------------------------------------------------------------------------|----------------|
| 4    | SSAEN  |       | Determines whether an interrupt occurs when the Slave Select is asserted.                     | 0              |
|      |        | 0     | No interrupt will be generated when any Slave Select transitions from deasserted to asserted. |                |
|      |        | 1     | An interrupt will be generated when any Slave Select transitions from deasserted to asserted. |                |
| 5    | SSDEN  |       | Determines whether an interrupt occurs when the Slave Select is deasserted.                   | 0              |
|      |        | 0     | No interrupt will be generated when all asserted Slave Selects transition to deasserted.      |                |
|      |        | 1     | An interrupt will be generated when all asserted Slave Selects transition to deasserted.      |                |
| 31:6 | -      |       | Reserved. Read value is undefined, only zero should be written.                               | NA             |

# Table 190. SPI Interrupt Enable read and Set register (INTENSET, addresses 0x4005 800C (SPI0), 0x4005 C00C (SPI1)) bit description

#### 14.6.5 SPI Interrupt Enable Clear register

The INTENCLR register is used to clear interrupt enable bits in the INTENSET register.

# Table 191. SPI Interrupt Enable clear register (INTENCLR, addresses 0x4005 8010 (SPI0), 0x4005 C010 (SPI1)) bit description

| Bit  | Symbol  | Description                                                       | Reset<br>value |
|------|---------|-------------------------------------------------------------------|----------------|
| 0    | RXRDYEN | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 1    | TXRDYEN | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 2    | RXOVEN  | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 3    | TXUREN  | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 4    | SSAEN   | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 5    | SSDEN   | Writing 1 clears the corresponding bits in the INTENSET register. | 0              |
| 31:6 | -       | Reserved. Read value is undefined, only zero should be written.   | NA             |

#### 14.6.6 SPI Receiver Data register

The read-only RXDAT register provides the means to read the most recently received data. The value of SSEL can be read along with the data.

For details on the slave select process, see Section 14.7.4.

| Table 192. SPI Receive | er Data register (RXDAT, addresses 0x4005 8014 (SPI0), 0x4005 C014 |  |
|------------------------|--------------------------------------------------------------------|--|
| (SPI1)) bit d          | lescription                                                        |  |

| Bit   | Symbol    | Description                                                                                                                                                                                                                                                                                                                                      | Reset<br>value |
|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | RXDAT     | Receiver Data. This contains the next piece of received data.<br>The number of bits that are used depends on the LEN setting<br>in TXCTL / TXDATCTL.                                                                                                                                                                                             | undefined      |
| 16    | RXSSEL0_N | Slave Select for receive. This field allows the state of the<br>SSEL0 pin to be saved along with received data. The value<br>will reflect the SSEL0 pin for both master and slave operation.<br>A zero indicates that a slave select is active. The actual<br>polarity of each slave select pin is configured by the related<br>SPOL bit in CFG. | undefined      |
| 17    | RXSSEL1_N | Slave Select for receive. This field allows the state of the<br>SSEL1 pin to be saved along with received data. The value<br>will reflect the SSEL1 pin for both master and slave operation.<br>A zero indicates that a slave select is active. The actual<br>polarity of each slave select pin is configured by the related<br>SPOL bit in CFG. | undefined      |
| 18    | RXSSEL2_N | Slave Select for receive. This field allows the state of the<br>SSEL2 pin to be saved along with received data. The value<br>will reflect the SSEL2 pin for both master and slave operation.<br>A zero indicates that a slave select is active. The actual<br>polarity of each slave select pin is configured by the related<br>SPOL bit in CFG. | undefined      |
| 19    | RXSSEL3_N | Slave Select for receive. This field allows the state of the<br>SSEL3 pin to be saved along with received data. The value<br>will reflect the SSEL3 pin for both master and slave operation.<br>A zero indicates that a slave select is active. The actual<br>polarity of each slave select pin is configured by the related<br>SPOL bit in CFG. | undefined      |
| 20    | SOT       | Start of Transfer flag. This flag will be 1 if this is the first data after the SSELs went from deasserted to asserted (i.e., any previous transfer has ended). This information can be used to identify the first piece of data in cases where the transfer length is greater than 16 bit.                                                      |                |
| 31:21 | -         | Reserved, the value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                     | NA             |

UM11021

#### 14.6.7 SPI Transmitter Data and Control register

The TXDATCTL register provides a location where both transmit data and control information can be written simultaneously. This allows detailed control of the SPI without a separate write of control information for each piece of data, which can be especially useful when the SPI is used with DMA.

**Remark:** The SPI has no receiver control registers. Hence software needs to set the data length in the transmitter control or transmitter data and control register first in order to handle reception with correct data length. The programmed data length becomes active only when data is actually transmitted. Therefore, this must be done before any data can be received.

When control information remains static during transmit, the TXDAT register should be used (see <u>Section 14.6.8</u>) instead of the TXDATCTL register. Control information can then be written separately via the TXCTL register (see <u>Section 14.6.9</u>). The upper part of TXDATCTL (bits 27 to 16) are the same bits contained in the TXCTL register. The two registers simply provide two ways to access them.

For details on the slave select process, see Section 14.7.4.

For details on using multiple consecutive data transmits for transfer lengths larger than 16 bit, see Section 14.7.6 "Data lengths greater than 16 bits".

# Table 193. SPI Transmitter Data and Control register (TXDATCTL, addresses 0x4005 8018 (SPI0), 0x4005 C018 (SPI1)) bit description

| Bit  | Symbol    | Value | Description                                                                                                     | Reset<br>value |
|------|-----------|-------|-----------------------------------------------------------------------------------------------------------------|----------------|
| 15:0 | TXDAT     |       | Transmit Data. This field provides from 1 to 16 bits of data to be transmitted.                                 | 0              |
| 16   | TXSSEL0_N |       | Transmit Slave Select. This field asserts SSEL0 in master mode. The output on the pin is active LOW by default. | 0              |
|      |           |       | <b>Remark:</b> The active state of the SSEL0 pin is configured by bits in the CFG register.                     |                |
|      |           | 0     | SSEL0 asserted.                                                                                                 |                |
|      |           | 1     | SSEL0 not asserted.                                                                                             |                |
| 17   | TXSSEL1_N |       | Transmit Slave Select. This field asserts SSEL1 in master mode. The output on the pin is active LOW by default. | 0              |
|      |           |       | <b>Remark:</b> The active state of the SSEL1 pin is configured by bits in the CFG register.                     |                |
|      |           | 0     | SSEL1 asserted.                                                                                                 |                |
|      |           | 1     | SSEL1 not asserted.                                                                                             |                |
| 18   | TXSSEL2_N |       | Transmit Slave Select. This field asserts SSEL2 in master mode. The output on the pin is active LOW by default. | 0              |
|      |           |       | <b>Remark:</b> The active state of the SSEL2 pin is configured by bits in the CFG register.                     |                |
|      |           | 0     | SSEL2 asserted.                                                                                                 |                |
|      |           | 1     | SSEL2 not asserted.                                                                                             |                |
| 19   | TXSSEL3_N |       | Transmit Slave Select. This field asserts SSEL3 in master mode. The output on the pin is active LOW by default. | 0              |
|      |           |       | <b>Remark:</b> The active state of the SSEL3 pin is configured by bits in the CFG register.                     |                |
|      |           | 0     | SSEL3 asserted.                                                                                                 | 1              |
|      |           | 1     | SSEL3 not asserted.                                                                                             | 1              |

**User manual** 

| Bit   | Symbol   | Value | Description                                                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 20    | EOT      |       | End of Transfer. The asserted SSEL will be deasserted at the end of a transfer, and remain so for at least the time specified by the Transfer_delay value in the DLY register.                                                                                                              | 0              |
|       |          | 0     | SSEL not deasserted. This piece of data is not treated as the end of a transfer.<br>SSEL will not be deasserted at the end of this data.                                                                                                                                                    |                |
|       |          | 1     | SSEL deasserted. This piece of data is treated as the end of a transfer. SSEL will be deasserted at the end of this piece of data.                                                                                                                                                          |                |
| 21    | EOF      |       | End of Frame. Between frames, a delay may be inserted, as defined by the FRAME_DELAY value in the DLY register. The end of a frame may not be particularly meaningful if the FRAME_DELAY value = 0. This control can be used as part of the support for frame lengths greater than 16 bits. | 0              |
|       |          | 0     | Data not EOF. This piece of data transmitted is not treated as the end of a frame.                                                                                                                                                                                                          |                |
|       |          | 1     | Data EOF. This piece of data is treated as the end of a frame, causing the FRAME_DELAY time to be inserted before subsequent data is transmitted.                                                                                                                                           |                |
| 22    | RXIGNORE |       | Receive Ignore. This allows data to be transmitted using the SPI without the need to read unneeded data from the receiver.Setting this bit simplifies the transmit process and can be used with the DMA.                                                                                    | 0              |
|       |          | 0     | Read received data. Received data must be read in order to allow transmission to progress. In slave mode, an overrun error will occur if received data is not read before new data is received.                                                                                             |                |
|       |          | 1     | Ignore received data. Received data is ignored, allowing transmission without reading unneeded received data. No receiver flags are generated.                                                                                                                                              |                |
| 23    | -        |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                             | NA             |
| 27:24 | LEN      |       | Data Length. Specifies the data length from 1 to 16 bits. Note that transfer lengths greater than 16 bits are supported by implementing multiple sequential transmits.                                                                                                                      | 0x0            |
|       |          |       | 0x0 = Data transfer is 1 bit in length.                                                                                                                                                                                                                                                     |                |
|       |          |       | 0x1 = Data transfer is 2 bits in length.                                                                                                                                                                                                                                                    |                |
|       |          |       | 0x2 = Data transfer is 3 bits in length.                                                                                                                                                                                                                                                    |                |
|       |          |       |                                                                                                                                                                                                                                                                                             |                |
|       |          |       | 0xF = Data transfer is 16 bits in length.                                                                                                                                                                                                                                                   |                |
| 31:28 | -        |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                             | NA             |

# Table 193. SPI Transmitter Data and Control register (TXDATCTL, addresses 0x4005 8018 (SPI0), 0x4005 C018 (SPI1)) bit description ...continued

### 14.6.8 SPI Transmitter Data Register

The TXDAT register is written in order to send data via the SPI transmitter when control information is not changing during the transfer (see <u>Section 14.6.7</u>). That data will be sent to the transmit shift register when it is available, and another character may then be written to TXDAT.

| Bit   | Symbol | Description                                                                     | Reset<br>value |
|-------|--------|---------------------------------------------------------------------------------|----------------|
| 15:0  | DATA   | Transmit Data. This field provides from 4 to 16 bits of data to be transmitted. | 0              |
| 31:16 | -      | Reserved. Only zero should be written.                                          | NA             |

# Table 194. SPI Transmitter Data Register (TXDAT, addresses 0x4005 801C (SPI0), 0x4005 C01C (SPI1)) bit description

#### 14.6.9 SPI Transmitter Control register

The TXCTL register provides a way to separately access control information for the SPI. These bits are another view of the same-named bits in the TXDATCTL register (see <u>Section 14.6.7</u>). Changing bits in TXCTL has no effect unless data is later written to the TXDAT register. Data written to TXDATCTL overwrites the TXCTL register.

When control information needs to be changed during transmission, the TXDATCTL register should be used (see <u>Section 14.6.7</u>) instead of TXDAT. Control information can then be written along with data.

# Table 195. SPI Transmitter Control register (TXCTL, addresses 0x4005 8020 (SPI0), 0x4005 C020 (SPI1)) bit description

| Bit   | Symbol    | Description                                                     | Reset<br>value |
|-------|-----------|-----------------------------------------------------------------|----------------|
| 15:0  | -         | Reserved. Read value is undefined, only zero should be written. | NA             |
| 16    | TXSSEL0_N | Transmit Slave Select 0.                                        | 0x0            |
| 17    | TXSSEL1_N | Transmit Slave Select 1.                                        | 0x0            |
| 18    | TXSSEL2_N | Transmit Slave Select 2.                                        | 0x0            |
| 19    | TXSSEL3_n | Transmit Slave Select 3.                                        | 0x0            |
| 20    | EOT       | End of Transfer.                                                | 0              |
| 21    | EOF       | End of Frame.                                                   | 0              |
| 22    | RXIGNORE  | Receive Ignore.                                                 | 0              |
| 23    | -         | Reserved. Read value is undefined, only zero should be written. | NA             |
| 27:24 | LEN       | Data transfer Length.                                           | 0x0            |
| 31:28 | -         | Reserved. Read value is undefined, only zero should be written. | NA             |

#### 14.6.10 SPI Divider register

The DIV register determines the clock used by the SPI in master mode.

For details on clocking, see Section 14.7.3 "Clocking and data rates".

|       | description |                                                                                                                                                                              |                |  |  |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| Bit   | Symbol      | Description                                                                                                                                                                  | Reset<br>Value |  |  |
| 15:0  | DIVVAL      | Rate divider value. Specifies how the PCLK for the SPI is divided to produce the SPI clock rate in master mode.                                                              | 0              |  |  |
|       |             | DIVVAL is -1 encoded such that the value 0 results in PCLK/1, the value 1 results in PCLK/2, up to the maximum possible divide value of 0xFFFF, which results in PCLK/65536. |                |  |  |
| 31:16 | -           | Reserved. Read value is undefined, only zero should be written.                                                                                                              | NA             |  |  |

# Table 196. SPI Divider register (DIV, addresses 0x4005 8024 (SPI0), 0x4005 C024 (SPI1)) bit description

### 14.6.11 SPI Interrupt Status register

The read-only INTSTAT register provides a view of those interrupt flags that are currently enabled. This can simplify software handling of interrupts. See <u>Table 189</u> for detailed descriptions of the interrupt flags.

| Table 197. | SPI Interrupt Status register (INTSTAT, addresses 0x4005 8028 (SPI0), 0x4005 |
|------------|------------------------------------------------------------------------------|
|            | C028 (SPI1)) bit description                                                 |

| Bit  | Symbol | Description                                                     | Reset<br>value |
|------|--------|-----------------------------------------------------------------|----------------|
| 0    | RXRDY  | Receiver Ready flag.                                            | 0              |
| 1    | TXRDY  | Transmitter Ready flag.                                         | 1              |
| 2    | RXOV   | Receiver Overrun interrupt flag.                                | 0              |
| 3    | TXUR   | Transmitter Underrun interrupt flag.                            | 0              |
| 4    | SSA    | Slave Select Assert.                                            | 0              |
| 5    | SSD    | Slave Select Deassert.                                          | 0              |
| 31:6 | -      | Reserved. Read value is undefined, only zero should be written. | NA             |

# 14.7 Functional description

# 14.7.1 Operating modes: clock and phase selection

SPI interfaces typically allow configuration of clock phase and polarity. These are sometimes referred to as numbered SPI modes, as described in <u>Table 198</u> and shown in Figure 24. CPOL and CPHA are configured by bits in the CFG register (Section 14.6.1).

| Table 198. SPI mode summary |      |             |                                                                                                                                                                            |                |         |                      |  |  |  |
|-----------------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|----------------------|--|--|--|
| CPOL                        | СРНА | SPI<br>Mode | Description                                                                                                                                                                | SCK rest state |         | SCK data sample edge |  |  |  |
| 0                           | 0    | 0           | The SPI captures serial data on the first clock transition of<br>the transfer (when the clock changes away from the rest<br>state). Data is changed on the following edge. | low            | falling | rising               |  |  |  |
| 0                           | 1    | 1           | The SPI changes serial data on the first clock transition of<br>the transfer (when the clock changes away from the rest<br>state). Data is captured on the following edge. | low            | rising  | falling              |  |  |  |
| 1                           | 0    | 2           | Same as mode 0 with SCK inverted.                                                                                                                                          | high           | rising  | falling              |  |  |  |
| 1                           | 1    | 3           | Same as mode 1 with SCK inverted.                                                                                                                                          | high           | falling | rising               |  |  |  |





### 14.7.2 Frame delays

Several delays can be specified for SPI frames. These include:

- Pre\_delay: delay after SSEL is asserted before data clocking begins
- Post\_delay: delay at the end of a data frame before SSEL is de-asserted
- Frame\_delay: delay between data frames when SSEL is not de-asserted
- Transfer\_delay: minimum duration of SSEL in the de-asserted state between transfers

#### 14.7.2.1 **Pre\_delay and Post\_delay**

Pre\_delay and Post\_delay are illustrated by the examples in Figure 25. The Pre\_delay value controls the amount of time between SSEL being asserted and the beginning of the subsequent data frame. The Post\_delay value controls the amount of time between the end of a data frame and the de-assertion of SSEL.



#### 14.7.2.2 Frame\_delay

The Frame\_delay value controls the amount of time at the end of each frame. This delay is inserted when the EOF bit = 1. Frame\_delay is illustrated by the examples in Figure 26. Note that frame boundaries occur only where specified. This is because frame lengths can be any size, involving multiple data writes. See Section 14.7.6 for more information.



**User manual** 

### 14.7.2.3 Transfer\_delay

The Transfer\_delay value controls the minimum amount of time that SSEL is de-asserted between transfers, because the EOT bit = 1. When Transfer\_delay = 0, SSEL may be de-asserted for a minimum of one SPI clock time. Transfer\_delay is illustrated by the examples in Figure 27.



**User manual** 

### 14.7.3 Clocking and data rates

In order to use the SPI, clocking details must be defined. This includes configuring the system clock and selection of the clock divider value in DIV. See Figure 22.

#### 14.7.3.1 Data rate calculations

The SPI interface is designed to operate asynchronously from any on-chip clocks, and without the need for overclocking.

In slave mode, this means that the SCK from the external master is used directly to run the transmit and receive shift registers and other logic.

In master mode, the SPI rate clock produced by the SPI clock divider is used directly as the outgoing SCK.

The SPI clock divider is an integer divider. The SPI in master mode can be set to run at the same speed as the selected PCLK, or at lower integer divide rates. The SPI rate will be = PCLK\_SPIn / DIVVAL.

In slave mode, the clock is taken from the SCK input and the SPI clock divider is not used.

#### 14.7.4 Slave select

The SPI block provides for four Slave Select inputs in slave mode or outputs in master mode. Each SSEL can be set for normal polarity (active low), or can be inverted (active high). Representation of the 4 SSELs in a register is always active low. If an SSEL is inverted, this is done as the signal leaves/enters the SPI block.

In slave mode, **any** asserted SSEL that is connected to a pin will activate the SPI. In master mode, all SSELs that are connected to a pin will be output as defined in the SPI registers. In the latter case, the SSELs could potentially be decoded externally in order to address more than four slave devices. Note that at least one SSEL is asserted when data is transferred in master mode.

In master mode, Slave Selects come from the SSELN field, which appears in both the CTL and DATCTL registers. In slave mode, the state of all four SSELs is saved along with received data in the RXSSEL\_N field of the RXDAT register.

### 14.7.5 DMA operation

A DMA request is provided for each SPI direction, and can be used in lieu of interrupts for transferring data by configuring the DMA controller appropriately, and enabling the Rx and/or Tx DMA via the CFG register. The DMA controller provides an acknowledgement signal that clears the related request when it completes handling that request.

The transmitter DMA request is asserted when Tx DMA is enabled and the transmitter can accept more data.

The receiver DMA request is asserted when Rx DMA is enabled and received data is available to be read.

#### 14.7.6 Data lengths greater than 16 bits

The SPI interface handles data frame sizes from 1 to 16 bits directly. Larger sizes can be handled by splitting data up into groups of 16 bits or less. For example, 24 bits can be supported as 2 groups of 16 bits and 8 bits or 2 groups of 12 bits, among others. Frames of any size, including greater than 32 bits, can supported in the same way.

Details of how to handle larger data widths depend somewhat on other SPI configuration options. For instance, if it is intended for Slave Selects to be de-asserted between frames, then this must be suppressed when a larger frame is split into more than one part. Sending 2 groups of 12 bits with SSEL de-asserted between 24-bit increments, for instance, would require changing the value of the EOF bit on alternate 12-bit frames.

#### 14.7.7 Data stalls

A stall for Master transmit data can happen in modes 0 and 2 when SCK cannot be returned to the rest state until the MSB of the next data frame can be driven on MOSI. In this case, the stall happens just before the final clock edge of data if the next piece of data is not yet available.

A stall for Master receive can happen when a receiver overrun would otherwise occur if the transmitter was not stalled. In modes 0 and 2, this occurs if the previously received data is not read before the end of the next piece of is received. This stall happens one clock edge earlier than the transmitter stall.

In modes 1 and 3, the same kind of receiver stall can occur, but just before the final clock edge of the received data. Also, a transmitter stall will not happen in modes 1 and 3 because the transmitted data is complete at the point where a stall would otherwise occur, so it is not needed.

Stalls are reflected in the STAT register by the Stalled status flag, which indicates the current SPI status.



# **UM11021**

# Chapter 15: LPC83x I2C0

Rev. 1.1 — 5 October 2016

**User manual** 

# 15.1 How to read this chapter

One I2C interface is available on all parts depending on the switch matrix configuration.

Read this chapter if you want to understand the I2C operation and the software interface and want to learn how to use the I2C for wake-up from reduced power modes.

# 15.2 Features

- 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.
- Supports the I<sup>2</sup>C-bus specification up to Fast-mode Plus (up to 1 MHz).

# **15.3 Basic configuration**

Configure the I2C interfaces using the following registers:

- In the SYSAHBCLKCTRL register, set the corresponding bits to enable the clocks to the register interfaces. See <u>Table 33</u>.
- Clear the I2C peripheral resets using the PRESETCTRL register (Table 21).
- Enable/disable the I2C interrupt in interrupt slots #8 in the NVIC. See Table 4.
- Configure the I2C pin functions through the switch matrix. See <u>Table 199</u>.
- The peripheral clock for the I2C is the system clock (see Figure 29).



# 15.3.1 I2C transmit/receive in master mode

In this example, the I2C is configured as the master. The master sends 8 bits to the slave and then receives 8 bits from the slave. The system clock is set to 30 MHz and the bit rate is approximately 400 kHz. You must enable the I2C0\_SCL and I2C0\_SDA functions on pins PIO0\_11 and PIO0\_10 or assign the SCL and SDA functions for any of the other I2C blocks to pins through the switch matrix. See <u>Table 199</u>.

For a 400 kHz bit rate, the I2C0 pins can be configured in standard mode in the IOCON block. See <u>Table 87 "PIO0\_11 register (PIO0\_11, address 0x4004 401C) bit description</u>" and <u>Table 88 "PIO0\_10 register (PIO0\_10, address 0x4004 4020) bit description</u>".

The transmission of the address and data bits is controlled by the state of the MSTPENDING status bit. Whenever the status is Master pending, the master can read or write to the MSTDAT register and go to the next step of the transmission protocol by writing to the MSTCTL register.

Configure the I2C bit rate:

- Divide the system clock (I2C\_PCLK) by a factor of 2. See <u>Table 208 "I<sup>2</sup>C Clock</u> Divider register (CLKDIV, address 0x4005 0014 (I2C0)) bit description".
- Set the SCL high and low times to 2 clock cycles each. This is the default. See <u>Table 211 "Master Time register (MSTTIME, address 0x4005 0024 (I2C0)) bit</u> <u>description</u>". The result is an SCL clock of 375 kHz.

#### 15.3.1.1 Master write to slave

Configure the I2C as master: Set the MSTEN bit to 1 in the CFG register. See <u>Table 201</u>.

Write data to the slave:

- 1. Write the slave address with the RW bit set to 0 to the Master data register MSTDAT. See <u>Table 212</u>.
- 2. Start the transmission by setting the MSTSTART bit to 1 in the Master control register. See <u>Table 210</u>. The following happens:
  - The pending status is cleared and the I2C-bus is busy.
  - The I2C master sends the start bit and address with the RW bit to the slave.
- 3. Wait for the pending status to be set (MSTPENDING = 1) by polling the STAT register.
- 4. Write 8 bits of data to the MSTDAT register.
- Continue with the transmission of data by setting the MSTCONT bit to 1 in the Master control register. See <u>Table 210</u>. The following happens:
  - The pending status is cleared and the I2C-bus is busy.
  - The I2C master sends the data bits to the slave address.
- 6. Wait for the pending status to be set (MSTPENDING = 1) by polling the STAT register.
- 7. Stop the transmission by setting the MSTSTOP bit to 1 in the Master control register. See <u>Table 210</u>.

#### 15.3.1.2 Master read from slave

Configure the I2C as master: Set the MSTEN bit to 1 in the CFG register. See Table 201.

Read data from the slave:

- 1. Write the slave address with the RW bit set to 1 to the Master data register MSTDAT. See <u>Table 212</u>.
- Start the transmission by setting the MSTSTART bit to 1 in the Master control register. See <u>Table 210</u>. The following happens:
  - The pending status is cleared and the I2C-bus is busy.
  - The I2C master sends the start bit and address with the RW bit to the slave.
  - The slave sends 8 bit of data.
- 3. Wait for the pending status to be set (MSTPENDING = 1) by polling the STAT register.
- 4. Read 8 bits of data from the MSTDAT register.
- Stop the transmission by setting the MSTSTOP bit to 1 in the Master control register. See <u>Table 210</u>.

#### 15.3.2 I2C receive/transmit in slave mode

In this example, the I2C is configured as the slave. The slave receives 8 bits from the master and sends 8 bits to the slave. The system clock is set to 30 MHz and the bit rate is approximately 400 kHz. You must enable the I2C0\_SCL and I2C0\_SDA functions on pins PIO0\_11 and PIO0\_10 or assign the SCL and SDA functions for any of the other I2C blocks to pins through the switch matrix. See Table 199.

For a 400 kHz bit rate, the pins can be configured in standard mode in the IOCON block. See <u>Table 87 "PIO0\_11 register (PIO0\_11, address 0x4004 401C) bit description</u>" and Table 88 "PIO0\_10 register (PIO0\_10, address 0x4004 4020) bit description".

The transmission of the address and data bits is controlled by the state of the SLVPENDING status bit. Whenever the status is Slave pending, the slave can acknowledge ("ack") or send or receive an address and data. The received data or the data to be sent to the master are available in the SLVDAT register. After sending and receiving data, continue to the next step of the transmission protocol by writing to the SLVCTL register.

#### 15.3.2.1 Slave read from master

Configure the I2C as slave with address x:

- Set the SLVEN bit to 1 in the CFG register. See Table 201.
- Write the slave address x to the address 0 match register. See Table 215.

Read data from the master:

- 1. Wait for the pending status to be set (SLVPENDING = 1) by polling the STAT register.
- Acknowledge ("ack") the address by setting SLVCONTINUE = 1 in the slave control register. See <u>Table 213</u>.
- 3. Wait for the pending status to be set (SLVPENDING = 1) by polling the STAT register.
- 4. Read 8 bits of data from the SLVDAT register. See <u>Table 214</u>.
- Acknowledge ("ack") the data by setting SLVCONTINUE = 1 in the slave control register. See <u>Table 213</u>.

#### 15.3.2.2 Slave write to master

- Set the SLVEN bit to 1 in the CFG register. See <u>Table 201</u>.
- Write the slave address x to the address 0 match register. See <u>Table 215</u>.

Write data to the master:

- 1. Wait for the pending status to be set (SLVPENDING = 1) by polling the STAT register.
- 2. ACK the address by setting SLVCONTINUE = 1 in the slave control register. See Table 213.
- 3. Wait for the pending status to be set (SLVPENDING = 1) by polling the STAT register.
- 4. Write 8 bits of data to SLVDAT register. See <u>Table 214</u>.
- Continue the transaction by setting SLVCONTINUE = 1 in the slave control register. See <u>Table 213</u>.

#### 15.3.3 Configure the I2C for wake-up

In sleep mode, any activity on the I2C-bus that triggers an I2C interrupt can wake up the part, provided that the interrupt is enabled in the INTENSET register and the NVIC. As long as the I2C clock I2C\_PCLK remains active in sleep mode, the I2C can wake up the part independently of whether the I2C block is configured in master or slave mode.

In Deep-sleep or Power-down mode, the I2C clock is turned off as are all peripheral clocks. However, if the I2C is configured in slave mode and an external master on the I2C-bus provides the clock signal, the I2C block can create an interrupt asynchronously. This interrupt, if enabled in the NVIC and in the I2C block's INTENCLR register, can then wake up the core.

#### 15.3.3.1 Wake-up from Sleep mode

- Enable the I2C interrupt in the NVIC.
- Enable the I2C wake-up event in the I2C INTENSET register. Wake-up on any enabled interrupts is supported (see the INTENSET register). Examples are the following events:
  - Master pending
  - Change to idle state
  - Start/stop error
  - Slave pending
  - Address match (in slave mode)
  - Data available/ready

#### 15.3.3.2 Wake-up from Deep-sleep and Power-down modes

- Enable the I2C interrupt in the NVIC.
- Enable the I2C interrupt in the STARTERP1 register in the SYSCON block to create the interrupt signal asynchronously while the core and the peripheral are not clocked. See <u>Table 49 "Start logic 1 interrupt wake-up enable register (STARTERP1, address</u> 0x4004 8214) bit description".

- In the PDAWAKE register, configure all peripherals that need to be running when the part wakes up.
- Configure the I2C in slave mode.
- Enable the I2C the interrupt in the I2C INTENCLR register which configures the interrupt as wake-up event. Examples are the following events:
  - Slave deselect
  - Slave pending (wait for read, write, or ACK)
  - Address match
  - Data available/ready for the monitor

# **15.4 Pin description**

The I2C0 pins are fixed-pin functions and enabled through the switch matrix.

If the I2C0-bus interface is used in Fast-mode Plus mode, configure the I2C-pins for this mode in the IOCON block: <u>Table 87 "PIO0\_11 register (PIO0\_11, address 0x4004 401C)</u> bit description" and <u>Table 88 "PIO0\_10 register (PIO0\_10, address 0x4004 4020) bit</u> description".

#### Table 199. I2C-bus pin description

| Function | Direction | Туре               | Connect<br>to | Use register | Reference | Description        |
|----------|-----------|--------------------|---------------|--------------|-----------|--------------------|
| I2C0_SDA | I/O       | external<br>to pin | PIO0_11       | PINENABLE0   | Table 76  | I2C0 serial data.  |
| I2C0_SCL | I/O       | external<br>to pin | PIO0_10       | PINENABLE0   | Table 76  | I2C0 serial clock. |

# **15.5 General description**

The architecture of the I2C-bus interface is shown in Figure 30.



**User manual** 

# **15.6 Register description**

The register functions can be grouped as follows:

- Common registers:
  - <u>Table 201 "I2C Configuration register (CFG, address 0x4005 0000 (I2C0)) bit</u> <u>description"</u>
  - Table 202 "I<sup>2</sup>C Status register (STAT, address 0x4005 0004 (I2C0)) bit description"
  - <u>Table 209 "I<sup>2</sup>C Interrupt Status register (INTSTAT, address 0x4005 0018 (I2C0)) bit</u> <u>description</u>"
  - Table 205 "Interrupt Enable Set and read register (INTENSET, address 0x4005 0008 (I2C0)) bit description"
  - <u>Table 206 "Interrupt Enable Clear register (INTENCLR, address 0x4005 000C</u> (I2C0)) bit description"
  - <u>Table 207 "Time-out value register (TIMEOUT, address 0x4005 0010 (I2C0)) bit</u> <u>description"</u>
  - <u>Table 208 "I<sup>2</sup>C Clock Divider register (CLKDIV, address 0x4005 0014 (I2C0)) bit</u> description"
- Master function registers:
  - <u>Table 210 "Master Control register (MSTCTL, address 0x4005 0020 (I2C0)) bit</u> <u>description"</u>
  - <u>Table 211 "Master Time register (MSTTIME, address 0x4005 0024 (I2C0)) bit</u> <u>description</u>"
  - <u>Table 212 "Master Data register (MSTDAT, address 0x4005 0028 (I2C0)) bit</u> <u>description"</u>
- Slave function registers:
  - Table 213 "Slave Control register (SLVCTL, address 0x4005 0040 (I2C0)) bit description"
  - <u>Table 213 "Slave Control register (SLVCTL, address 0x4005 0040 (I2C0)) bit</u> <u>description"</u>
  - <u>Table 215 "Slave Address registers (SLVADR[0:3], address 0x4005 0048</u> (SLVADR0) to 0x4005 0054 (SLVADR3) (I2C0)) bit description"</u>
  - Table 216 "Slave address Qualifier 0 register (SLVQUAL0, address 0x4005 0058 (I2C0)) bit description"
- Monitor function register: <u>Table 217</u> "Monitor data register (MONRXDAT, address 0x4005 0080 (I2C0)) bit description"

| Name     | Access | Offset | Description                                                                                                                                   | Reset<br>value | Reference        |
|----------|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| CFG      | R/W    | 0x00   | Configuration for shared functions.                                                                                                           | 0              | Table 201        |
| STAT     | R/W    | 0x04   | Status register for Master, Slave, and Monitor functions.                                                                                     | 0x00080<br>1   | <u>Table 202</u> |
| INTENSET | R/W    | 0x08   | Interrupt Enable Set and read register.                                                                                                       | 0              | Table 205        |
| INTENCLR | W      | 0x0C   | Interrupt Enable Clear register.                                                                                                              | NA             | Table 206        |
| TIMEOUT  | R/W    | 0x10   | Time-out value register.                                                                                                                      | 0xFFFF         | Table 207        |
| CLKDIV   | R/W    | 0x14   | Clock pre-divider for the entire I <sup>2</sup> C block. This determines what time increments are used for the MSTTIME and SLVTIME registers. | 0              | <u>Table 208</u> |
| INTSTAT  | R      | 0x18   | Interrupt Status register for Master, Slave, and Monitor functions.                                                                           | 0              | Table 209        |
| MSTCTL   | R/W    | 0x20   | Master control register.                                                                                                                      | 0              | Table 210        |
| MSTTIME  | R/W    | 0x24   | Master timing configuration.                                                                                                                  | 0x77           | Table 211        |
| MSTDAT   | R/W    | 0x28   | Combined Master receiver and transmitter data register.                                                                                       | NA             | Table 212        |
| SLVCTL   | R/W    | 0x40   | Slave control register.                                                                                                                       | 0              | Table 213        |
| SLVDAT   | R/W    | 0x44   | Combined Slave receiver and transmitter data register.                                                                                        | NA             | Table 214        |
| SLVADR0  | R/W    | 0x48   | Slave address 0.                                                                                                                              | 0x01           | Table 215        |
| SLVADR1  | R/W    | 0x4C   | Slave address 1.                                                                                                                              | 0x01           | Table 215        |
| SLVADR2  | R/W    | 0x50   | Slave address 2.                                                                                                                              | 0x01           | Table 215        |
| SLVADR3  | R/W    | 0x54   | Slave address 3.                                                                                                                              | 0x01           | Table 215        |
| SLVQUAL0 | R/W    | 0x58   | Slave Qualification for address 0.                                                                                                            | 0              | Table 216        |
| MONRXDAT | RO     | 0x80   | Monitor receiver data register.                                                                                                               | 0              | Table 217        |

#### Table 200. Register overview: I2C (base address 0x4005 0000 (I2C0))

# 15.6.1 I2C Configuration register

The CFG register contains mode settings that apply to Master, Slave, and Monitor functions.

| Bit | Symbol  | Value | Description                                                                                                                                       | Reset<br>Value |
|-----|---------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | MSTEN   |       | Master Enable. When disabled, configurations settings for<br>the Master function are not changed, but the Master<br>function is internally reset. | 0              |
|     |         | 0     | Disabled. The I <sup>2</sup> C Master function is disabled.                                                                                       |                |
|     |         | 1     | Enabled. The I <sup>2</sup> C Master function is enabled.                                                                                         |                |
| 1   | 1 SLVEN |       | Slave Enable. When disabled, configurations settings for<br>the Slave function are not changed, but the Slave function<br>is internally reset.    | 0              |
|     |         | 0     | Disabled. The I <sup>2</sup> C slave function is disabled.                                                                                        | 1              |
|     |         | 1     | Enabled. The I <sup>2</sup> C slave function is enabled.                                                                                          |                |

| Bit  | Symbol    | Value | Description                                                                                                                                                                                                                                                  | Reset<br>Value |
|------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 2    | MONEN     |       | Monitor Enable. When disabled, configurations settings for<br>the Monitor function are not changed, but the Monitor<br>function is internally reset.                                                                                                         | 0              |
|      |           | 0     | Disabled. The I <sup>2</sup> C monitor function is disabled.                                                                                                                                                                                                 |                |
|      |           | 1     | Enabled. The I <sup>2</sup> C monitor function is enabled.                                                                                                                                                                                                   |                |
| 3    | TIMEOUTEN |       | I <sup>2</sup> C bus Time-out Enable. When disabled, the time-out function is internally reset.                                                                                                                                                              | 0              |
|      |           | 0     | Disabled. Time-out function is disabled.                                                                                                                                                                                                                     |                |
|      |           | 1     | Enabled. Time-out function is enabled. Both types of time-out flags will be generated and will cause interrupts if they are enabled. Typically, only one time-out will be used in a system.                                                                  | -              |
| 4    | MONCLKSTR |       | Monitor function Clock Stretching.                                                                                                                                                                                                                           | 0              |
| 4    |           | 0     | Disabled. The monitor function will not perform clock<br>stretching. Software or DMA may not always be able to<br>read data provided by the monitor function before it is<br>overwritten. This mode may be used when non-invasive<br>monitoring is critical. | -              |
|      |           | 1     | Enabled. The monitor function will perform clock stretching<br>in order to ensure that software or DMA can read all<br>incoming data supplied by the monitor function.                                                                                       |                |
| 31:5 | -         |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                              | NA             |

 Table 201. I2C Configuration register (CFG, address 0x4005 0000 (I2C0)) bit description

### 15.6.2 I2C Status register

The STAT register provides status flags and state information about all of the functions of the I<sup>2</sup>C block. Some information in this register is read-only and some flags can be cleared by writing a 1 to them.

Access to bits in this register varies. RO = Read-only, W1 = write 1 to clear.

Details on the master and slave states described in the MSTSTATE and SLVSTATE bits in this register are listed in <u>Table 203</u> and <u>Table 204</u>.

| Table 2 | 02. I <sup>2</sup> | C Status | registe | r (STAT | , address | 0x4005 | 0004 | (I2C0)) I | bit descr | iption |
|---------|--------------------|----------|---------|---------|-----------|--------|------|-----------|-----------|--------|
|         |                    |          |         |         |           |        |      |           |           |        |

| Bit | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset<br>value | Access |
|-----|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 0   | MSTPENDING |       | Master Pending. Indicates that the Master is waiting to continue communication on the I2C-bus (pending) or is idle. When the master is pending, the MSTSTATE bits indicate what type of software service if any the master expects. This flag will cause an interrupt when set if, enabled via the INTENSET register. The MSTPENDING flag is not set when the DMA is handling an event (if the MSTDMA bit in the MSTCTL register is set). If the master is in the idle state, and no communication is needed, mask this interrupt. | 1              | RO     |
|     |            | 0     | In progress. Communication is in progress and the Master function is busy and cannot currently accept a command.                                                                                                                                                                                                                                                                                                                                                                                                                   |                |        |
|     |            | 1     | Pending. The Master function needs software service or is in the idle state. If the master is not in the idle state, it is waiting to receive or transmit data or the NACK bit.                                                                                                                                                                                                                                                                                                                                                    | -              |        |
| 3:1 | MSTSTATE   |       | Master State code. The master state code reflects the master state<br>when the MSTPENDING bit is set, that is the master is pending or in<br>the idle state. Each value of this field indicates a specific required<br>service for the Master function. All other values are reserved.                                                                                                                                                                                                                                             | 0              | RO     |
|     |            | 0x0   | Idle. The Master function is available to be used for a new transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                           | -              |        |
|     |            | 0x1   | Receive ready. Received data available (Master Receiver mode).<br>Address plus Read was previously sent and Acknowledged by slave.                                                                                                                                                                                                                                                                                                                                                                                                 | _              |        |
|     |            | 0x2   | Transmit ready. Data can be transmitted (Master Transmitter mode).<br>Address plus Write was previously sent and Acknowledged by slave.                                                                                                                                                                                                                                                                                                                                                                                            | _              |        |
|     |            | 0x3   | NACK Address. Slave NACKed address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -              |        |
|     |            | 0x4   | NACK Data. Slave NACKed transmitted data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | _              |        |
| 4   | MSTARBLOSS |       | Master Arbitration Loss flag. This flag can be cleared by software writing a 1 to this bit. It is also cleared automatically a 1 is written to MSTCONTINUE.                                                                                                                                                                                                                                                                                                                                                                        | 0              | W1     |
|     |            | 0     | No loss. No Arbitration Loss has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |        |
|     |            | 1     | Arbitration loss. The Master function has experienced an Arbitration Loss.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |        |
|     |            |       | At this point, the Master function has already stopped driving the bus<br>and gone to an idle state. Software can respond by doing nothing, or<br>by sending a Start in order to attempt to gain control of the bus when<br>it next becomes idle.                                                                                                                                                                                                                                                                                  |                |        |
| 5   | -          |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | NA             | NA     |

#### Bit Symbol Value Description Reset Access value Master Start/Stop Error flag. This flag can be cleared by software 6 **MSTSTSTPERR** 0 W1 writing a 1 to this bit. It is also cleared automatically a 1 is written to MSTCONTINUE. 0 No Start/Stop Error has occurred. 1 Start/stop error has occurred. The Master function has experienced a Start/Stop Error. A Start or Stop was detected at a time when it is not allowed by the I<sup>2</sup>C specification. The Master interface has stopped driving the bus and gone to an idle state, no action is required. A request for a Start could be made, or software could attempt to insure that the bus has not stalled. Reserved. Read value is undefined, only zero should be written. NA 7 NA SLVPENDING RO 8 Slave Pending. Indicates that the Slave function is waiting to continue 0 communication on the I2C-bus and needs software service. This flag will cause an interrupt when set if enabled via INTENSET. The SLVPENDING flag is not set when the DMA is handling an event (if the SLVDMA bit in the SLVCTL register is set). The SLVPENDING flag is read-only and is automatically cleared when a 1 is written to the SLVCONTINUE bit in the MSTCTL register. In progress. The Slave function does not currently need service. 0 1 Pending. The Slave function needs service. Information on what is needed can be found in the adjacent SLVSTATE field. 10:9 SLVSTATE Slave State code. Each value of this field indicates a specific required 0 RO service for the Slave function. All other values are reserved. Slave address. Address plus R/W received. At least one of the four 0x0 slave addresses has been matched by hardware. Slave receive. Received data is available (Slave Receiver mode). 0x1 Slave transmit. Data can be transmitted (Slave Transmitter mode). 0x2 0x3 Reserved. **SLVNOTSTR** RO 11 Slave Not Stretching. Indicates when the slave function is stretching 1 the I<sup>2</sup>C clock. This is needed in order to gracefully invoke Deep Sleep or Power-down modes during slave operation. This read-only flag reflects the slave function status in real time. 0 Stretching. The slave function is currently stretching the I<sup>2</sup>C bus clock. Deep-Sleep or Power-down mode cannot be entered at this time Not stretching. The slave function is not currently stretching the I<sup>2</sup>C 1 bus clock. Deep-sleep or Power-down mode could be entered at this time.

#### Table 202. I<sup>2</sup>C Status register (STAT, address 0x4005 0004 (I2C0)) bit description ...continued

Symbol

Bit

Reset Access

value

#### 13:12 SLVIDX Slave address match Index. This field is valid when the I<sup>2</sup>C slave 0 RO function has been selected by receiving an address that matches one of the slave addresses defined by any enabled slave address registers, and provides an identification of the address that was matched. It is possible that more than one address could be matched, but only one match can be reported here. Slave address 0 was matched. 0x0 Slave address 1 was matched. 0x1 Slave address 2 was matched. 0x2 Slave address 3 was matched. 0x3 SLVSEL Slave selected flag. SLVSEL is set after an address match when ٥ RO 14 software tells the Slave function to acknowledge the address. It is cleared when another address cycle presents an address that does not match an enabled address on the Slave function, when slave software decides to NACK a matched address, or when there is a Stop detected on the bus. SLVSEL is not cleared if software Nacks data. 0 Not selected. The Slave function is not currently selected. 1 Selected. The Slave function is currently selected. 15 SLVDESEL Slave Deselected flag. This flag will cause an interrupt when set if 0 W1 enabled via INTENSET. This flag can be cleared by writing a 1 to this bit. 0 Not deselected. The Slave function has not become deselected. This does not mean that it is currently selected. That information can be found in the SLVSEL flag. 1 Deselected. The Slave function has become deselected. This is specifically caused by the SLVSEL flag changing from 1 to 0. See the description of SLVSEL for details on when that event occurs. MONRDY Monitor Ready. This flag is cleared when the MONRXDAT register is 0 RO 16 read. 0 No data. The Monitor function does not currently have data available. 1 Data waiting. The Monitor function has data waiting to be read. 0 17 MONOV W1 Monitor Overflow flag. 0 No overrun. Monitor data has not overrun. Overrun. A Monitor data overrun has occurred. This can only happen 1 when Monitor clock stretching not enabled via the MONCLKSTR bit in the CFG register. Writing 1 to this bit clears the flag. MONACTIVE Monitor Active flag. This flag indicates when the Monitor function 0 RO 18 considers the I<sup>2</sup>C bus to be active. Active is defined here as when

#### Table 202. I<sup>2</sup>C Status register (STAT, address 0x4005 0004 (I2C0)) bit description ...continued

Value Description

than a bus Stop.

0

1

some Master is on the bus: a bus Start has occurred more recently

Inactive. The Monitor function considers the I<sup>2</sup>C bus to be inactive.

Active. The Monitor function considers the I<sup>2</sup>C bus to be active.

| Bit   | Symbol                                                          | Value | Description                                                                                                                                                                                                                                                                                                                                                       | Reset<br>value | Access |
|-------|-----------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------|
| 19    | I <sup>2</sup> C bus chang<br>to decide whe<br>This flag will o |       | Monitor Idle flag. This flag is set when the Monitor function sees the I <sup>2</sup> C bus change from active to inactive. This can be used by software to decide when to process data accumulated by the Monitor function. This flag will cause an interrupt when set if enabled via the INTENSET register. The flag can be cleared by writing a 1 to this bit. | 0              | W1     |
|       |                                                                 | 0     | Not idle. The I <sup>2</sup> C bus is not idle, or this flag has been cleared by software.                                                                                                                                                                                                                                                                        | _              |        |
|       |                                                                 | 1     | Idle. The $l^2C$ bus has gone idle at least once since the last time this flag was cleared by software.                                                                                                                                                                                                                                                           |                |        |
| 23:20 | -                                                               |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                   | NA             | NA     |
| 24    | EVENTTIMEOUT                                                    |       | Event Time-out Interrupt flag. Indicates when the time between<br>events has been longer than the time specified by the TIMEOUT<br>register. Events include Start, Stop, and clock edges. The flag is<br>cleared by writing a 1 to this bit. No time-out is created when the<br>I2C-bus is idle.                                                                  | 0              | W1     |
|       |                                                                 | 0     | No time-out. I <sup>2</sup> C bus events have not caused a time-out.                                                                                                                                                                                                                                                                                              |                |        |
|       |                                                                 |       | Event time-out. The time between I <sup>2</sup> C bus events has been longer than the time specified by the I2C TIMEOUT register.                                                                                                                                                                                                                                 | -              |        |
| 25    | SCLTIMEOUT                                                      |       | SCL Time-out Interrupt flag. Indicates when SCL has remained low longer than the time specific by the TIMEOUT register. The flag is cleared by writing a 1 to this bit.                                                                                                                                                                                           | 0              | W1     |
|       |                                                                 | 0     | No time-out. SCL low time has not caused a time-out.                                                                                                                                                                                                                                                                                                              | 1              |        |
|       |                                                                 | 1     | Time-out. SCL low time has caused a time-out.                                                                                                                                                                                                                                                                                                                     | 1              |        |
| 31:26 | -                                                               |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                   | NA             | NA     |

#### Table 202. I<sup>2</sup>C Status register (STAT, address 0x4005 0004 (I2C0)) bit description ...continued

#### Table 203. Master function state codes (MSTSTATE)

| MSTSTATE | Description                                                                                                          | Actions                                                                                      | DMA<br>access<br>allowed |
|----------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------|
| 0x0      | <b>Idle.</b> The Master function is available to be used for a new transaction.                                      | Send a Start or disable MSTPENDING interrupt if the Master function is not needed currently. | No                       |
| 0x1      | Received data is available (Master Receiver mode). Address plus Read was previously sent and Acknowledged by slave.  | Read data and either continue, send a Stop, or send a Repeated Start.                        | Yes                      |
| 0x2      | Data can be transmitted (Master Transmitter mode). Address plus Write was previously sent and Acknowledged by slave. | Send data and continue, or send a Stop or Repeated Start.                                    | Yes                      |
| 0x3      | Slave NACKed address.                                                                                                | Send a Stop or Repeated Start.                                                               | No                       |
| 0x4      | Slave NACKed transmitted data.                                                                                       | Send a Stop or Repeated Start.                                                               | No                       |

#### Table 204. Slave function state codes (SLVSTATE)

| SLV | STATE      | Description                                                                                                | Actions                                                                                                                                                                                                                                                                      | DMA<br>access<br>allowed |
|-----|------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| 0   | SLVST_ADDR | Address plus R/W<br>received. At least one of<br>the 4 slave addresses has<br>been matched by<br>hardware. | Software can further check the address if needed, for instance if a subset of addresses qualified by SLVQUAL0 is to be used. Software can ACK or NACK the address by writing 1 to either SLVCONTINUE or SLVNACK. Also see <u>Section 15.7.3</u> regarding 10-bit addressing. | No                       |
| 1   | SLVST_RX   | Received data is<br>available (Slave Receiver<br>mode).                                                    | Read data reply with an ACK or a NACK.                                                                                                                                                                                                                                       | Yes                      |
| 2   | SLVST_TX   | Data can be transmitted (Slave Transmitter mode).                                                          | Send data.                                                                                                                                                                                                                                                                   | Yes                      |
| 3   | -          | Reserved.                                                                                                  | -                                                                                                                                                                                                                                                                            | -                        |

# 15.6.3 Interrupt Enable Set and read register

The INTENSET register controls which I<sup>2</sup>C status flags generate interrupts. Writing a 1 to a bit position in this register enables an interrupt in the corresponding position in the STAT register, if an interrupt is supported there. Reading INTENSET indicates which interrupts are currently enabled.

| Bit  | Symbol        | Value | Description                                                     | Reset<br>value |
|------|---------------|-------|-----------------------------------------------------------------|----------------|
| 0    | MSTPENDINGEN  |       | Master Pending interrupt Enable.                                | 0              |
|      |               | 0     | The MstPending interrupt is disabled.                           |                |
|      |               | 1     | The MstPending interrupt is enabled.                            |                |
| 3:1  | -             |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 4    | MSTARBLOSSEN  |       | Master Arbitration Loss interrupt Enable.                       | 0              |
|      |               | 0     | The MstArbLoss interrupt is disabled.                           |                |
|      |               | 1     | The MstArbLoss interrupt is enabled.                            |                |
| 5    | -             |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 6    | MSTSTSTPERREN |       | Master Start/Stop Error interrupt Enable.                       | 0              |
|      |               | 0     | The MstStStpErr interrupt is disabled.                          |                |
|      |               | 1     | The MstStStpErr interrupt is enabled.                           |                |
| 7    | -             |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 8    | SLVPENDINGEN  |       | Slave Pending interrupt Enable.                                 | 0              |
|      |               | 0     | The SlvPending interrupt is disabled.                           |                |
|      |               | 1     | The SlvPending interrupt is enabled.                            |                |
| 10:9 | -             |       | Reserved. Read value is undefined, only zero should be written. | NA             |

# Table 205. Interrupt Enable Set and read register (INTENSET, address 0x4005 0008 (I2C0)) bit description

| Bit   | Symbol         | Value | Description                                                     | Reset<br>value |
|-------|----------------|-------|-----------------------------------------------------------------|----------------|
| 11    | SLVNOTSTREN    |       | Slave Not Stretching interrupt Enable.                          | 0              |
|       |                | 0     | The SlvNotStr interrupt is disabled.                            |                |
|       |                | 1     | The SlvNotStr interrupt is enabled.                             |                |
| 14:12 | -              |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 15    | SLVDESELEN     |       | Slave Deselect interrupt Enable.                                | 0              |
|       |                | 0     | The SlvDeSel interrupt is disabled.                             |                |
|       |                | 1     | The SlvDeSel interrupt is enabled.                              |                |
| 16    | MONRDYEN       |       | Monitor data Ready interrupt Enable.                            | 0              |
|       |                | 0     | The MonRdy interrupt is disabled.                               |                |
|       |                | 1     | The MonRdy interrupt is enabled.                                |                |
| 17    | MONOVEN        |       | Monitor Overrun interrupt Enable.                               | 0              |
|       |                | 0     | The MonOv interrupt is disabled.                                |                |
|       |                | 1     | The MonOv interrupt is enabled.                                 |                |
| 18    | -              |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 19    | MONIDLEEN      |       | Monitor Idle interrupt Enable.                                  | 0              |
|       |                | 0     | The MonIdle interrupt is disabled.                              |                |
|       |                | 1     | The MonIdle interrupt is enabled.                               |                |
| 23:20 | -              |       | Reserved. Read value is undefined, only zero should be written. | NA             |
| 24    | EVENTTIMEOUTEN |       | Event time-out interrupt Enable.                                | 0              |
|       |                | 0     | The Event time-out interrupt is disabled.                       |                |
|       |                | 1     | The Event time-out interrupt is enabled.                        |                |
| 25    | SCLTIMEOUTEN   |       | SCL time-out interrupt Enable.                                  | 0              |
|       |                | 0     | The SCL time-out interrupt is disabled.                         |                |
|       |                | 1     | The SCL time-out interrupt is enabled.                          |                |
| 31:26 | -              |       | Reserved. Read value is undefined, only zero should be written. | NA             |

# Table 205. Interrupt Enable Set and read register (INTENSET, address 0x4005 0008 (I2C0)) bit description

# 15.6.4 Interrupt Enable Clear register

Writing a 1 to a bit position in INTENCLR clears the corresponding position in the INTENSET register, disabling that interrupt. INTENCLR is a write-only register.

Bits that do not correspond to defined bits in INTENSET are reserved and only zeroes should be written to them.

| Bit   | Symbol          | Description                                                                                                                 | Reset<br>value |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|----------------|
| 0     | MSTPENDINGCLR   | Master Pending interrupt clear. Writing 1 to this bit clears the corresponding bit in the INTENSET register if implemented. | 0              |
| 3:1   | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 4     | MSTARBLOSSCLR   | Master Arbitration Loss interrupt clear.                                                                                    | 0              |
| 5     | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 6     | MSTSTSTPERRCLR  | Master Start/Stop Error interrupt clear.                                                                                    | 0              |
| 7     | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 8     | SLVPENDINGCLR   | Slave Pending interrupt clear.                                                                                              | 0              |
| 10:9  | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 11    | SLVNOTSTRCLR    | Slave Not Stretching interrupt clear.                                                                                       | 0              |
| 14:12 | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 15    | SLVDESELCLR     | Slave Deselect interrupt clear.                                                                                             | 0              |
| 16    | MONRDYCLR       | Monitor data Ready interrupt clear.                                                                                         | 0              |
| 17    | MONOVCLR        | Monitor Overrun interrupt clear.                                                                                            | 0              |
| 18    | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 19    | MONIDLECLR      | Monitor Idle interrupt clear.                                                                                               | 0              |
| 23:20 | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |
| 24    | EVENTTIMEOUTCLR | Event time-out interrupt clear.                                                                                             | 0              |
| 25    | SCLTIMEOUTCLR   | SCL time-out interrupt clear.                                                                                               | 0              |
| 31:26 | -               | Reserved. Read value is undefined, only zero should be written.                                                             | NA             |

# Table 206. Interrupt Enable Clear register (INTENCLR, address 0x4005 000C (I2C0)) bit description

# 15.6.5 Time-out value register

The TIMEOUT register allows setting an upper limit to certain I<sup>2</sup>C bus times, informing by status flag and/or interrupt when those times are exceeded.

Two time-outs are generated, and software can elect to use either of them.

1. EVENTTIMEOUT checks the time between bus events while the bus is not idle: Start, SCL rising, SCL falling, and Stop. The EVENTTIMEOUT status flag in the STAT register is set if the time between any two events becomes longer than the time configured in the TIMEOUT register. The EVENTTIMEOUT status flag can cause an interrupt if enabled to do so by the EVENTTIMEOUTEN bit in the INTENSET register.

UM11021

Chapter 15: LPC83x I2C0

Also see Section 15.7.2 "Time-out".

flag can cause an interrupt if enabled to do so by the SCLTIMEOUTEN bit in the

INTENSET register. The SCLTIMEOUT can be used with the SMBus.

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                     | Reset<br>value |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   | TOMIN  | Time-out time value, bottom four bits. These are hard-wired to $0xF$ .<br>This gives a minimum time-out of 16 $I^2C$ function clocks and also a time-out resolution of 16 $I^2C$ function clocks.                                                                                               | 0xF            |
| 15:4  | то     | Time-out time value. Specifies the time-out interval value in increments of 16 I <sup>2</sup> C function clocks, as defined by the CLKDIV register. To change this value while I <sup>2</sup> C is in operation, disable all time-outs, write a new value to TIMEOUT, then re-enable time-outs. | 0xFFF          |
|       |        | 0x000 = A time-out will occur after 16 counts of the I <sup>2</sup> C function clock.                                                                                                                                                                                                           |                |
|       |        | 0x001 = A time-out will occur after 32 counts of the I <sup>2</sup> C function clock.                                                                                                                                                                                                           |                |
|       |        | 0xFFF = A time-out will occur after 65,536 counts of the I <sup>2</sup> C function clock.                                                                                                                                                                                                       |                |
| 31:16 | -      | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                 | NA             |

# 15.6.6 Clock Divider register

The CLKDIV register divides down the Peripheral Clock (PCLK) to produce the I<sup>2</sup>C function clock that is used to time various aspects of the I<sup>2</sup>C interface. The I<sup>2</sup>C function clock is used for some internal operations in the I<sup>2</sup>C block and to generate the timing required by the I<sup>2</sup>C bus specification, some of which are user configured in the MSTTIME register for Master operation and the SLVTIME register for Slave operation.

See <u>Section 15.7.1.1 "Rate calculations</u>" for details on bus rate setup.

| Bit   | Symbol | Description                                                                                                                         | Reset<br>value |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | DIVVAL | This field controls how the clock (PCLK) is used by the I <sup>2</sup> C functions that need an internal clock in order to operate. | 0              |
|       |        | 0x0000 = PCLK is used directly by the I <sup>2</sup> C function.                                                                    |                |
|       |        | 0x0001 = PCLK is divided by 2 before use by the I <sup>2</sup> C function.                                                          |                |
|       |        | 0x0002 = PCLK is divided by 3 before use by the I <sup>2</sup> C function.                                                          |                |
|       |        | 0xFFFF = PCLK is divided by 65,536 before use by the I <sup>2</sup> C function.                                                     |                |
| 31:16 | -      | Reserved. Read value is undefined, only zero should be written.                                                                     | NA             |

Table 208. I<sup>2</sup>C Clock Divider register (CLKDIV, address 0x4005 0014 (I2C0)) bit description

# 15.6.7 Interrupt Status register

The INTSTAT register provides register provides a view of those interrupt flags that are currently enabled. This can simplify software handling of interrupts. See <u>Table 202</u> for detailed descriptions of the interrupt flags.

| Bit   | Symbol       | Description                                                     | Reset<br>value |
|-------|--------------|-----------------------------------------------------------------|----------------|
| 0     | MSTPENDING   | Master Pending.                                                 | 1              |
| 3:1   | -            | Reserved.                                                       |                |
| 4     | MSTARBLOSS   | Master Arbitration Loss flag.                                   | 0              |
| 5     | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 6     | MSTSTSTPERR  | Master Start/Stop Error flag.                                   | 0              |
| 7     | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 8     | SLVPENDING   | Slave Pending.                                                  | 0              |
| 10:9  | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 11    | SLVNOTSTR    | Slave Not Stretching status.                                    | 1              |
| 14:12 | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 15    | SLVDESEL     | Slave Deselected flag.                                          | 0              |
| 16    | MONRDY       | Monitor Ready.                                                  | 0              |
| 17    | MONOV        | Monitor Overflow flag.                                          | 0              |
| 18    | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 19    | MONIDLE      | Monitor Idle flag.                                              | 0              |
| 23:20 | -            | Reserved. Read value is undefined, only zero should be written. | NA             |
| 24    | EVENTTIMEOUT | Event time-out Interrupt flag.                                  | 0              |
| 25    | SCLTIMEOUT   | SCL time-out Interrupt flag.                                    | 0              |
| 31:26 | -            | Reserved. Read value is undefined, only zero should be written. | NA             |

Table 209. I<sup>2</sup>C Interrupt Status register (INTSTAT, address 0x4005 0018 (I2C0)) bit description

# 15.6.8 Master Control register

The MSTCTL register contains bits that control various functions of the  $I^2C$  Master interface. Only write to this register when the master is pending (MSTPENDING = 1 in the STAT register, <u>Table 202</u>).

Software should always write a complete value to MSTCTL, and not OR new control bits into the register as is possible in other registers such as CFG. This is due to the fact that MSTSTART and MSTSTOP are not self-clearing flags. ORing in new data following a Start or Stop may cause undesirable side effects.

After an initial I2C Start, MSTCTL should generally only be written when the MSTPENDING flag in the STAT register is set, after the last bus operation has completed. An exception is when DMA is being used and a transfer completes. In this case there is no

MSTPENDING flag, and the MSTDMA control bit would be cleared by software potentially at the same time as setting either the MSTSTOP or MSTSTART control bit.

**Remark:** When in the idle or slave NACKed states (see <u>Table 203</u>), set the MSTDMA bit either with or after the MSTCONTINUE bit. MSTDMA can be cleared at any time.

| Bit      | Symbol      | Value | Description                                                                                                                                                                                                                                                                                                                                                                                           | Reset<br>value |
|----------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0        | MSTCONTINUE |       | Master Continue. This bit is write-only.                                                                                                                                                                                                                                                                                                                                                              | 0              |
|          |             | 0     | No effect.                                                                                                                                                                                                                                                                                                                                                                                            |                |
|          |             | 1     | Continue. Informs the Master function to continue to the next operation. This must done after writing transmit data, reading received data, or any other housekeeping related to the next bus operation.                                                                                                                                                                                              | _              |
| 1        | MSTSTART    |       | Master Start control. This bit is write-only.                                                                                                                                                                                                                                                                                                                                                         | 0              |
|          |             | 0     | No effect.                                                                                                                                                                                                                                                                                                                                                                                            |                |
|          |             | 1     | Start. A Start will be generated on the I <sup>2</sup> C bus at the next allowed time.                                                                                                                                                                                                                                                                                                                |                |
| 2        | MSTSTOP     |       | Master Stop control. This bit is write-only.                                                                                                                                                                                                                                                                                                                                                          | 0              |
|          |             | 0     | No effect.                                                                                                                                                                                                                                                                                                                                                                                            |                |
|          |             | 1     | Stop. A Stop will be generated on the I <sup>2</sup> C bus at the next allowed time, preceded by a NACK to the slave if the master is receiving data from the slave (Master Receiver mode).                                                                                                                                                                                                           |                |
| 3        | 3 MSTDMA    |       | Master DMA enable. Data operations of the I <sup>2</sup> C can be<br>performed with DMA. Protocol type operations such as<br>Start, address, Stop, and address match must always be<br>done with software, typically via an interrupt. When a<br>DMA data transfer is complete, MSTDMA must be<br>cleared prior to beginning the next operation, typically a<br>Start or Stop.This bit is read/write. | 0              |
|          |             | 0     | Disable. No DMA requests are generated for master operation.                                                                                                                                                                                                                                                                                                                                          |                |
|          |             | 1     | Enable. A DMA request is generated for I <sup>2</sup> C master data operations. When this I <sup>2</sup> C master is generating Acknowledge bits in Master Receiver mode, the acknowledge is generated automatically.                                                                                                                                                                                 |                |
| 31:<br>4 | -           |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                       | NA             |

Table 210. Master Control register (MSTCTL, address 0x4005 0020 (I2C0)) bit description

# 15.6.9 Master Time

The MSTTIME register allows programming of certain times that may be controlled by the Master function. These include the clock (SCL) high and low times, repeated Start setup time, and transmitted data setup time.

The I2C clock pre-divider is described in <u>Table 208</u>.

| Bit | Symbol    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                        | Reset<br>value |
|-----|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 2:0 | MSTSCLLOW |       | Master SCL Low time. Specifies the minimum low time that will be asserted by this master on SCL. Other devices on the bus (masters or slaves) could lengthen this time. This corresponds to the parameter $t_{LOW}$ in the I <sup>2</sup> C bus specification. I <sup>2</sup> C bus specification parameters $t_{BUF}$ and $t_{SU;STA}$ have the same values and are also controlled by MSTSCLLOW. | 0              |
|     |           | 0x0   | 2 clocks. Minimum SCL low time is 2 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x1   | 3 clocks. Minimum SCL low time is 3 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x2   | 4 clocks. Minimum SCL low time is 4 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x3   | 5 clocks. Minimum SCL low time is 5 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x4   | 6 clocks. Minimum SCL low time is 6 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              | -              |
|     |           | 0x5   | 7 clocks. Minimum SCL low time is 7 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x6   | 8 clocks. Minimum SCL low time is 8 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|     |           | 0x7   | 9 clocks. Minimum SCL low time is 9 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
| 3   | -         |       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          | 0              |

Table 211. Master Time register (MSTTIME, address 0x4005 0024 (I2C0)) bit description

User manual

# UM11021 Chapter 15: LPC83x I2C0

| Bit  | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                                                        | Reset<br>value |
|------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 6:4  | MSTSCLHIGH |       | Master SCL High time. Specifies the minimum high time that will be asserted by this master on SCL. Other masters in a multi-master system could shorten this time. This corresponds to the parameter $t_{HIGH}$ in the I <sup>2</sup> C bus specification. I <sup>2</sup> C bus specification parameters $t_{SU;STO}$ and $t_{HD;STA}$ have the same values and are also controlled by MSTSCLHIGH. | 0              |
|      |            | 0x0   | 2 clocks. Minimum SCL high time is 2 clock of the $I^2C$ clock pre-divider.                                                                                                                                                                                                                                                                                                                        |                |
|      |            | 0x1   | 3 clocks. Minimum SCL high time is 3 clocks of the ${\rm I}^2{\rm C}$ clock pre-divider .                                                                                                                                                                                                                                                                                                          |                |
|      |            | 0x2   | 4 clocks. Minimum SCL high time is 4 clock of the $I^2C$ clock pre-divider.                                                                                                                                                                                                                                                                                                                        |                |
|      |            | 0x3   | 5 clocks. Minimum SCL high time is 5 clock of the $I^2C$ clock pre-divider.                                                                                                                                                                                                                                                                                                                        |                |
|      |            | 0x4   | 6 clocks. Minimum SCL high time is 6 clock of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|      |            | 0x5   | 7 clocks. Minimum SCL high time is 7 clock of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|      |            | 0x6   | 8 clocks. Minimum SCL high time is 8 clock of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                              |                |
|      |            | 0x7   | 9 clocks. Minimum SCL high time is 9 clocks of the I <sup>2</sup> C clock pre-divider.                                                                                                                                                                                                                                                                                                             |                |
| 31:7 | -          |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                                                                                                                                                                                    | NA             |

Table 211. Master Time register (MSTTIME, address 0x4005 0024 (I2C0)) bit description

# 15.6.10 Master Data register

The MSTDAT register provides the means to read the most recently received data for the Master function, and to transmit data using the Master function.

| Table 212. | Master Data register | (MSTDAT, address 0x4005 | 0028 (I2C0)) bit description |
|------------|----------------------|-------------------------|------------------------------|
|------------|----------------------|-------------------------|------------------------------|

| Bit  | Symbol | Description                                                         | Reset<br>value |
|------|--------|---------------------------------------------------------------------|----------------|
| 7:0  | DATA   | Master function data register.                                      | 0              |
|      |        | Read: read the most recently received data for the Master function. |                |
|      |        | Write: transmit data using the Master function.                     |                |
| 31:8 | -      | Reserved. Read value is undefined, only zero should be written.     | NA             |

# 15.6.11 Slave Control register

The SLVCTL register contains bits that control various functions of the  $I^2C$  Slave interface. Only write to this register when the slave is pending (SLVPENDING = 1 in the STAT register, <u>Table 202</u>). **Remark:** When in the slave address state (slave state 0, see <u>Table 204</u>), set the SLVDMA bit either with or after the SLVCONTINUE bit. SLVDMA can be cleared at any time.

| Bit  | Symbol      | Value | Description                                                                                                                                                                                             | Reset<br>Value |
|------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | SLVCONTINUE |       | Slave Continue.                                                                                                                                                                                         | 0              |
|      |             | 0     | No effect.                                                                                                                                                                                              |                |
|      |             | 1     | Continue. Informs the Slave function to continue to the next operation. This must done after writing transmit data, reading received data, or any other housekeeping related to the next bus operation. |                |
| 1    | SLVNACK     |       | Slave NACK.                                                                                                                                                                                             | 0              |
|      |             | 0     | No effect.                                                                                                                                                                                              |                |
|      |             | 1     | NACK. Causes the Slave function to NACK the master<br>when the slave is receiving data from the master (Slave<br>Receiver mode).                                                                        |                |
| 2    | -           |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                         | NA             |
| 3    | SLVDMA      |       | Slave DMA enable.                                                                                                                                                                                       | 0              |
|      |             | 0     | Disabled. No DMA requests are issued for Slave mode operation.                                                                                                                                          |                |
|      |             | 1     | Enabled. DMA requests are issued for I <sup>2</sup> C slave data transmission and reception.                                                                                                            |                |
| 31:4 | -           |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                         | NA             |

Table 213. Slave Control register (SLVCTL, address 0x4005 0040 (I2C0)) bit description

# 15.6.12 Slave Data register

The SLVDAT register provides the means to read the most recently received data for the Slave function and to transmit data using the Slave function.

| Table 214. Slave Da | ta register (SLVDAT, address | 0x4005 0044 (I2C0)) bit description |
|---------------------|------------------------------|-------------------------------------|
|---------------------|------------------------------|-------------------------------------|

| Bit  | Symbol | Description                                                        | Reset<br>Value |
|------|--------|--------------------------------------------------------------------|----------------|
| 7:0  | DATA   | Slave function data register.                                      | 0              |
|      |        | Read: read the most recently received data for the Slave function. |                |
|      |        | Write: transmit data using the Slave function.                     |                |
| 31:8 | -      | Reserved. Read value is undefined, only zero should be written.    | NA             |

# 15.6.13 Slave Address registers

The SLVADR[0:3] registers allow enabling and defining one of the addresses that can be automatically recognized by the I<sup>2</sup>C slave hardware. The value in the SLVADR0 register is qualified by the setting of the SLVQUAL0 register.

When the slave address is compared to the receive address, the compare can be affected by the setting of the SLVQUAL0 register (see <u>Section 15.6.14</u>).

The I<sup>2</sup>C slave function has 4 address comparators. The additional 3 address comparators do not include the address qualifier feature. For handling of the general call address, one of the 4 address registers can be programmed to respond to address 0.

| Table 215. | Slave Address registers (SLVADR[0:3], address 0x4005 0048 (SLVADR0) to |
|------------|------------------------------------------------------------------------|
|            | 0x4005 0054 (SLVADR3) (I2C0)) bit description                          |

| Bit  | Symbol    | Value | Description                                                                                                     | Reset<br>value |
|------|-----------|-------|-----------------------------------------------------------------------------------------------------------------|----------------|
| 0    | SADISABLE |       | Slave Address n Disable.                                                                                        | 1              |
|      |           | 0     | Enabled. Slave Address n is enabled and will be recognized with any changes specified by the SLVQUAL0 register. |                |
|      |           | 1     | Ignored Slave Address n is ignored.                                                                             |                |
| 7:1  | SLVADR    |       | Seven bit slave address that is compared to received addresses if enabled.                                      | 0              |
| 31:8 | -         |       | Reserved. Read value is undefined, only zero should be written.                                                 | NA             |

# 15.6.14 Slave address Qualifier 0 register

The SLVQUAL0 register can alter how Slave Address 0 is interpreted.

| Table 216. | Slave address Qualifier 0 register (SLVQUAL0, address 0x4005 0058 (I2C0)) bit |  |
|------------|-------------------------------------------------------------------------------|--|
|            | description                                                                   |  |

| Bit  | Symbol    | Value | Description                                                                                                                                                                                                                                | Reset<br>Value |
|------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | QUALMODE0 |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                            | 0              |
|      |           | 0     | The SLVQUAL0 field is used as a logical mask for matching address 0.                                                                                                                                                                       |                |
|      |           | 1     | The SLVQUAL0 field is used to extend address 0 matching in a range of addresses.                                                                                                                                                           |                |
| 7:1  | SLVQUAL0  |       | Slave address Qualifier for address 0. A value of 0 causes the address in SLVADR0 to be used as-is, assuming that it is enabled.                                                                                                           | 0              |
|      |           |       | If QUALMODE0 = 0, any bit in this field which is set to 1<br>will cause an automatic match of the corresponding bit of<br>the received address when it is compared to the<br>SLVADR0 register.                                             |                |
|      |           |       | If QUALMODE0 = 1, an address range is matched for<br>address 0. This range extends from the value defined by<br>SLVADR0 to the address defined by SLVQUAL0 (address<br>matches when SLVADR0[7:1] <= received address <=<br>SLVQUAL0[7:1]). |                |
| 31:8 | -         |       | Reserved. Read value is undefined, only zero should be written.                                                                                                                                                                            | NA             |

# 15.6.15 Monitor data register

The read-only MONRXDAT register provides information about events on the  $I^2C$  bus, primarily to facilitate debugging of the  $I^2C$  during application development. All data addresses and data passing on the bus and whether these were acknowledged, as well as Start and Stop events, are reported.

The Monitor function must be enabled by the MONEN bit in the CFG register. Monitor mode can be configured to stretch the I<sup>2</sup>C clock if data is not read from the MONRXDAT register in time to prevent it, via the MONCLKSTR bit in the CFG register. This can help ensure that nothing is missed but can cause the monitor function to be somewhat intrusive (by potentially adding clock delays, depending on software or DMA response time). In order to improve the chance of collecting all Monitor information if clock stretching is not enabled, Monitor data is buffered such that it is available until the end of the next piece of information from the I<sup>2</sup>C bus.

| Bit   | Symbol     | Value | Description                                                                                                                                                          |    |
|-------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 7:0   | MONRXDAT   |       | Monitor function Receiver Data. This reflects every data byte that passes on the I <sup>2</sup> C pins, and adds indication of Start, Repeated Start, and data NACK. |    |
| 8     | MONSTART   |       | Monitor Received Start.                                                                                                                                              | 0  |
|       |            | 0     | No detect. The monitor function has not detected a Start event on the $I^2C$ bus.                                                                                    |    |
|       |            | 1     | Start detect. The monitor function has detected a Start event on the I <sup>2</sup> C bus.                                                                           |    |
| 9     | MONRESTART |       | Monitor Received Repeated Start.                                                                                                                                     | 0  |
|       |            | 0     | No start detect. The monitor function has not detected a Repeated Start event on the I <sup>2</sup> C bus.                                                           |    |
|       |            | 1     | Repeated start detect. The monitor function has detected a Repeated Start event on the I <sup>2</sup> C bus.                                                         |    |
| 10    | MONNACK    |       | Monitor Received NACK.                                                                                                                                               | 0  |
|       |            | 0     | Acknowledged. The data currently being provided by the monitor function was acknowledged by at least one master or slave receiver.                                   | -  |
|       |            | 1     | Not acknowledged. The data currently being provided by the monitor function was not acknowledged by any receiver.                                                    |    |
| 31:11 | -          |       | Reserved. Read value is undefined, only zero should be written.                                                                                                      | NA |

#### Table 217. Monitor data register (MONRXDAT, address 0x4005 0080 (I2C0)) bit description

# **15.7 Functional description**

### 15.7.1 Bus rates and timing considerations

Due to the nature of the I<sup>2</sup>C bus, it is generally not possible to guarantee a specific clock rate on the SCL pin. On the I2C-bus, the The clock can be stretched by any slave device, extended by software overhead time, etc. In a multi-master system, the master that

provides the shortest SCL high time will cause that time to appear on SCL as long as that master is participating in I2C traffic (i.e. when it is the only master on the bus, or during arbitration between masters).

Rate calculations give a base frequency that represents the fastest that the I<sup>2</sup>C bus could operate if nothing slows it down.

#### 15.7.1.1 Rate calculations

SCL high time (in I<sup>2</sup>C function clocks) = (CLKDIV + 1) \* (MSTSCLHIGH + 2)

SCL low time (in  $I^2C$  function clocks) = (CLKDIV + 1) \* (MSTSCLLOW + 2)

Nominal SCL rate =  $I^2C$  function clock rate / (SCL high time + SCL low time)

#### 15.7.2 Time-out

A time-out feature on an I<sup>2</sup>C interface can be used to detect a "stuck" bus and potentially do something to alleviate the condition. Two different types of time-out are supported. Both types apply whenever the I<sup>2</sup>C block and the time-out function are both enabled, Master, Slave, or Monitor functions do not need to be enabled.

In the first type of time-out, reflected by the EVENTTIMEOUT flag in the STAT register, the time between bus events governs the time-out check. These events include Start, Stop, and all changes on the I<sup>2</sup>C clock (SCL). This time-out is asserted when the time between any of these events is longer than the time configured in the TIMEOUT register. This time-out could be useful in monitoring an I<sup>2</sup>C bus within a system as part of a method to keep the bus running of problems occur.

The second type of I<sup>2</sup>C time-out is reflected by the SCLTIMEOUT flag in the STAT register. This time-out is asserted when the SCL signal remains low longer than the time configured in the TIMEOUT register. This corresponds to SMBus time-out parameter T<sub>TIMEOUT</sub>. In this situation, a slave could reset its own I<sup>2</sup>C interface in case it is the offending device. If all listening slaves (including masters that can be addressed as slaves) do this, then the bus will be released unless it is a current master causing the problem. Refer to the SMBus specification for more details.

Both types of time-out are generated when the I<sup>2</sup>C bus is considered busy.

# 15.7.3 Ten-bit addressing

Ten-bit addressing is accomplished by the I<sup>2</sup>C master sending a second address byte to extend a particular range of standard 7-bit addresses. In the case of the master writing to the slave, the I<sup>2</sup>C frame simply continues with data after the 2 address bytes. For the master to read from a slave, it needs to reverse the data direction after the second address byte. This is done by sending a Repeated Start, followed by a repeat of the same standard 7-bit address, with a Read bit. The slave must remember that it had been addressed by the previous write operation and stay selected for the subsequent read with the correct partial I<sup>2</sup>C address.

For the Master function, the I2C is simply instructed to perform the 2-byte addressing as a normal write operation, followed either by more write data, or by a Repeated Start with a repeat of the first part of the 10-bit slave address and then reading in the normal fashion.

For the Slave function, the first part of the address is automatically matched in the same fashion as 7-bit addressing. The Slave address qualifier feature (see <u>Section 15.6.14</u>) can be used to intercept all potential 10-bit addresses (first address byte values F0 through F6), or just one. In the case of Slave Receiver mode, data is received in the normal fashion after software matches the first data byte to the remaining portion of the 10-bit address. The Slave function should record the fact that it has been addressed, in case there is a follow-up read operation.

For Slave Transmitter mode, the slave function responds to the initial address in the same fashion as for Slave Receiver mode, and checks that it has previously been addressed with a full 10-bit address. If the address matched is address 0, and address qualification is enabled, software must check that the first part of the 10-bit address is a complete match to the previous address before acknowledging the address.

### 15.7.4 Clocking and power considerations

The Master function of the I<sup>2</sup>C always requires a peripheral clock to be running in order to operate. The Slave function can operate without any internal clocking when the slave is not currently addressed. This means that reduced power modes up to Power-down mode can be entered, and the device will wake up when the I<sup>2</sup>C Slave function recognizes an address. Monitor mode can similarly wake up the device from a reduced power mode when information becomes available.

### 15.7.5 Interrupt handling

The I2C provides a single interrupt output that handles all interrupts for Master, Slave, and Monitor functions.

#### 15.7.6 DMA

Generally, data transfers can be handled by DMA for Master mode after an address is sent and acknowledged by a slave, and for Slave mode after software has acknowledged an address. In either mode, software is always involved in the address portion of a message. In master and slave modes, data receive and transmit data can be transferred by the DMA. The DMA supports three DMA requests: data transfer in master mode, slave mode, and monitor mode.

# **UM11021**

Chapter 16: LPC83x SCTimer/PWM

Rev. 1.1 — 5 October 2016

**User manual** 

# 16.1 How to read this chapter

The SCTimer/PWM is available on all parts.

**Remark:** For a detailed description of SCTimer/PWM applications and code examples, see <u>Ref. 5 "AN11538"</u>.

# 16.2 Features

- The SCTimer/PWM supports:
  - Eight match/capture registers.
  - Eight events.
  - Eight states.
  - Four inputs with multiple connection options through the input MUX.
  - Six outputs.
- Counter/timer features:
  - Each SCTimer is configurable as two 16-bit counters or one 32-bit counter.
  - Counters clocked by system clock or selected input.
  - Configurable as up counters or up-down counters.
  - Configurable number of match and capture registers. Up to five match and capture registers total.
  - Upon match and/or an input or output transition create the following events: interrupt; stop, limit, halt the timer or change counting direction; toggle outputs; change the state.
  - Counter value can be loaded into capture register triggered by a match or input/output toggle.
- PWM features:
  - Counters can be used in conjunction with match registers to toggle outputs and create time-proportioned PWM signals.
  - Up to 6 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 an 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 bi-directional mode, events can be enabled based on the count direction.
  - Match events can be held until another qualifying event occurs.

UM11021

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

# **16.3 Basic configuration**

Configure the SCT as follows:

- Enable the clock to the SCTimer/PWM (SCT) in the SYSAHBCLKCTRL register (Table 33) to enable the register interface and the peripheral clock.
- Clear the SCT peripheral reset using the PRESETCTRL register (Table 21).
- The SCT uses interrupt in slot #9 in the NVIC (Table 4).
- Use the INPUT MUX to connect the SCT inputs to external pins. See <u>Table 218</u>.
- Use the switch matrix registers to connect the SCT outputs to external pins. See <u>Table 218</u>.
- The SCT DMA request lines are connected to the DMA trigger inputs via the DMA\_ITRIG\_PINMUX registers. See <u>Table 142 "DMA input trigger Input mux</u> registers 0 to 17 (DMA\_ITRIG\_INMUX[0:17], address 0x4002 80E0 (DMA\_ITRIG\_INMUX0) to 0x4002 8124 (DMA\_ITRIG\_INMUX17)) bit description".

| SYSCON               | SCT        |
|----------------------|------------|
| system clock -       | CLOCK      |
| SYSAHBCLKCTRL[8]     | PROCESSING |
| Fig 31. SCT clocking |            |

#### Chapter 16: LPC83x SCTimer/PWM



# **16.4 Pin description**

| Function                                                     | Туре                                   | Connect to                                                                                                                           | Use register    | Reference       | Description                                                                        |
|--------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|------------------------------------------------------------------------------------|
| SCT input 0,<br>SCT input 1,<br>SCT input 2,<br>SCT input 3, | external<br>to pins or<br>internal     | one of the following:<br>SCT_PIN[0:3] through the<br>switch matrix, or internally to<br>ADC threshold compare<br>interrupt, ARM TXEV | SCT0_INMUX[0:3] | Table 144       | SCT capture and event inputs.                                                      |
| SCT_OUT0                                                     | external<br>to pins                    | pins through the switch matrix                                                                                                       | PINASSIGN7      | Table 71        | SCT match and PWM output.                                                          |
| SCT_OUT1,<br>SCT_OUT2,<br>SCT_OUT3,<br>SCT_OUT4              | external<br>to pins<br>and<br>internal | pins through the switch matrix;<br>to ADC trigger                                                                                    | PINASSIGN8      | Table 72        | SCT match and PWM<br>outputs. SCT_OUT3 can<br>be selected as ADC input<br>trigger. |
| SCT_OUT5                                                     | external<br>to pin                     | pin through the switch matrix                                                                                                        | PINASSIGN9      | <u>Table 72</u> | SCT match and PWM output.                                                          |

#### Table 218. SCT pin description

# **16.5 General description**

The SCTimer/PWM, or in short SCT, is a powerful, flexible timer module capable of creating complex PWM waveforms and performing other advanced timing and control operations with minimal or no CPU intervention.

The SCT can operate as a single 32-bit counter or as two independent, 16-bit counters in uni-directional or bi-directional mode. As with most timers, the SCT supports a selection of match registers against which the count value can be compared, and capture registers where the current count value can be recorded when some pre-defined condition is detected.

An additional feature contributing to the versatility of the SCT is the concept of "events". The SCT module supports multiple separate events that can be defined by the user based on some combination of parameters including a match on one of the match registers, and/or a transition on one of the SCT inputs or outputs, the direction of count, and other factors.

Every action that the SCT block can perform occurs in direct response to one if these user-defined events without any software overhead. Any event can be enabled to:

- Start, stop, or halt the counter.
- Limit the counter which means to clear the counter in uni-directional mode or change its direction in bi-directional mode.
- Set, clear, or toggle any SCT output.
- Force a capture of the count value into any capture registers.
- Generate an interrupt of DMA request.

Regarding states, maybe include something like this:

The SCT allows the user to group and filter events, thereby selecting some events to be enabled together while others are disabled. A group of enabled and disabled events can be described as a state, and several states with different sets of enabled and disabled events are allowed. Changing from one state to another is event driven as well and can therefore happen without software intervention. By defining these states, the SCTimer/PWM provides the means to run entire state machines in hardware with any desired level of complexity to accomplish complex waveform and timing tasks.

In a simple system such as a classical timer/counter with capture and match capabilities. all events that could cause the timer to capture the timer value or toggle a match output are enabled and remain enabled at all times while the counter is running. In this case, no events are filtered and the system is described by one state that does not change. This is the default configuration of the SCT.

In a more complex system, two states could be set up that allow some events in one state and not in the other. An event itself, enabled in both states, can then be used, to move from one state to the other and back while filtering out events in either state. In such a two-state system different waveforms at the SCT output can be created depending on the event history. Changing between states is event-driven and happens without any intervention by the CPU.

Formally, the SCTimer/PWM can be programmed as state machine generator. The ability to perform switching between groups of events provides the SCT the unique capability to be utilized as a highly complex State Machine engine. Events identify the occurrence of conditions that warrant state changes and determine the next state to move to. This provides an extremely powerful control tool - particularly when the SCT inputs and outputs are connected to other on-chip resources (ADC triggers, other timers etc.) in addition to general-purpose I/O.

In addition to events and states, the SCTimer/PWM provides other enhanced features:

- Four alternative clocking modes including a fully asynchronous mode.
- Selection of any SCT input as a clock source or a clock gate.
- Capability of selecting a "greater-than-or-equal-to" match condition for the purpose of

UM11021

event generation.





**Remark:** In this chapter, the term bus error indicates an SCT response that makes the processor take an exception.

# **16.6 Register description**

The register addresses of the State Configurable Timer are shown in <u>Table 219</u>. For most of the SCT registers, the register function depends on the setting of certain other register bits:

UM11021

- The UNIFY bit in the CONFIG register determines whether the SCT is used as one 32-bit register (for operation as one 32-bit counter/timer) or as two 16-bit counter/timers named L and H. The setting of the UNIFY bit is reflected in the register map:
  - UNIFY = 1: Only one register is used (for operation as one 32-bit counter/timer).
  - UNIFY = 0: Access the L and H registers by a 32-bit read or write operation or can be read or written to individually (for operation as two 16-bit counter/timers).

Typically, the UNIFY bit is configured by writing to the CONFIG register before any other registers are accessed.

- 2. The REGMODEn bits in the REGMODE register determine whether each set of Match/Capture registers uses the match or capture functionality:
  - REGMODEn = 0: Registers operate as match and reload registers.
  - REGMODEn = 1: Registers operate as capture and capture control registers.

#### Table 219. Register overview: State Configurable Timer SCT/PWM (base address 0x5000 4000)

| Name      | Access | Address<br>offset | Description                                         | Reset value | Reference        |
|-----------|--------|-------------------|-----------------------------------------------------|-------------|------------------|
| CONFIG    | R/W    | 0x000             | SCT configuration register                          | 0x0000 7E00 | Table 220        |
| CTRL      | R/W    | 0x004             | SCT control register                                | 0x0004 0004 | Table 221        |
| CTRL_L    | R/W    | 0x004             | SCT control register low counter 16-bit             | 0x0004 0004 | Table 221        |
| CTRL_H    | R/W    | 0x006             | SCT control register high counter 16-bit            | 0x0004 0004 | Table 221        |
| LIMIT     | R/W    | 0x008             | SCT limit event select register                     | 0x0000 0000 | Table 222        |
| LIMIT_L   | R/W    | 0x008             | SCT limit event select register low counter 16-bit  | 0x0000 0000 | Table 222        |
| LIMIT_H   | R/W    | 0x00A             | SCT limit event select register high counter 16-bit | 0x0000 0000 | Table 222        |
| HALT      | R/W    | 0x00C             | SCT halt events elect register                      | 0x0000 0000 | Table 223        |
| HALT_L    | R/W    | 0x00C             | SCT halt event select register low counter 16-bit   | 0x0000 0000 | Table 223        |
| HALT_H    | R/W    | 0x00E             | SCT halt event select register high counter 16-bit  | 0x0000 0000 | Table 223        |
| STOP      | R/W    | 0x010             | SCT stop event select register                      | 0x0000 0000 | Table 224        |
| STOP_L    | R/W    | 0x010             | SCT stop event select register low counter 16-bit   | 0x0000 0000 | Table 224        |
| STOP_H    | R/W    | 0x012             | SCT stop event select register high counter 16-bit  | 0x0000 0000 | Table 224        |
| START     | R/W    | 0x014             | SCT start event select register                     | 0x0000 0000 | Table 225        |
| START_L   | R/W    | 0x014             | SCT start event select register low counter 16-bit  | 0x0000 0000 | Table 225        |
| START_H   | R/W    | 0x016             | SCT start event select register high counter 16-bit | 0x0000 0000 | Table 225        |
| -         | -      | 0x018 - 0x03C     | Reserved                                            |             | -                |
| COUNT     | R/W    | 0x040             | SCT counter register                                | 0x0000 0000 | Table 226        |
| COUNT_L   | R/W    | 0x040             | SCT counter register low counter 16-bit             | 0x0000 0000 | Table 226        |
| COUNT_H   | R/W    | 0x042             | SCT counter register high counter 16-bit            | 0x0000 0000 | Table 226        |
| STATE     | R/W    | 0x044             | SCT state register                                  | 0x0000 0000 | Table 227        |
| STATE_L   | R/W    | 0x044             | SCT state register low counter 16-bit               | 0x0000 0000 | Table 227        |
| STATE_H   | R/W    | 0x046             | SCT state register high counter 16-bit              | 0x0000 0000 | Table 227        |
| INPUT     | RO     | 0x048             | SCT input register                                  | 0x0000 0000 | Table 228        |
| REGMODE   | R/W    | 0x04C             | SCT match/capture mode register                     | 0x0000 0000 | Table 229        |
| REGMODE_L | R/W    | 0x04C             | SCT match/capture mode register low counter 16-bit  | 0x0000 0000 | <u>Table 229</u> |

#### UM11021

| Table 219 | . Register overv | view: State Configurabl | e Timer SCT/PWM | (base address 0x5000 4000) | continued |
|-----------|------------------|-------------------------|-----------------|----------------------------|-----------|
|-----------|------------------|-------------------------|-----------------|----------------------------|-----------|

| Name                                  | Access | Address<br>offset | Description                                                                                               | Reset value | Reference        |
|---------------------------------------|--------|-------------------|-----------------------------------------------------------------------------------------------------------|-------------|------------------|
| REGMODE_H                             | R/W    | 0x04E             | SCT match/capture registers mode register high counter 16-bit                                             | 0x0000 0000 | Table 229        |
| OUTPUT                                | R/W    | 0x050             | SCT output register                                                                                       | 0x0000 0000 | Table 230        |
| OUTPUTDIRC<br>TRL                     | R/W    | 0x054             | SCT output counter direction control register                                                             | 0x0000 0000 | <u>Table 231</u> |
| RES                                   | R/W    | 0x058             | SCT conflict resolution register                                                                          | 0x0000 0000 | Table 232        |
| DMAREQ0                               | R/W    | 0x05C             | SCT DMA request 0 register                                                                                | 0x0000 0000 | Table 233        |
| DMAREQ1                               | R/W    | 0x060             | SCT DMA request 1 register                                                                                | 0x0000 0000 | Table 234        |
| -                                     | -      | 0x064 - 0x0EC     | Reserved                                                                                                  | -           | -                |
| EVEN                                  | R/W    | 0x0F0             | SCT event interrupt enable register                                                                       | 0x0000 0000 | Table 235        |
| EVFLAG                                | R/W    | 0x0F4             | SCT event flag register                                                                                   | 0x0000 0000 | Table 236        |
| CONEN                                 | R/W    | 0x0F8             | SCT conflict interrupt enable register                                                                    | 0x0000 0000 | Table 237        |
| CONFLAG                               | R/W    | 0x0FC             | SCT conflict flag register                                                                                | 0x0000 0000 | Table 238        |
| MATCH0 to<br>MATCH7                   | R/W    | 0x100 to 0x11C    | SCT match value register of match channels 0 to 7; REGMOD0 to REGMODE7 = 0                                | 0x0000 0000 | Table 238        |
| MATCH0_L to<br>MATCH7_L               | R/W    | 0x100 to 0x11C    | SCT match value register of match channels 0 to<br>7; low counter 16-bit; REGMOD0_L to<br>REGMODE7_L = 0  | 0x0000 0000 | Table 238        |
| MATCH0_H to<br>MATCH7_H               | R/W    | 0x102 to 0x11E    | SCT match value register of match channels 0 to<br>7; high counter 16-bit; REGMOD0_H to<br>REGMODE7_H = 0 | 0x0000 0000 | <u>Table 238</u> |
| CAP0 to CAP7                          | R/W    | 0x100 to 0x11C    | SCT capture register of capture channel 0 to 7;<br>REGMOD0 to REGMODE7 = 1                                | 0x0000 0000 | Table 240        |
| CAP0_L to<br>CAP7_L                   | R/W    | 0x100 to 0x11C    | SCT capture register of capture channel 0 to 7;<br>low counter 16-bit; REGMOD0_L to<br>REGMODE7_L = 1     | 0x0000 0000 | <u>Table 240</u> |
| CAP0_H to<br>CAP7_H                   | R/W    | 0x102 to 0x11E    | SCT capture register of capture channel 0 to 7;<br>high counter 16-bit; REGMOD0_H to<br>REGMODE7_H = 1    | 0x0000 0000 | <u>Table 240</u> |
| MATCHREL0 to<br>MATCHREL7             | R/W    | 0x200 to<br>0x21C | SCT match reload value register 0 to 7;<br>REGMOD0 = 0 to REGMODE7 = 0                                    | 0x0000 0000 | Table 241        |
| MATCHREL0_L<br>to<br>MATCHREL7_L      | R/W    | 0x200 to<br>0x21C | SCT match reload value register 0 to 7; low<br>counter 16-bit; REGMOD0_L = 0 to<br>REGMODE7_L = 0         | 0x0000 0000 | <u>Table 241</u> |
| MATCHREL0_<br>H to<br>MATCHREL7_<br>H | R/W    | 0x202 to 0x21E    | SCT match reload value register 0 to 7; high<br>counter 16-bit; REGMOD0_H = 0 to<br>REGMODE7_H = 0        | 0x0000 0000 | Table 241        |
| CAPCTRL0 to<br>CAPCTRL7               | R/W    | 0x200 to<br>0x21C | SCT capture control register 0 to 7; REGMOD0 = 1 to REGMODE7 = 1                                          | 0x0000 0000 | Table 242        |
| CAPCTRL0_L<br>to<br>CAPCTRL7_L        | R/W    | 0x200 to<br>0x21C | SCT capture control register 0 to 7; low counter<br>16-bit; REGMOD0_L = 1 to REGMODE7_L = 1               | 0x0000 0000 | <u>Table 242</u> |
| CAPCTRL0_H<br>to<br>CAPCTRL7_H        | R/W    | 0x202 to 0x21E    | SCT capture control register 0 to 7; high counter<br>16-bit; REGMOD0 = 1 to REGMODE7 = 1                  | 0x0000 0000 | <u>Table 242</u> |

UM11021

| Table 219 | . Register | overview: Stat | e Configurable | Timer S | CT/PWM | (base address | 0x5000 40 | 000)continued |  |
|-----------|------------|----------------|----------------|---------|--------|---------------|-----------|---------------|--|
|-----------|------------|----------------|----------------|---------|--------|---------------|-----------|---------------|--|

| Name      | Access | Address<br>offset | Description                  | Reset value | Reference |
|-----------|--------|-------------------|------------------------------|-------------|-----------|
| -         | -      | 0x220 to 0x2FF    | Reserved                     | -           | -         |
| EV0_STATE | R/W    | 0x300             | SCT event state register 0   | 0x0000 0000 | Table 243 |
| EV0_CTRL  | R/W    | 0x304             | SCT event control register 0 | 0x0000 0000 | Table 244 |
| EV1_STATE | R/W    | 0x308             | SCT event state register 1   | 0x0000 0000 | Table 243 |
| EV1_CTRL  | R/W    | 0x30C             | SCT event control register 1 | 0x0000 0000 | Table 244 |
| EV2_STATE | R/W    | 0x310             | SCT event state register 2   | 0x0000 0000 | Table 243 |
| EV2_CTRL  | R/W    | 0x314             | SCT event control register 2 | 0x0000 0000 | Table 244 |
| EV3_STATE | R/W    | 0x318             | SCT event state register 3   | 0x0000 0000 | Table 243 |
| EV3_CTRL  | R/W    | 0x31C             | SCT event control register 3 | 0x0000 0000 | Table 244 |
| EV4_STATE | R/W    | 0x320             | SCT event state register 4   | 0x0000 0000 | Table 243 |
| EV4_CTRL  | R/W    | 0x324             | SCT event control register4  | 0x0000 0000 | Table 244 |
| EV5_STATE | R/W    | 0x328             | SCT event state register 5   | 0x0000 0000 | Table 243 |
| EV5_CTRL  | R/W    | 0x32C             | SCT event control register 5 | 0x0000 0000 | Table 244 |
| EV6_STATE | R/W    | 0x330             | SCT event state register 6   | 0x0000 0000 | Table 243 |
| EV6_CTRL  | R/W    | 0x334             | SCT event control register 6 | 0x0000 0000 | Table 244 |
| EV7_STATE | R/W    | 0x338             | SCT event state register 7   | 0x0000 0000 | Table 243 |
| EV7_CTRL  | R/W    | 0x33C             | SCT event control register 7 | 0x0000 0000 | Table 244 |
| -         | -      | 0x340 to 0x4FF    | Reserved                     | -           | -         |
| OUT0_SET  | R/W    | 0x500             | SCT output 0 set register    | 0x0000 0000 | Table 245 |
| OUT0_CLR  | R/W    | 0x504             | SCT output 0 clear register  | 0x0000 0000 | Table 246 |
| OUT1_SET  | R/W    | 0x508             | SCT output 1 set register    | 0x0000 0000 | Table 245 |
| OUT1_CLR  | R/W    | 0x50C             | SCT output 1 clear register  | 0x0000 0000 | Table 246 |
| OUT2_SET  | R/W    | 0x510             | SCT output 2 set register    | 0x0000 0000 | Table 245 |
| OUT2_CLR  | R/W    | 0x514             | SCT output 2 clear register  | 0x0000 0000 | Table 246 |
| OUT3_SET  | R/W    | 0x518             | SCT output 3 set register    | 0x0000 0000 | Table 245 |
| OUT3_CLR  | R/W    | 0x51C             | SCT output 3 clear register  | 0x0000 0000 | Table 246 |
| OUT4_SET  | R/W    | 0x520             | SCT output 4 set register    | 0x0000 0000 | Table 245 |
| OUT4_CLR  | R/W    | 0x524             | SCT output 4 clear register  | 0x0000 0000 | Table 246 |
| OUT5_SET  | R/W    | 0x528             | SCT output 5 set register    | 0x0000 0000 | Table 245 |
| OUT5_CLR  | R/W    | 0x52C             | SCT output 5 clear register  | 0x0000 0000 | Table 246 |

# 16.6.1 Register functional grouping

Most SCT registers either configure an event or select an event for a specific action of the counter (or counters) and outputs. <u>Figure 35</u> shows the registers and register bits that can be configured for each event.



### 16.6.1.1 Counter configuration and control registers

The SCT contains two registers for configuring the SCT and monitor and control its operation by software.

- The configuration register (CONFIG) configures the SCT in single, 32-bit counter mode or in dual, 16-bit counter mode, configures the clocking and clock synchronization, and configures automatic limits and the use of reload registers.
- The control register (CTRL) allows to monitor and set the counter direction, and to clear, start, stop, or halt the 32-bit counter or each individual 16-bit counter if in dual-counter mode.

### 16.6.1.2 Event configuration registers

Each event is associated with two registers:

- One EVn\_CTRL register per event to define what triggers the event.
- One EVn\_STATE register per event to enable the event.

### 16.6.1.3 Match and capture registers

The SCT includes a set of registers to store the SCT's match or capture values. Each match register is associated with a match reload register which automatically reloads the match register at the beginning of each counter cycle. This register group includes the following registers:

- One REGMODE register per match/capture register to configure each match/capture register for either storing a match value or a capture value.
- A set of match/capture registers with each register, depending on the setting of REGMODE, either storing a match value or a counter value.
- One reload register for each match register.

### 16.6.1.4 Event select registers for the counter operations

This group contains the registers that select the events which affect the counter. Counter actions are limit, halt, and start or stop and apply to the unified counter or to the two 16-bit counters. Also included is the counter register with the counter value, or values in the dual-counter set-up. This register group includes the following registers:

- LIMIT selects the events that limit the counter.
- START and STOP select events that start or stop the counter.
- · HALT selects events that halt the counter: HALT
- COUNT contains the counter value.

The LIMIT, START, STOP, and HALT registers each contain one bit per event that selects for each event whether the event limits, stops, starts, or halts the counter, or counters in dual-counter mode.

In the dual-counter mode, the events can be selected independently for each counter.

### 16.6.1.5 Event select registers for setting or clearing the outputs

This group contains the registers that select the events which affect the level of each SCT output. Also included are registers to manage conflicts that occur when events try to set or clear the same output. This register group includes the following registers:

- One OUTn\_SET register for each output to select the events which set the output.
- One OUTn\_CLR register for each output to select the events which clear the output.
- The conflict resolution register which defines an action when more than one event try to control an output at the same time.
- The conflict flag and conflict interrupt enable registers that monitor interrupts arising from output set and clear conflicts.
- The output direction control register that interchanges the set and clear output operation caused by an event in bi-directional mode.

The OUTn\_SET and OUTn\_CLR registers each contain one bit per event that selects whether the event changes the state a given output n.

In the dual-counter mode, the events can be selected independently for each output.

### 16.6.1.6 Event select registers for capturing a counter value

This group contains registers that select events which capture the counter value and store it in one of the CAP registers. Each capture register m has one associated CAPCTRLm register which in turn selects the events to capture the counter value.

### 16.6.1.7 Event select register for initiating DMA transfers

One register is provided for each of the two DMA requests to select the events that can trigger a DMA request.

The DMAREQn register contain one bit for each event that selects whether this event triggers a DMA request. An additional bit enables the DMA trigger when the match registers are reloaded.

### 16.6.1.8 Interrupt handling registers

The following registers provide flags that are set by events and select the events that when they occur request an interrupt.

- The event flag register provides one flag for each event that is set when the event occurs.
- The event flag interrupt enable register provides one bit for each event to be enabled for the SCT interrupt.

### 16.6.1.9 Registers for controlling SCT inputs and outputs by software

Two registers are provided that allow software (as opposed to events) to set input and outputs of the SCT:

- The SCT input register to read the state of any of the SCT inputs.
- The SCT output register to set or clear any of the SCT outputs or to read the state of the outputs.

UM11021

# 16.6.2 SCT configuration register

This register configures the overall operation of the SCT. Write to this register before any other registers. Only word-writes are permitted to this register. Attempting to write a half-word value results in a bus error.

Table 220. SCT configuration register (CONFIG, address 0x5000 4000) bit description

| Bit | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                              | Reset<br>value |
|-----|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | UNIFY      |       | SCT operation                                                                                                                                                                                                                                                                                                                                                            | 0              |
|     |            | 0     | The SCT operates as two 16-bit counters named L and H.                                                                                                                                                                                                                                                                                                                   |                |
|     |            | 1     | The SCT operates as a unified 32-bit counter.                                                                                                                                                                                                                                                                                                                            |                |
| 2:1 | CLKMODE    |       | SCT clock mode                                                                                                                                                                                                                                                                                                                                                           | 00             |
|     |            | 0x0   | System Clock Mode. The system clock clocks the entire SCT module including the counter(s) and counter prescalers.                                                                                                                                                                                                                                                        |                |
|     |            | 0x1   | Sampled System Clock Mode. The system clock clocks the SCT module, but<br>the counter and prescalers are only enabled to count when the designated<br>edge is detected on the input selected by the CKSEL field. The minimum pulse<br>width on the selected clock-gate input is one system clock period. This mode is<br>the high-performance, sampled-clock mode.       | _              |
|     |            | 0x2   | SCT Input Clock Mode. The input/edge selected by the CKSEL field clocks the SCT module, including the counters and prescalers, after first being synchronized to the system clock. The minimum pulse width on the clock input is 1 bus clock one system clock period. This mode is the low-power, sampled-clock mode.                                                    |                |
|     |            | 0x3   | Asynchronous Mode. The entire SCT module is clocked directly by the input/edge selected by the CKSEL field. In this mode, the SCT outputs are switched synchronously to the SCT input clock - not the system clock. The input clock rate must be at least half the system clock rate and can be the same or faster than the system clock.                                |                |
| 6:3 | CKSEL      |       | SCT clock select. The specific functionality of the designated input/edge is dependent on the CLKMODE bit selection in this register.                                                                                                                                                                                                                                    | 0000           |
|     |            | 0x0   | Rising edges on input 0.                                                                                                                                                                                                                                                                                                                                                 |                |
|     |            | 0x1   | Falling edges on input 0.                                                                                                                                                                                                                                                                                                                                                |                |
|     |            | 0x2   | Rising edges on input 1.                                                                                                                                                                                                                                                                                                                                                 |                |
|     |            | 0x3   | Falling edges on input 1.                                                                                                                                                                                                                                                                                                                                                |                |
|     |            | 0x4   | Rising edges on input 2.                                                                                                                                                                                                                                                                                                                                                 |                |
|     |            | 0x5   | Falling edges on input 2.                                                                                                                                                                                                                                                                                                                                                |                |
|     |            | 0x6   | Rising edges on input 3.                                                                                                                                                                                                                                                                                                                                                 |                |
|     |            | 0x7   | Falling edges on input 3.                                                                                                                                                                                                                                                                                                                                                |                |
| 7   | NORELAOD_L | -     | A 1 in this bit prevents the lower match registers from being reloaded from their respective reload registers. Setting this bit eliminates the need to write to the reload registers MATCHREL if the match values are fixed. Software can write to set or clear this bit at any time. This bit applies to both the higher and lower registers when the UNIFY bit is set. | 0              |
| 8   | NORELOAD_H | -     | A 1 in this bit prevents the higher match registers from being reloaded from their respective reload registers. Setting this bit eliminates the need to write to the reload registers MATCHREL if the match values are fixed. Software can write to set or clear this bit at any time. This bit is not used when the UNIFY bit is set.                                   | 0              |

| Bit   | Symbol      | Value | Description                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 12:9  | INSYNC      | -     | Synchronization for input N (bit 9 = input 0, bit 10 = input 1,, bit 12 = input 3);<br>all other bits are reserved. A 1 in one of these bits subjects the corresponding<br>input to synchronization to the SCT clock, before it is used to create an event. | 1              |
|       |             |       | If an input is known to already be synchronous to the SCT clock, this bit may be set to 0 for faster input response. (Note: The SCT clock is the system clock for CLKMODEs 0-2. It is the selected, asynchronous SCT input clock for CLKMODE3).             |                |
|       |             |       | Note that the INSYNC field only affects inputs used for event generation. It does not apply to the clock input specified in the CKSEL field.                                                                                                                |                |
| 16:13 | -           | -     | Reserved.                                                                                                                                                                                                                                                   |                |
| 17    | AUTOLIMIT_L | -     | A one in this bit causes a match on match register 0 to be treated as a de-facto LIMIT condition without the need to define an associated event.                                                                                                            |                |
|       |             |       | As with any LIMIT event, this automatic limit causes the counter to be cleared to zero in uni-directional mode or to change the direction of count in bi-directional mode.                                                                                  |                |
|       |             |       | Software can write to set or clear this bit at any time. This bit applies to both the higher and lower registers when the UNIFY bit is set.                                                                                                                 |                |
| 18    | AUTOLIMIT_H | -     | A one in this bit will cause a match on match register 0 to be treated as a de-facto LIMIT condition without the need to define an associated event.                                                                                                        |                |
|       |             |       | As with any LIMIT event, this automatic limit causes the counter to be cleared to zero in uni-directional mode or to change the direction of count in bi-directional mode.                                                                                  |                |
|       |             |       | Software can write to set or clear this bit at any time. This bit is not used when the UNIFY bit is set.                                                                                                                                                    |                |
| 31:19 | -           |       | Reserved                                                                                                                                                                                                                                                    | -              |

#### Table 220. SCT configuration register (CONFIG, address 0x5000 4000) bit description ...continued

# 16.6.3 SCT control register

If bit UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If bit UNIFY = 0 in the CONFIG register, this register can be written to as two registers CTRL\_L and CTRL\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

All bits in this register can be written to when the counter is stopped or halted. When the counter is running, the only bits that can be written are STOP or HALT. (Other bits can be written in a subsequent write after HALT is set to 1.)

**Remark:** If CLKMODE = 0x3 is selected, wait at least 12 system clock cycles between a write access to the H, L or unified version of this register and the next write access. This restriction does not apply when writing to the HALT bit or bits and then writing to the CTRL register again to restart the counters - for example because software must update the MATCH register, which is only allowed when the counters are halted.

**Remark:** If the SCTimer/PWM is operating as two 16-bit counters, events can only modify the state of the outputs when neither counter is halted. This is true regardless of what triggered the event.

| Bit   | Symbol   | Value | Description                                                                                                                                                                                                                                                                                                                                                            | Reset<br>value |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0     | DOWN_L   | -     | This bit is 1 when the L or unified counter is counting down. Hardware sets this bit when the counter is counting up, counter limit occurs, and $BIDIR = 1.Hardware$ clears this bit when the counter is counting down and a limit condition occurs or when the counter reaches 0.                                                                                     | 0              |
| 1     | STOP_L   | -     | When this bit is 1 and HALT is 0, the L or unified counter does not run, but I/O events related to the counter can occur. If a designated start event occurs, this bit is cleared and counting resumes.                                                                                                                                                                | 0              |
| 2     | HALT_L   | -     | When this bit is 1, the L or unified counter does not run and no events can occur. A reset sets this bit. When the HALT_L bit is one, the STOP_L bit is cleared. It is possible to remove the halt condition while keeping the SCT in the stop condition (not running) with a single write to this register to simultaneously clear the HALT bit and set the STOP bit. | 1              |
|       |          |       | <b>Remark:</b> Once set, only software can clear this bit to restore counter operation. This bit is set on reset.                                                                                                                                                                                                                                                      |                |
| 3     | CLRCTR_L | -     | Writing a 1 to this bit clears the L or unified counter. This bit always reads as 0.                                                                                                                                                                                                                                                                                   | 0              |
| 4     | BIDIR_L  |       | L or unified counter direction select                                                                                                                                                                                                                                                                                                                                  | 0              |
|       |          | 0     | Up. The counter counts up to a limit condition, then is cleared to zero.                                                                                                                                                                                                                                                                                               |                |
|       |          | 1     | Up-down. The counter counts up to a limit, then counts down to a limit condition or to 0.                                                                                                                                                                                                                                                                              |                |
| 12:5  | PRE_L    | -     | Specifies the factor by which the SCT clock is prescaled to produce the L or unified counter clock. The counter clock is clocked at the rate of the SCT clock divided by PRE_L+1.                                                                                                                                                                                      | 0              |
|       |          |       | <b>Remark:</b> Clear the counter (by writing a 1 to the CLRCTR bit) whenever changing the PRE value.                                                                                                                                                                                                                                                                   |                |
| 15:13 | -        |       | Reserved                                                                                                                                                                                                                                                                                                                                                               |                |
| 16    | DOWN_H   | -     | This bit is 1 when the H counter is counting down. Hardware sets this bit when the counter is counting, a counter limit condition occurs, and BIDIR is 1. Hardware clears this bit when the counter is counting down and a limit condition occurs or when the counter reaches 0.                                                                                       | 0              |
| 17    | STOP_H   | -     | When this bit is 1 and HALT is 0, the H counter does not, run but I/O events related to the counter can occur. If such an event matches the mask in the Start register, this bit is cleared and counting resumes.                                                                                                                                                      | 0              |
| 18    | HALT_H   | -     | When this bit is 1, the H counter does not run and no events can occur. A reset sets this bit. When the HALT_H bit is one, the STOP_H bit is cleared.                                                                                                                                                                                                                  | 1              |
|       |          |       | It is possible to remove the halt condition while keeping the SCT in the stop condition (not running) with a single write to this register to simultaneously clear the HALT bit and set the STOP bit.                                                                                                                                                                  |                |
|       |          |       | <b>Remark:</b> Once set, this bit can only be cleared by software to restore counter operation. This bit is set on reset.                                                                                                                                                                                                                                              |                |
| 19    | CLRCTR_H | -     | Writing a 1 to this bit clears the H counter. This bit always reads as 0.                                                                                                                                                                                                                                                                                              | 0              |

### Table 221. SCT control register (CTRL, address 0x5000 4004) bit description

User manual

| Bit   | Symbol  | Value | Description                                                                                                                                                            | Reset<br>value |
|-------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 20    | BIDIR_H |       | Direction select                                                                                                                                                       | 0              |
|       |         | 0     | The H counter counts up to its limit condition, then is cleared to zero.                                                                                               |                |
|       |         | 1     | The H counter counts up to its limit, then counts down to a limit condition or to 0.                                                                                   |                |
| 28:21 | PRE_H   | -     | Specifies the factor by which the SCT clock is prescaled to produce the H counter clock. The counter clock is clocked at the rate of the SCT clock divided by PRELH+1. | 0              |
|       |         |       | <b>Remark:</b> Clear the counter (by writing a 1 to the CLRCTR bit) whenever changing the PRE value.                                                                   |                |
| 31:29 | -       |       | Reserved                                                                                                                                                               |                |

#### Table 221. SCT control register (CTRL, address 0x5000 4004) bit description

### 16.6.4 SCT limit event select register

The running counter can be limited by an event. When any of the events selected in this register occur, the counter is cleared to zero from its current value or changes counting direction if in bi-directional mode.

Each bit of the register is associated with a different event (bit 0 with event 0, etc.). Setting a bit causes its associated event to serve as a LIMIT event. When any limit event occurs, the counter is reset to zero in uni-directional mode or changes its direction of count in bi-directional mode. To define the actual limiting event (a match, an I/O pin toggle, etc.), see the EVn\_CTRL register.

**Remark:** Counting up to all ones or counting down to zero is always equivalent to a limit event occurring.

Note that in addition to using this register to specify events that serve as limits, it is also possible to automatically cause a limit condition whenever a match register 0 match occurs. This eliminates the need to define an event for the sole purpose of creating a limit. The AUTOLIMITL and AUTOLIMITH bits in the configuration register enable/disable this feature (see <u>Table 220</u>).

If UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers LIMIT\_L and LIMIT\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

| Bit   | Symbol   | Description                                                                                                                                 | Reset<br>value |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | LIMMSK_L | If bit n is one, event n is used as a counter limit for the L or<br>unified counter (event 0 = bit 0, event 1 = bit 1, event 7 = bit<br>7). | 0              |
| 15:8  | -        | Reserved.                                                                                                                                   | -              |
| 23:16 | LIMMSK_H | If bit n is one, event n is used as a counter limit for the H counter (event 0 = bit 16, event 1 = bit 17, event 7 = bit 23).               | 0              |
| 31:24 | -        | Reserved.                                                                                                                                   | -              |

Table 222. SCT limit event select register (LIMIT, address 0x5000 4008) bit description

## 16.6.5 SCT halt event select register

The running counter can be disabled (halted) by an event. When any of the events selected in this register occur, the counter stops running and all further events are disabled.

Each bit of the register is associated with a different event (bit 0 with event 0, etc.). Setting a bit will cause its associated event to serve as a HALT event. To define the actual events that cause the counter to halt (a match, an I/O pin toggle, etc.), see the EVn\_CTRL registers.

**Remark:** A HALT condition can only be removed when software clears the HALT bit in the CTRL register (<u>Table 221</u>).

If UNIFY = 1 in the CONFIG register, only the L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers  $HALT_L$  and  $HALT_H$ . Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

Table 223. SCT halt event select register (HALT, address 0x5000 400C) bit description

| Bit   | Symbol    | Description                                                                                                                        | Reset<br>value |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | HALTMSK_L | If bit n is one, event n sets the HALT_L bit in the CTRL register (event $0 = bit 0$ , event $1 = bit 1$ , event $7 = bit 7$ ).    | 0              |
| 15:8  | -         | Reserved.                                                                                                                          | -              |
| 23:16 | HALTMSK_H | If bit n is one, event n sets the HALT_H bit in the CTRL register (event $0 = bit 16$ , event $1 = bit 17$ , event $7 = bit 23$ ). | 0              |
| 31:24 | -         | Reserved.                                                                                                                          | -              |

### 16.6.6 SCT stop event select register

The running counter can be stopped by an event. When any of the events selected in this register occur, counting is suspended, that is the counter stops running and remains at its current value. Event generation remains enabled, and any event selected in the START register such as an I/O event or an event generated by the other counter can restart the counter.

This register specifies which events stop the counter. Each bit of the register is associated with a different event (bit 0 with event 0, etc.). Setting a bit will cause its associated event to serve as a STOP event. To define the actual event that causes the counter to stop (a match, an I/O pin toggle, etc.), see the EVn\_CTRL register.

Remark: Software can stop and restart the counter by writing to the CTRL register.

If UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers STOPT\_L and STOP\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

| Bit   | Symbol    | Description                                                                                                                        | Reset<br>value |  |  |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| 7:0   | STOPMSK_L | If bit n is one, event n sets the STOP_L bit in the CTRL register (event $0 = bit 0$ , event $1 = bit 1$ , event $7 = bit 7$ ).    | 0              |  |  |
| 15:8  | -         | Reserved.                                                                                                                          | -              |  |  |
| 23:16 | STOPMSK_H | If bit n is one, event n sets the STOP_H bit in the CTRL register (event $0 = bit 16$ , event $1 = bit 17$ , event $7 = bit 23$ ). | 0              |  |  |
| 31:24 | -         | Reserved.                                                                                                                          | -              |  |  |

Table 224. SCT stop event select register (STOP, address 0x5000 4010) bit description

## 16.6.7 SCT start event select register

The stopped counter can be re-started by an event. When any of the events selected in this register occur, counting is restarted from the current counter value.

Each bit of the register is associated with a different event (bit 0 with event 0, etc.). Setting a bit will cause its associated event to serve as a START event. When any START event occurs, hardware will clear the STOP bit in the Control Register CTRL. Note that a START event has no effect on the HALT bit. Only software can remove a HALT condition. To define the actual event that starts the counter (an I/O pin toggle or an event generated by the other running counter in dual-counter mode), see the EVn\_CTRL register.

If UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers START\_L and START\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

| Bit   | Symbol     | Description                                                                                                                 | Reset<br>value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0   | STARTMSK_L | If bit n is one, event n clears the STOP_L bit in the CTRL register (event 0 = bit 0, event 1 = bit 1, event 7 = bit 7).    | 0              |
| 15:8  | -          | Reserved.                                                                                                                   | -              |
| 23:16 | STARTMSK_H | If bit n is one, event n clears the STOP_H bit in the CTRL register (event 0 = bit 16, event 1 = bit 17, event 7 = bit 23). | 0              |
| 31:24 | -          | Reserved.                                                                                                                   | -              |

Table 225. SCT start event select register (START, address 0x5000 4014) bit description

# 16.6.8 SCT counter register

If UNIFY = 1 in the CONFIG register, the counter is a unified 32-bit register and both the \_L and \_H bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers COUNT\_L and COUNT\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation. In this case, the L and H registers count independently under the control of the other registers.

Writing to the COUNT\_L, COUNT\_H, or unified register is only allowed when the corresponding counter is halted (HALT bits are set to 1 in the CTRL register). Attempting to write to the counter when it is not halted causes a bus error. Software can read the counter registers at any time.

 Table 226. SCT counter register (COUNT, address 0x5000 4040) bit description

| Bit   | Symbol | Description                                                                                                                              | Reset<br>value |
|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | CTR_L  | When UNIFY = 0, read or write the 16-bit L counter value. When UNIFY = 1, read or write the lower 16 bits of the 32-bit unified counter. | 0              |
| 31:16 | CTR_H  | When UNIFY = 0, read or write the 16-bit H counter value. When UNIFY = 1, read or write the upper 16 bits of the 32-bit unified counter. | 0              |

# 16.6.9 SCT state register

Each group of enabled and disabled events is assigned a number called the state variable. For example, a state variable with a value of 0 could have events 0, 2, and 3 enabled and all other events disabled. A state variable with the value of 1 could have events 1, 4, and 5 enabled and all others disabled.

**Remark:** The EVm\_STATE registers define which event is enabled in each group.

Software can read the state associated with a counter at any time. Writing to the STATE\_L, STATE\_H, or unified register is only allowed when the corresponding counter is halted (HALT bits are set to 1 in the CTRL register).

The state variable is the main feature that distinguishes the SCTimer/PWM from other counter/timer/ PWM blocks. Events can be made to occur only in certain states. Events, in turn, can perform the following actions:

- set and clear outputs
- limit, stop, and start the counter
- cause interrupts and DMA requests
- modify the state variable

The value of a state variable is completely under the control of the application. If an application does not use states, the value of the state variable remains zero, which is the default value.

A state variable can be used to track and control multiple cycles of the associated counter in any desired operational sequence. The state variable is logically associated with a state machine diagram which represents the SCT configuration. See <u>Section 16.6.24</u> and <u>16.6.25</u> for more about the relationship between states and events.

The STATELD/STADEV fields in the event control registers of all defined events set all possible values for the state variable. The change of the state variable during multiple counter cycles reflects how the associated state machine moves from one state to the next.

If UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers STATE\_L and STATE\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

| Table 227. S | SCT state register ( | (STATE, address | s 0x5000 4044 | ) bit description |
|--------------|----------------------|-----------------|---------------|-------------------|
|              | or state register    | (OTATE, address | 5 072000 4044 | ) bit accomption  |

| Bit   | Symbol  | Description     | Reset<br>value |
|-------|---------|-----------------|----------------|
| 4:0   | STATE_L | State variable. | 0              |
| 15:5  | -       | Reserved.       | -              |
| 20:16 | STATE_H | State variable. | 0              |
| 31:21 | -       | Reserved.       |                |

# 16.6.10 SCT input register

Software can read the state of the SCT inputs in this read-only register in slightly different forms.

- 1. The AIN bit displays the state of the input captured on each rising edge of the SCT clock This corresponds to a nearly direct read-out of the input but can cause spurious fluctuations in case of an asynchronous input signal.
- 2. The SIN bit displays the form of the input as it is used for event detection. This may include additional stages of synchronization, depending on what is specified for that input in the INSYNC field in the CONFIG register:
  - If the INSYNC bit is set for the input, the input is triple-synchronized to the SCT clock resulting in a stable signal that is delayed by three SCT clock cycles.
  - If the INSYNC bit is not set, the SIN bit value is identical to the AIN bit value.

### Table 228. SCT input register (INPUT, address 0x5000 4048) bit description

| Bit   | Symbol | Description                                                                      |   |  |  |  |  |
|-------|--------|----------------------------------------------------------------------------------|---|--|--|--|--|
| 0     | AIN0   | Input 0 state.Input 0 state on the last SCT clock edge.                          | - |  |  |  |  |
| 1     | AIN1   | Input 1 state. Input 1 state on the last SCT clock edge.                         | - |  |  |  |  |
| 2     | AIN2   | Input 2 state. Input 2 state on the last SCT clock edge.                         | - |  |  |  |  |
| 3     | AIN3   | Input 3 state. Input 3 state on the last SCT clock edge.                         | - |  |  |  |  |
| 15:4  | -      | Reserved.                                                                        | - |  |  |  |  |
| 16    | SIN0   | Input 0 state. Input 0 state following the synchronization specified by INSYNC0. | - |  |  |  |  |
| 17    | SIN1   | Input 1 state. Input 1 state following the synchronization specified by INSYNC0. | - |  |  |  |  |
| 18    | SIN2   | Input 2 state. Input 2 state following the synchronization specified by INSYNC0. | - |  |  |  |  |
| 19    | SIN3   | Input 3 state. Input 3 state following the synchronization specified by INSYNC0. |   |  |  |  |  |
| 31:20 | -      | Reserved                                                                         | - |  |  |  |  |

# 16.6.11 SCT match/capture mode register

If UNIFY = 1 in the CONFIG register, only the  $\_L$  bits of this register are used. In this case, REGMODE\_H is not used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers REGMODE\_L and REGMODE\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation. The \_L bits/registers control the L match/capture registers, and the \_H bits/registers control the H match/capture registers.

The SCT contains multiple Match/Capture registers. The Register Mode register selects whether each register acts as a Match register (see <u>Section 16.6.20</u>) or as a Capture register (see <u>Section 16.6.21</u>). Each Match/Capture register has an accompanying register which functions as a Reload register when the primary register is used as a Match register (<u>Section 16.6.22</u>) or as a Capture-Control register when the register is used as a capture register (<u>Section 16.6.23</u>). REGMODE\_H is used only when the UNIFY bit is 0.

# Table 229. SCT match/capture mode register (REGMODE, address 0x5000 404C) bit description

| =        |                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Description                                                                                                             | Reset<br>value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| REGMOD_L | Each bit controls one match/capture register (register 0 = bit 0, register 1 = bit 1,, register = bit 7).               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | 0 = register operates as match register.                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 1 = register operates as capture register.                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| -        | Reserved.                                                                                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| REGMOD_H | Each bit controls one match/capture register (register $0 = bit 16$ , register $1 = bit 17$ ,, register $7 = bit 23$ ). | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | 0 = register operates as match registers.                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|          | 1 = register operates as capture registers.                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| -        | Reserved.                                                                                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | REGMOD_L                                                                                                                | REGMOD_L       Each bit controls one match/capture register (register 0 = bit 0, register 1 = bit 1,, register = bit 7).         0 = register operates as match register.         1 = register operates as capture register.         -       Reserved.         REGMOD_H       Each bit controls one match/capture register (register 0 = bit 16, register 1 = bit 17,, register 7 = bit 23).         0 = register operates as match registers.       1 = register operates as capture registers. |

# 16.6.12 SCT output register

Each SCT output has a corresponding bit in this register to allow software to control the output state directly or read its current state.

While the counter is running, outputs are set, cleared, or toggled only by events. However, using this register, software can write to any of the output registers when both counters are halted to control the outputs directly. Writing to the OUT register is only allowed when all counters (L-counter, H-counter, or unified counter) are halted (HALT bits are set to 1 in the CTRL register).

Software can read this register at any time to sense the state of the outputs.

#### Table 230. SCT output register (OUTPUT, address 0x5000 4050) bit description

| Bit  | Symbol | Description                                                                                                                                                               | Reset<br>value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  |        | Writing a 1 to bit n forces the corresponding output HIGH. Writing a 0 forces the corresponding output LOW (output $0 = bit 0$ , output $1 = bit 1,, output 5 = bit 5$ ). | 0              |
| 31:6 | -      | Reserved                                                                                                                                                                  |                |

# 16.6.13 SCT bi-directional output control register

For bi-directional mode, this register specifies (for each output) the impact of the counting direction on the meaning of set and clear operations on the output (see <u>Section 16.6.26</u>) and <u>Section 16.6.27</u>). The purpose of this register is to facilitate the creation of center-aligned output waveforms without the need to define additional events.

Table 231. SCT bidirectional output control register (OUTPUTDIRCTRL, address 0x5000 4054) bit description

| Bit   | Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Value | Description                                                                          | Reset<br>value |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------|----------------|
| 1:0   | SETCLR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Set/clear operation on output 0. Value 0x3 is reserved. Do not program this value.   | 0              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | Set and clear are reversed when counter H is counting down. Do not use if UNIFY = 1. |                |
| 3:2   | 0x2         Set and clear are reversed when counter H is counting down. Do not use if UNIFY =<br>1.           SETCLR1         Set/clear operation on output 1. Value 0x3 is reserved. Do not program this value.           0x0         Set and clear do not depend on the direction of any counter.           0x1         Set and clear are reversed when counter L or the unified counter is counting down.           0x2         Set and clear are reversed when counter H is counting down. Do not use if UNIFY =<br>1.           SETCLR2         Set /clear operation on output 2. Value 0x3 is reserved. Do not program this value.           0x0         Set and clear are reversed when counter H is counting down. Do not use if UNIFY =<br>1.           SETCLR2         Set/clear operation on output 2. Value 0x3 is reserved. Do not program this value.           0x0         Set and clear are reversed when counter L or the unified counter is counting down.           0x1         Set and clear are reversed when counter L or the unified counter is counting down.           0x2         Set and clear are reversed when counter L or the unified counter is counting down.           0x2         Set and clear are reversed when counter H is counting down. Do not use if UNIFY =<br>1.           SETCLR3         Set/clear operation on output 3. Value 0x3 is reserved. Do not program this value.           0x0         Set and clear are reversed when counter L or the unified counter is counting down.           0x1         Set and clear are reversed when counter | 0     |                                                                                      |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | -                                                                                    |                |
| 5:4   | SETCLR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Set/clear operation on output 2. Value 0x3 is reserved. Do not program this value.   | 0              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | -                                                                                    |                |
| 7:6   | SETCLR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Set/clear operation on output 3. Value 0x3 is reserved. Do not program this value.   | 0              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | Set and clear are reversed when counter H is counting down. Do not use if UNIFY = 1. |                |
| 9:8   | SETCLR4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Set/clear operation on output 4. Value 0x3 is reserved. Do not program this value.   | 0              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | Set and clear are reversed when counter H is counting down. Do not use if UNIFY = 1. |                |
| 11:10 | SETCLR5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       | Set/clear operation on output 5. Value 0x3 is reserved. Do not program this value.   | 0              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   | Set and clear do not depend on the direction of any counter.                         |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   | Set and clear are reversed when counter L or the unified counter is counting down.   |                |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x2   | Set and clear are reversed when counter H is counting down. Do not use if UNIFY = 1. |                |
| 31:12 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | Reserved                                                                             | -              |

# 16.6.14 SCT conflict resolution register

The output conflict resolution register specifies what action should be taken if multiple events (or even the same event) dictate that a given output should be both set and cleared at the same time.

To enable an event to toggle an output each time the event occurs, set the bits for that event in both the OUTn\_SET and OUTn\_CLR registers and set the On\_RES value to 0x3 in this register.

| Bit        | Symbol | Value | Description                                                                     | Reset<br>value |
|------------|--------|-------|---------------------------------------------------------------------------------|----------------|
| 1:0        | O0RES  |       | Effect of simultaneous set and clear on output 0.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR0 field in the OUTPUTDIRCTRL register). |                |
|            |        | 0x2   | Clear output (or set based on the SETCLR0 field).                               |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 3:2        | O1RES  |       | Effect of simultaneous set and clear on output 1.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR1 field in the OUTPUTDIRCTRL register). |                |
|            |        | 0x2   | Clear output (or set based on the SETCLR1 field).                               |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 5:4        | O2RES  |       | Effect of simultaneous set and clear on output 2.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR2 field in the OUTPUTDIRCTRL register). |                |
|            |        | 0x2   | Clear output n (or set based on the SETCLR2 field).                             |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 7:6        | O3RES  |       | Effect of simultaneous set and clear on output 3.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR3 field in the OUTPUTDIRCTRL register). |                |
| 7:6<br>9:8 |        | 0x2   | Clear output (or set based on the SETCLR3 field).                               |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 9:8        | O4RES  |       | Effect of simultaneous set and clear on output 4.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR4 field in the OUTPUTDIRCTRL register). |                |
|            |        | 0x2   | Clear output (or set based on the SETCLR4 field).                               |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 11:10      | O5RES  |       | Effect of simultaneous set and clear on output 5.                               | 0              |
|            |        | 0x0   | No change.                                                                      |                |
|            |        | 0x1   | Set output (or clear based on the SETCLR5 field in the OUTPUTDIRCTRL register). |                |
|            |        | 0x2   | Clear output (or set based on the SETCLR5 field).                               |                |
|            |        | 0x3   | Toggle output.                                                                  |                |
| 31:12      | -      | -     | Reserved                                                                        | -              |

### Table 232. SCT conflict resolution register (RES, address 0x5000 4058) bit description

## 16.6.15 SCT DMA request 0 and 1 registers

The SCT includes two DMA request outputs. These registers enable the DMA requests to be triggered when a particular event occurs or when counter Match registers are loaded from its Reload registers. The DMA request registers are word-write only. Attempting to write a half-word value to these registers result in a bus error.

Event-triggered DMA requests are particularly useful for launching DMA activity to or from other peripherals under the control of the SCT.

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                              | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  | DEV_0  | If bit n is one, event n triggers DMA request 0 (event $0 = bit 0$ , event $1 = bit 1$ ,, event $7 = bit 7$ ).                                                                                                                                                                                           | 0              |
| 29:6 | -      | Reserved                                                                                                                                                                                                                                                                                                 | -              |
| 30   | DRL0   | A 1 in this bit triggers DMA request 0 when it loads the Match_L/Unified registers from the Reload_L/Unified registers.                                                                                                                                                                                  |                |
| 31   | DRQ0   | This read-only bit indicates the state of DMA Request 0.<br>Note that if the related DMA channel is enabled and properly set<br>up, it is unlikely that software will see this flag, it will be cleared<br>rapidly by the DMA service. The flag remaining set could point<br>to an issue with DMA setup. |                |

Table 233. SCT DMA 0 request register (DMAREQ0, address 0x5000 405C) bit description

#### Table 234. SCT DMA 1 request register (DMAREQ1, address 0x5000 C060) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                              | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  | DEV_1  | If bit n is one, event n triggers DMA request 1 (event $0 = bit 0$ , event $1 = bit 1$ ,, event $7 = bit 7$ ).                                                                                                                                                                                           | 0              |
| 29:6 | -      | Reserved                                                                                                                                                                                                                                                                                                 | -              |
| 30   | DRL1   | A 1 in this bit triggers DMA request 1 when it loads the Match L/Unified registers from the Reload L/Unified registers.                                                                                                                                                                                  |                |
| 31   | DRQ1   | This read-only bit indicates the state of DMA Request 1.<br>Note that if the related DMA channel is enabled and properly set<br>up, it is unlikely that software will see this flag, it will be cleared<br>rapidly by the DMA service. The flag remaining set could point<br>to an issue with DMA setup. |                |

### 16.6.16 SCT event interrupt enable register

This register enables flags to request an interrupt if the FLAGn bit in the SCT event flag register (Section 16.6.17) is also set.

| Table 235. | SCT | event interru | ot enable | register | (EVEN, | address | 0x5000 | 40F0 | ) bit descri | ption |
|------------|-----|---------------|-----------|----------|--------|---------|--------|------|--------------|-------|
|            |     |               |           |          |        |         |        |      |              |       |

| Bit  | Symbol | Description                                                                                                                                                       | Reset<br>value |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | IEN    | The SCT requests an interrupt when bit n of this register and the event flag register are both one (event $0 = bit 0$ , event $1 = bit 1$ ,, event $7 = bit 7$ ). | 0              |
| 31:8 | -      | Reserved                                                                                                                                                          |                |

# 16.6.17 SCT event flag register

This register records events. Writing ones to this register clears the corresponding flags and negates the SCT interrupt request if all enabled flag register bits are zero.

 Table 236.
 SCT event flag register (EVFLAG, address 0x5000 40F4) bit description

| Bit      | Symbol | Description                                                                                                                                         | Reset<br>value |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0      | FLAG   | Bit n is one if event n has occurred since reset or a 1 was last written to this bit (event $0 = bit 0$ , event $1 = bit 1$ ,, event $7 = bit 7$ ). | 0              |
| 31:<br>8 | -      | Reserved                                                                                                                                            | -              |

## 16.6.18 SCT conflict interrupt enable register

This register enables the no-change conflict events specified in the SCT conflict resolution register to generate an interrupt request.

# Table 237. SCT conflict interrupt enable register (CONEN, address 0x5000 40F8) bit description

| Bit  | Symbol |                                                                                                                                                                            | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  | NCEN   | The SCT requests an interrupt when bit n of this register and the SCT conflict flag register are both one (output $0 = bit 0$ , output $1 = bit 1,,$ output $5 = bit 5$ ). | 0              |
| 31:6 | -      | Reserved                                                                                                                                                                   |                |

# 16.6.19 SCT conflict flag register

This register records a no-change conflict occurrence and provides details of a bus error. Writing ones to the NCFLAG bits clears the corresponding read bits and negates the SCT interrupt request if all enabled Flag bits are zero.

| Table 238. SC | T conflict flag register | (CONFLAG, address | 0x5000 40FC) bit description |
|---------------|--------------------------|-------------------|------------------------------|
|---------------|--------------------------|-------------------|------------------------------|

| Bit  | Symbol  | Description                                                                                                                                                                                                                                                   | Reset<br>value |
|------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5:0  | NCFLAG  | Bit n is one if a no-change conflict event occurred on output n since reset or a 1 was last written to this bit (output $0 = bit 0$ , output $1 = bit 1$ ,, output $5 = bit 5$ ).                                                                             | 0              |
| 29:6 | -       | Reserved.                                                                                                                                                                                                                                                     | -              |
| 30   | BUSERRL | The most recent bus error from this SCT involved writing CTR L/Unified, STATE L/Unified, MATCH L/Unified, or the Output register when the L/U counter was not halted. A word write to certain L and H registers can be half successful and half unsuccessful. | 0              |
| 31   | BUSERRH | The most recent bus error from this SCT involved writing CTR<br>H, STATE H, MATCH H, or the Output register when the H<br>counter was not halted.                                                                                                             | 0              |

# 16.6.20 SCT match registers 0 to 7 (REGMODEn bit = 0)

Match registers are compared to the counters to help create events. When the UNIFY bit is 0, the L and H registers are independently compared to the L and H counters. When UNIFY is 1, the combined L and H registers hold a 32-bit value that is compared to the unified counter. A Match can only occur in a clock in which the counter is running (STOP and HALT are both 0).

Match registers can be read at any time. Writing to the MATCH\_L, MATCH\_H, or unified register is only allowed when the corresponding counter is halted (HALT bits are set to 1 in the CTRL register). Match events occur in the SCT clock in which the counter is (or would be) incremented to the next value. When a Match event limits its counter as described in <u>Section 16.6.4</u>, the value in the Match register is the last value of the counter before it is cleared to zero (or decremented if BIDIR is 1).

There is no "write-through" from Reload registers to Match registers. Before starting a counter, software can write one value to the Match register used in the first cycle of the counter and a different value to the corresponding Match Reload register used in the second cycle.

# Table 239. SCT match registers 0 to 7 (MATCH[0:7], address 0x5000 4100 (MATCH0) to 0x5000 411C (MATCH7)) bit description (REGMODEn bit = 0)

| Bit   | Symbol   | Description                                                                                                                                                                                      | Reset<br>value |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | MATCHn_L | When $UNIFY = 0$ , read or write the 16-bit value to be compared to the L counter. When $UNIFY = 1$ , read or write the lower 16 bits of the 32-bit value to be compared to the unified counter. | 0              |
| 31:16 | MATCHn_H | When $UNIFY = 0$ , read or write the 16-bit value to be compared to the H counter. When $UNIFY = 1$ , read or write the upper 16 bits of the 32-bit value to be compared to the unified counter. | 0              |

# 16.6.21 SCT capture registers 0 to 7 (REGMODEn bit = 1)

These registers allow software to record the counter values upon occurrence of the events selected by the corresponding Capture Control registers occurred.

| Bit   | Symbol | Description                                                                                                                                                                                        | Reset<br>value |
|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  | CAPn_L | When $UNIFY = 0$ , read the 16-bit counter value at which this register was last captured. When $UNIFY = 1$ , read the lower 16 bits of the 32-bit value at which this register was last captured. | 0              |
| 31:16 | CAPn_H | When $UNIFY = 0$ , read the 16-bit counter value at which this register was last captured. When $UNIFY = 1$ , read the upper 16 bits of the 32-bit value at which this register was last captured. | 0              |

# Table 240. SCT capture registers 0 to 7 (CAP[0:7], address 0x5000 4100 (CAP0) to 0x5000411C (CAP7)) bit description (REGMODEn bit = 1)

# 16.6.22 SCT match reload registers 0 to 7 (REGMODEn bit = 0)

A Match register (L, H, or unified 32-bit) is loaded from its corresponding Reload register at the start of each new counter cycle, that is

• when BIDIR = 0 and the counter is cleared to zero upon reaching it limit condition.

**User manual** 

• when BIDIR = 1 and the counter counts down to 0, unless the appropriate NORELOAD bit is set in the CFG register.

#### Table 241. SCT match reload registers 0 to 7 (MATCHREL[0:7], address 0x5000 4200 (MATCHREL0) to 0x5000 421C (MATCHREL7)) bit description (REGMODEn bit = 0)

| Bit   | Symbol | Description                                                                                                                                                                                   | Reset<br>value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 15:0  |        | When UNIFY = 0, specifies the 16-bit value to be loaded into the SCTMATCHn_L register. When UNIFY = 1, specifies the lower 16 bits of the 32-bit value to be loaded into the MATCHn register. | 0              |
| 31:16 | _      | When $UNIFY = 0$ , specifies the 16-bit to be loaded into the MATCHn_H register. When $UNIFY = 1$ , specifies the upper 16 bits of the 32-bit value to be loaded into the MATCHn register.    | 0              |

# 16.6.23 SCT capture control registers 0 to 7 (REGMODEn bit = 1)

If UNIFY = 1 in the CONFIG register, only the \_L bits are used.

If UNIFY = 0 in the CONFIG register, this register can be written to as two registers CAPCTRLn\_L and CAPCTRLn\_H. Both the L and H registers can be read or written individually or in a single 32-bit read or write operation.

Based on a selected event, the capture registers can be loaded with the current counter value when the event occurs.

Each Capture Control register (L, H, or unified 32-bit) controls which events cause loading of the corresponding Capture register from the counter.

| (CAPCTRED) to 0x3000 421C (CAPCTRED)) bit description (REGMODEN bit = 1) |           |                                                                                                                                                                  |                |  |  |
|--------------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|
| Bit                                                                      | Symbol    | Description                                                                                                                                                      | Reset<br>value |  |  |
| 7:0                                                                      | CAPCONn_L | If bit m is one, event m causes the CAPn_L (UNIFY = 0) or the CAPn (UNIFY = 1) register to be loaded (event $0 = bit 0$ , event $1 = bit 1,, event 7 = bit 7$ ). | 0              |  |  |
| 15:8                                                                     | -         | Reserved.                                                                                                                                                        | -              |  |  |
| 23:16                                                                    | CAPCONn_H | If bit m is one, event m causes the CAPn_H (UNIFY = 0) register to be loaded (event 0 = bit 16, event 1 = bit 17,, event 7 = bit 23).                            | 0              |  |  |
| 31:24                                                                    | -         | Reserved.                                                                                                                                                        | -              |  |  |

# Table 242. SCT capture control registers 0 to 7 (CAPCTRL[0:7], address 0x5000 4200 (CAPCTRL0) to 0x5000 421C (CAPCTRL7)) bit description (REGMODEn bit = 1)

### 16.6.24 SCT event enable registers 0 to 7

Each event can be enabled in selected states and disabled in others. Each event defined in the EV\_CTRL register has one associated event enable register that can enable or disable the event for each available state.

Each event has one associated SCT event state mask register that allow this event to happen in one or more states of the counter selected by the HEVENT bit in the corresponding EVn\_CTRL register.

UM11021

An event n is disabled when its EVn\_STATE register contains all zeros, since it is masked regardless of the current state.

In simple applications that do not use states, write 0x01 to this register to enable each event in exactly one state. Since the state doesn't change (that is, the state variable always remains at its reset value of 0), writing 0x01 permanently enables this event.

# Table 243. SCT event state mask registers 0 to 7 (EV[0:7]\_STATE, addresses 0x5000 4300 (EV0\_STATE) to 0x5000 4338 (EV7\_STATE)) bit description

| Bit  | Symbol | Description                                                                                                                                                              | Reset<br>value |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  |        | If bit m is one, event n (n= 0 to 7) happens in state m of the counter selected by the HEVENT bit (m = state number; state 0 = bit 0, state 1= bit 1,, state 7 = bit 7). | 0              |
| 31:8 | -      | Reserved.                                                                                                                                                                | -              |

# 16.6.25 SCT event control registers 0 to 7

This register defines the conditions for an event to occur based on the counter values or input and output states. Once the event is configured, it can trigger any of the actions for which it has been selected (for example stop the counter and toggle an output) unless the event is blocked in the current state of the SCT or the counter is halted. To block a particular event from occurring in any given context, use the EV\_STATE register. To block all events for a given counter, set the HALT bit in the CTRL register or select an event to halt the counter.

An event can be programmed to occur based on a selected input or output edge or level and/or based on its counter value matching a selected match register. In bi-directional mode, events can also be enabled based on the direction of count.

When the UNIFY bit is 0, each event is associated with a particular counter by the HEVENT bit in its event control register. An event is permanently disabled when its event state mask register contains all 0s.

Each event can modify its counter STATE value. If more than one event associated with the same counter occurs in a given clock cycle, only the state change specified for the highest-numbered event among them takes place. Other actions dictated by any simultaneously occurring events all take place.

| Bit | Symbol   | Value | Description                                                                                                                                    | Reset<br>value |  |
|-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|
| 3:0 | MATCHSEL | -     | Selects the Match register associated with this event (if any). A match can occur only when the counter selected by the HEVENT bit is running. | 0              |  |
| 4   | HEVENT   |       | Select L/H counter. Do not set this bit if UNIFY = 1.                                                                                          | 0              |  |
|     |          | 0     | Selects the L state and the L match register selected by MATCHSEL.                                                                             |                |  |
|     |          | 1     | Selects the H state and the H match register selected by MATCHSEL.                                                                             |                |  |
| 5 ( | OUTSEL   |       | Input/output select                                                                                                                            | 0              |  |
|     |          | 0     | Selects the inputs elected by IOSEL.                                                                                                           |                |  |
|     |          | 1     | Selects the outputs selected by IOSEL.                                                                                                         |                |  |

# Table 244. SCT event control register 0 to 7 (EV[0:7]\_CTRL, address 0x5000 4304 (EV0\_CTRL) to 0x5000 433C (EV7\_CTRL)) bit description

| Table 244. | CT event control register 0 to 7 (EV[0:7]_CTRL, address 0x5000 4304 (EV0_CTRL) to 0x5000 433C |  |
|------------|-----------------------------------------------------------------------------------------------|--|
|            | EV7_CTRL)) bit description                                                                    |  |

| Bit   | Symbol    | Value | Description                                                                                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 9:6   | IOSEL     | -     | Selects the input or output signal number (0 to 3 for inputs or 0 to 5 for outputs) associated with this event (if any). Do not select an input in this register, if CLKMODE is 1x. In this case the clock input is an implicit ingredient of every event.                                                                  |                |
| 11:10 | IOCOND    |       | Selects the I/O condition for event n. (The detection of edges on outputs lag the conditions that switch the outputs by one SCT clock). In order to guarantee proper edge/state detection, an input must have a minimum pulse width of at least one SCT clock period.                                                       | 0              |
|       |           | 0x0   | LOW                                                                                                                                                                                                                                                                                                                         |                |
|       |           | 0x1   | Rise                                                                                                                                                                                                                                                                                                                        |                |
|       |           | 0x2   | Fall                                                                                                                                                                                                                                                                                                                        |                |
|       |           | 0x3   | HIGH                                                                                                                                                                                                                                                                                                                        |                |
| 13:12 | COMBMODE  |       | Selects how the specified match and I/O condition are used and combined.                                                                                                                                                                                                                                                    |                |
|       |           | 0x0   | OR. The event occurs when either the specified match or I/O condition occurs.                                                                                                                                                                                                                                               |                |
|       |           | 0x1   | MATCH. Uses the specified match only.                                                                                                                                                                                                                                                                                       |                |
|       |           | 0x2   | IO. Uses the specified I/O condition only.                                                                                                                                                                                                                                                                                  |                |
|       |           | 0x3   | AND. The event occurs when the specified match and I/O condition occur simultaneously.                                                                                                                                                                                                                                      |                |
| 14    | STATELD   |       | This bit controls how the STATEV value modifies the state selected by HEVENT when this event is the highest-numbered event occurring for that state.                                                                                                                                                                        |                |
|       |           | 0     | STATEV value is added into STATE (the carry-out is ignored).                                                                                                                                                                                                                                                                |                |
|       |           | 1     | STATEV value is loaded into STATE.                                                                                                                                                                                                                                                                                          |                |
| 19:15 | STATEV    |       | This value is loaded into or added to the state selected by HEVENT, depending on STATELD, when this event is the highest-numbered event occurring for that state. If STATELD and STATEV are both zero, there is no change to the STATE value.                                                                               |                |
| 20    | MATCHMEM  |       | If this bit is one and the COMBMODE field specifies a match component to the triggering of this event, then a match is considered to be active whenever the counter value is GREATER THAN OR EQUAL TO the value specified in the match register when counting up, LESS THEN OR EQUAL TO the match value when counting down. |                |
|       |           |       | If this bit is zero, a match is only be active during the cycle when the counter is equal to the match value.                                                                                                                                                                                                               |                |
| 22:21 | DIRECTION |       | Direction qualifier for event generation. This field only applies when the counters are operating in BIDIR mode. If BIDIR = 0, the SCT ignores this field. Value 0x3 is reserved.                                                                                                                                           |                |
|       |           | 0x0   | Direction independent. This event is triggered regardless of the count direction.                                                                                                                                                                                                                                           |                |
|       |           | 0x1   | Counting up. This event is triggered only during up-counting when BIDIR = 1.                                                                                                                                                                                                                                                |                |
|       |           | 0x2   | Counting down. This event is triggered only during down-counting when BIDIR = 1.                                                                                                                                                                                                                                            |                |
| 31:23 | -         |       | Reserved                                                                                                                                                                                                                                                                                                                    |                |

# 16.6.26 SCT output set registers 0 to 5

Based on a selected event, each SCT output can be set.

There is one output set register for each SCT output which selects which events can set that output. Each bit of an output set register is associated with a different event (bit 0 with event 0, etc.). A selected event can set or clear the output depending on the setting of the SETCLRn field in the OUTPUTDIRCTRL register. To define the actual event that sets the output (a match, an I/O pin toggle, etc.), see the EVn\_CTRL register.

**Remark:** If the SCTimer/PWM is operating as two 16-bit counters, events can only modify the state of the outputs when neither counter is halted. This is true regardless of what triggered the event.

# Table 245. SCT output set register (OUT[0:5]\_SET, address 0x5000 4500 (OUT0\_SET) to 0x5000 4528 (OUT5\_SET) bit description

| Bit     | Symbol | Description                                                                                                                                                                            | Reset<br>value |
|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0 SET |        | A 1 in bit m selects event m to set output n (or clear it if SETCLRn = 0x1 or 0x2) event 0 = bit 0, event 1 = bit 1,, event 7 = bit 7.                                                 |                |
|         |        | When the counter is used in bi-directional mode, it is possible to reverse the action specified by the output set and clear registers when counting down, See the OUTPUTCTRL register. |                |
| 31:8    | -      | Reserved                                                                                                                                                                               |                |

## 16.6.27 SCT output clear registers 0 to 5

Based on a selected event, each SCT output can be cleared.

There is one register for each SCT output which selects which events can clear that output. Each bit of an output clear register is associated with a different event (bit 0 with event 0, etc.). A selected event can clear or set the output depending on the setting of the SETCLRn field in the OUTPUTDIRCTRL register. To define the actual event that clears the output (a match, an I/O pin toggle, etc.), see the EVn\_CTRL register.

**Remark:** If the SCTimer/PWM is operating as two 16-bit counters, events can only modify the state of the outputs when neither counter is halted. This is true regardless of what triggered the event.

| Bit  | Symbol | Description                                                                                                                                                                            | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0  | CLR    | A 1 in bit m selects event m to clear output n (or set it if SETCLRn = 0x1 or 0x2) event 0 = bit 0, event 1 = bit 1,, event 7 = bit 7.                                                 | 0              |
|      |        | When the counter is used in bi-directional mode, it is possible to reverse the action specified by the output set and clear registers when counting down, See the OUTPUTCTRL register. |                |
| 31:8 | -      | Reserved                                                                                                                                                                               |                |

# Table 246. SCT output clear register (OUT[0:5]\_CLR, address 0x5000 4504 (OUT0\_CLR) to 0x5000 452C (OUT5\_CLR)) bit description

# **16.7 Functional description**

# 16.7.1 Match logic



# 16.7.2 Capture logic



# 16.7.3 Event selection

State variables allow control of the SCT across more than one cycle of the counter. Counter matches, input/output edges, and state values are combined into a set of general-purpose events that can switch outputs, request interrupts, and change state values.

UM11021



### 16.7.4 Output generation

Figure 39 shows one output slice of the SCT.



### 16.7.5 State logic

The SCT can be configured as a timer/counter with multiple programmable states. The states are user-defined through the events that can be captured in each particular state. In a multi-state SCT, the SCT can change from one state to another state when a user-defined event triggers a state change. The state change is triggered through each event's EV\_CTRL register in one of the following ways:

- The event can increment the current state number by a new value.
- The event can write a new state value.

If an event increments the state number beyond the number of available states, the SCT enters a locked state in which all further events are ignored while the counter is still running. Software must interfere to change out of this state.

Software can capture the counter value (and potentially create an interrupt and write to all outputs) when the event moving the SCT into a locked state occurs.Later, while the SCT is in the locked state, software can read the counter again to record the time passed since the locking event and can also read the state variable to obtain the current state number

If the SCT registers an event that forces an abort, putting the SCT in a locked state can be a safe way to record the time that has passed since the abort event while no new events are allowed to occur. Since multiple states (any state number between the maximum implemented state and 31) are locked states, multiple abort or error events can be defined each incrementing the state number by a different value.

## 16.7.6 Interrupt generation

The SCT generates one interrupt to the NVIC.



# 16.7.7 Clearing the prescaler

When enabled by a non-zero PRE field in the Control register, the prescaler acts as a clock divider for the counter, like a fractional part of the counter value. The prescaler is cleared whenever the counter is cleared or loaded for any of the following reasons:

- Hardware reset
- Software writing to the counter register
- Software writing a 1 to the CLRCTR bit in the control register
- an event selected by a 1 in the counter limit register when BIDIR = 0

When BIDIR is 0, a limit event caused by an I/O signal can clear a non-zero prescaler. However, a limit event caused by a Match only clears a non-zero prescaler in one special case as described <u>Section 16.7.8</u>.

A limit event when BIDIR is 1 does not clear the prescaler. Rather it clears the DOWN bit in the Control register, and decrements the counter on the same clock if the counter is enabled in that clock.

### 16.7.8 Match vs. I/O events

Counter operation is complicated by the prescaler and by clock mode 01 in which the SCT clock is the bus clock. However, the prescaler and counter are enabled to count only when a selected edge is detected on a clock input.

UM11021

- The prescaler is enabled when the clock mode is not 01, or when the input edge selected by the CLKSEL field is detected.
- The counter is enabled when the prescaler is enabled, and (PRELIM=0 or the prescaler is equal to the value in PRELIM).

An I/O component of an event can occur in any SCT clock when its counter HALT bit is 0. In general, a Match component of an event can only occur in a UT clock when its counter HALT and STOP bits are both 0 and the counter is enabled.

Table 247 shows when the various kinds of events can occur.

| COMBMODE | IOMODE       | Event can occur on clock:                                                                                                                                                 |
|----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IO       | Any          | Event can occur whenever HALT = 0 (type A).                                                                                                                               |
| MATCH    | Any          | Event can occur when HALT = 0 and STOP = 0 and the counter is enabled (type C).                                                                                           |
| OR       | Any          | From the IO component: Event can occur whenever $HALT = 0$ (A).<br>From the match component: Event can occur when $HALT = 0$ and STOP = 0 and the counter is enabled (C). |
| AND      | LOW or HIGH  | Event can occur when HALT = 0 and STOP = 0 and the counter is enabled (C).                                                                                                |
| AND      | RISE or FALL | Event can occur whenever HALT = 0 (A).                                                                                                                                    |

### Table 247. Event conditions

**User manual** 

## 16.7.9 SCT operation

In its simplest, single-state configuration, the SCT operates as an event controlled one- or bidirectional counter. Events can be configured to be counter match events, an input or output level, transitions on an input or output pin, or a combination of match and input/output behavior. In response to an event, the SCT output or outputs can transition, or the SCT can perform other actions such as creating an interrupt or starting, stopping, or resetting the counter. Multiple simultaneous actions are allowed for each event. Furthermore, any number of events can trigger one specific action of the SCT.

An action or multiple actions of the SCT uniquely define an event. A state is defined by which events are enabled to trigger an SCT action or actions in any stage of the counter. Events not selected for this state are ignored.

In a multi-state configuration, states change in response to events. A state change is an additional action that the SCT can perform when the event occurs. When an event is configured to change the state, the new state defines a new set of events resulting in different actions of the SCT. Through multiple cycles of the counter, events can change the state multiple times and thus create a large variety of event controlled transitions on the SCT outputs and/or interrupts.

Once configured, the SCT can run continuously without software intervention and can generate multiple output patterns entirely under the control of events.

- To configure the SCT, see Section 16.7.10.
- To start, run, and stop the SCT, see Section 16.7.11.
- To configure the SCT as simple event controlled counter/timer, see Section 16.7.12.

### 16.7.10 Configure the SCT

To set up the SCT for multiple events and states, perform the following configuration steps:

### 16.7.10.1 Configure the counter

- Configure the L and H counters in the CONFIG register by selecting two independent 16-bit counters (L counter and H counter) or one combined 32-bit counter in the UNIFY field.
- 2. Select the SCT clock source in the CONFIG register (fields CLKMODE and CLKSEL) from any of the inputs or an internal clock.

### 16.7.10.2 Configure the match and capture registers

- 1. Select how many match and capture registers the application uses (total of up to 5):
  - In the REGMODE register, select for each of the 5 match/capture register pairs whether the register is used as a match register or capture register.
- 2. Define match conditions for each match register selected:
  - Each match register MATCH sets one match value, if a 32-bit counter is used, or two match values, if the L and H 16-bit counters are used.
  - Each match reload register MATCHRELOAD sets a reload value that is loaded into the match register when the counter reaches a limit condition or the value 0.

### 16.7.10.3 Configure events and event responses

- 1. Define when each event can occur in the following way in the EVn\_CTRL registers (up to 6, one register per event):
  - Select whether the event occurs on an input or output changing, on an input or output level, a match condition of the counter, or a combination of match and input/output conditions in field COMBMODE.
  - For a match condition:

Select the match register that contains the match condition for the event to occur. Enter the number of the selected match register in field MATCHSEL.

If using L and H counters, define whether the event occurs on matching the L or the H counter in field HEVENT.

- For an SCT input or output level or transition:

Select the input number or the output number that is associated with this event in fields IOSEL and OUTSEL.

Define how the selected input or output triggers the event (edge or level sensitive) in field IOCOND.

- Define what the effect of each event is on the SCT outputs in the OUTn\_SET or OUTn\_CLR registers (up to 4 outputs, one register per output):
  - For each SCT output, select which events set or clear this output. More than one event can change the output, and each event can change multiple outputs.
- 3. Define how each event affects the counter:
  - Set the corresponding event bit in the LIMIT register for the event to set an upper limit for the counter.

When a limit event occurs in unidirectional mode, the counter is cleared to zero and begins counting up on the next clock edge.

When a limit event occurs in bidirectional mode, the counter begins to count down from the current value on the next clock edge.

- Set the corresponding event bit in the HALT register for the event to halt the counter. If the counter is halted, it stops counting and no new events can occur. The counter operation can only be restored by clearing the HALT\_L and/or the HALT\_H bits in the CTRL register.
- Set the corresponding event bit in the STOP register for the event to stop the counter. If the counter is stopped, it stops counting. However, an event that is configured as a transition on an input/output can restart the counter.
- Set the corresponding event bit in the START register for the event to restart the counting. Only events that are defined by an input changing can be used to restart the counter.
- 4. Define which events contribute to the SCT interrupt:
  - Set the corresponding event bit in the EVEN and the EVFLAG registers to enable the event to contribute to the SCT interrupt.

### 16.7.10.4 Configure multiple states

- 1. In the EVn\_STATE register for each event (up to 6 events, one register per event), select the state or states (up to 2) in which this event is allowed to occur. Each state can be selected for more than one event.
- 2. Determine how the event affects the system state:

In the EVn\_CTRL registers (up to 6 events, one register per event), set the new state value in the STATEV field for this event. If the event is the highest numbered in the current state, this value is either added to the existing state value or replaces the existing state value, depending on the field STATELD.

**Remark:** If there are higher numbered events in the current state, this event cannot change the state.

If the STATEV and STATELD values are set to zero, the state does not change.

### 16.7.10.5 Miscellaneous options

- There are a certain (selectable) number of capture registers. Each capture register can be programmed to capture the counter contents when one or more events occur.
- If the counter is in bidirectional mode, the effect of set and clear of an output can be made to depend on whether the counter is counting up or down by writing to the OUTPUTDIRCTRL register.

### 16.7.11 Run the SCT

- 1. Configure the SCT (see Section 16.7.10 "Configure the SCT").
- Write to the STATE register to define the initial state. By default the initial state is state 0.
- 3. To start the SCT, write to the CTRL register:
  - Clear the counters.
  - Clear or set the STOP\_L and/or STOP\_H bits.

**Remark:** The counter starts counting once the STOP bit is cleared as well. If the STOP bit is set, the SCT waits instead for an event to occur that is configured to start the counter.

- For each counter, select unidirectional or bidirectional counting mode (field BIDIR\_L and/or BIDIR\_H).
- Select the prescale factor for the counter clock (CTRL register).
- Clear the HALT\_L and/or HALT\_H bit. By default, the counters are halted and no events can occur.
- To stop the counters by software at any time, stop or halt the counter (write to STOP\_L and/or STOP\_H bits or HALT\_L and/or HALT\_H bits in the CTRL register).
  - When the counters are stopped, both an event configured to clear the STOP bit or software writing a zero to the STOP bit can start the counter again.
  - When the counter are halted, only a software write to clear the HALT bit can start the counter again. No events can occur.
  - When the counters are halted, software can set any SCT output HIGH or LOW directly by writing to the OUT register.

UM11021

The current state can be read at any time by reading the STATE register.

To change the current state by software (that is independently of any event occurring), set the HALT bit and write to the STATE register to change the state value. Writing to the STATE register is only allowed when the counter is halted (the HALT\_L and/or HALT\_H bits are set) and no events can occur.

## 16.7.12 Configure the SCT without using states

The SCT can be used as standard counter/timer with external capture inputs and match outputs without using the state logic. To operate the SCT without states, configure the SCT as follows:

- Write zero to the STATE register (zero is the default).
- Write zero to the STATELD and STATEV fields in the EVCTRL registers for each event.
- Write 0x1 to the EVn\_STATE register of each event. Writing 0x1 enables the event.

In effect, the event is allowed to occur in a single state which never changes while the counter is running.

### 16.7.13 SCT PWM Example

Figure 41 shows a simple application of the SCT using two sets of match events (EV0/1 and EV3/4) to set/clear SCT output 0. The timer is automatically reset whenever it reaches the MAT0 match value.

In the initial state 0, match event EV0 sets output 0 to HIGH and match event EV1 clears output 0. The SCT input 0 is monitored: If input0 is found LOW by the next time the timer is reset(EV2), the state is changed to state 1, and EV3/4 are enabled, which create the same output but triggered by different match values. If input 0 is found HIGH by the next time the timer is reset, the associated event (EV5) causes the state to change back to state 0where the events EV0 and EV1 are enabled.

The example uses the following SCT configuration:

- 1 input
- 1 output
- 5 match registers
- 6 events and match 0 used with autolimit function
- 2 states



This application of the SCT uses the following configuration (all register values not listed in <u>Table 248</u> are set to their default values):

| Configuration              | Registers         | Setting                                                                                                                                                                                                                                    |
|----------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter                    | CONFIG            | Uses one counter (UNIFY = 1).                                                                                                                                                                                                              |
|                            | CONFIG            | Enable the autolimit for MAT0. (AUTOLIMIT = 1.)                                                                                                                                                                                            |
|                            | CTRL              | Uses unidirectional counter (BIDIR_L = 0).                                                                                                                                                                                                 |
| Clock base                 | CONFIG            | Uses default values for clock configuration.                                                                                                                                                                                               |
| Match/Capture registers    | REGMODE           | Configure one match register for each match event by setting REGMODE_L bits 0,1, 2, 3, 4 to 0. This is the default.                                                                                                                        |
| Define match values        | MATCH0/1/2/3/4    | Set a match value MATCH0/1/2/4/5_L in each register. The match 0 register serves as an automatic limit event that resets the counter. without using an event. To enable the automatic limit, set the AUTOLIMIT bit in the CONFIG register. |
| Define match reload values | MATCHREL0/1/2/3/4 | Set a match reload value RELOAD0/1/2/3/4_L in each register (same as the match value in this example).                                                                                                                                     |
| Define when event 0 occurs | EV0_CTRL          | <ul> <li>Set COMBMODE = 0x1. Event 0 uses match condition only.</li> <li>Set MATCHSEL = 1. Select match value of match register 1.<br/>The match value of MAT1 is associated with event 0.</li> </ul>                                      |
| Define when event 1 occurs | EV1_CTRL          | <ul> <li>Set COMBMODE = 0x1. Event 1 uses match condition only.</li> <li>Set MATCHSEL = 2 Select match value of match register 2. The match value of MAT2 is associated with event 1.</li> </ul>                                           |

#### Table 248. SCT configuration example

### Table 248. SCT configuration example

| Configuration                                | Registers | Setting                                                                                                           |
|----------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------|
| Define when event 2 occurs                   | EV2_CTRL  | • Set COMBMODE = 0x3. Event 2 uses match condition and I/O condition.                                             |
|                                              |           | • Set IOSEL = 0. Select input 0.                                                                                  |
|                                              |           | • Set IOCOND = 0x0. Input 0 is LOW.                                                                               |
|                                              |           | <ul> <li>Set MATCHSEL = 0. Chooses match register 0 to qualify the event.</li> </ul>                              |
| Define how event 2 changes the state         | EV2_CTRL  | Set STATEV bits to 1 and the STATED bit to 1. Event 2 changes the state to state 1.                               |
| Define when event 3                          | EV3_CTRL  | • Set COMBMODE = 0x1. Event 3 uses match condition only.                                                          |
| occurs                                       |           | • Set MATCHSEL = 0x3. Select match value of match register 3. The match value of MAT3 is associated with event 3  |
| Define when event 4                          | EV4_CTRL  | • Set COMBMODE = 0x1. Event 4 uses match condition only.                                                          |
| occurs                                       |           | • Set MATCHSEL = 0x4. Select match value of match register 4. The match value of MAT4 is associated with event 4. |
| Define when event 5 occurs                   | EV5_CTRL  | <ul> <li>Set COMBMODE = 0x3. Event 5 uses match condition and I/O condition.</li> </ul>                           |
|                                              |           | • Set IOSEL = 0. Select input 0.                                                                                  |
|                                              |           | • Set IOCOND = 0x3. Input 0 is HIGH.                                                                              |
|                                              |           | <ul> <li>Set MATCHSEL = 0. Chooses match register 0 to qualify the<br/>event.</li> </ul>                          |
| Define how event 5 changes the state         | EV5_CTRL  | Set STATEV bits to 0 and the STATED bit to 1. Event 5 changes the state to state 0.                               |
| Define by which events<br>output 0 is set    | OUT0_SET  | Set SET0 bits 0 (for event 0) and 3 (for event 3) to one to set the output when these events 0 and 3 occur.       |
| Define by which events output 0 is cleared   | OUT0_CLR  | Set CLR0 bits 1 (for events 1) and 4 (for event 4) to one to clear the output when events 1 and 4 occur.          |
| Configure states in which event 0 is enabled | EV0_STATE | Set STATEMSK0 bit 0 to 1. Set all other bits to 0. Event 0 is enabled in state 0.                                 |
| Configure states in which event 1 is enabled | EV1_STATE | Set STATEMSK1 bit 0 to 1. Set all other bits to 0. Event 1 is enabled in state 0.                                 |
| Configure states in which event 2 is enabled | EV2_STATE | Set STATEMSK2 bit 0 to 1. Set all other bits to 0. Event 2 is enabled in state 0.                                 |
| Configure states in which event 3 is enabled | EV3_STATE | Set STATEMSK3 bit 1 to 1. Set all other bits to 0. Event 3 is enabled in state 1.                                 |
| Configure states in which event 4 is enabled | EV4_STATE | Set STATEMSK4 bit 1 to 1. Set all other bits to 0. Event 4 is enabled in state 1.                                 |
| Configure states in which event 5 is enabled | EV5_STATE | Set STATEMSK5 bit 1 to 1. Set all other bits to 0. Event 5 is enabled in state 1.                                 |
|                                              |           |                                                                                                                   |

Chapter 17: LPC83x Windowed Watchdog Timer (WWDT)

Rev. 1.1 — 5 October 2016

User manual

# 17.1 How to read this chapter

The watchdog timer is identical on all LPC83x parts.

# **17.2 Features**

- Internally resets chip if not reloaded during the programmable time-out period.
- Optional windowed operation requires reload to occur between a minimum and maximum time-out period, both programmable.
- Optional warning interrupt can be generated at a programmable time prior to watchdog time-out.
- Programmable 24-bit timer with internal fixed pre-scaler.
- Selectable time period from 1,024 watchdog clocks ( $T_{WDCLK} \times 256 \times 4$ ) to over 67 million watchdog clocks ( $T_{WDCLK} \times 2^{24} \times 4$ ) in increments of 4 watchdog clocks.
- "Safe" watchdog operation. Once enabled, requires a hardware reset or a Watchdog reset to be disabled.
- Incorrect feed sequence causes immediate watchdog event if enabled.
- The watchdog reload value can optionally be protected such that it can only be changed after the "warning interrupt" time is reached.
- Flag to indicate Watchdog reset.
- The Watchdog clock (WDCLK) source is the WatchDog oscillator.
- The Watchdog timer can be configured to run in Deep-sleep or Power-down mode.
- Debug mode.

# **17.3 Basic configuration**

The WWDT is configured through the following registers:

- Power to the register interface (WWDT PCLK clock): In the SYSAHBCLKCTRL register, set bit 17 in <u>Table 33</u>.
- Enable the WWDT clock source (the watchdog oscillator) in the PDRUNCFG register (Table 52). This is the clock source for the timer base.
- For waking up from a WWDT interrupt, enable the watchdog interrupt for wake-up in the STARTERP1 register (Table 49).



# 17.4 Pin description

The WWDT has no external pins.

# **17.5 General description**

The purpose of the Watchdog Timer is to reset or interrupt the microcontroller within a programmable time if it enters an erroneous state. When enabled, a watchdog reset is generated if the user program fails to feed (reload) the Watchdog within a predetermined amount of time.

When a watchdog window is programmed, an early watchdog feed is also treated as a watchdog event. This allows preventing situations where a system failure may still feed the watchdog. For example, application code could be stuck in an interrupt service that contains a watchdog feed. Setting the window such that this would result in an early feed will generate a watchdog event, allowing for system recovery.

The Watchdog consists of a fixed (divide by 4) pre-scaler and a 24-bit counter which decrements when clocked. The minimum value from which the counter decrements is 0xFF. Setting a value lower than 0xFF causes 0xFF to be loaded in the counter. Hence the minimum Watchdog interval is ( $T_{WDCLK} \times 256 \times 4$ ) and the maximum Watchdog interval is ( $T_{WDCLK} \times 2^{24} \times 4$ ) in multiples of ( $T_{WDCLK} \times 4$ ). The Watchdog should be used in the following manner:

- Set the Watchdog timer constant reload value in the TC register.
- Set the Watchdog timer operating mode in the MOD register.
- Set a value for the watchdog window time in the WINDOW register if windowed operation is desired.
- Set a value for the watchdog warning interrupt in the WARNINT register if a warning interrupt is desired.
- Enable the Watchdog by writing 0xAA followed by 0x55 to the FEED register.
- The Watchdog must be fed again before the Watchdog counter reaches zero in order to prevent a watchdog event. If a window value is programmed, the feed must also occur after the watchdog counter passes that value.

**User manual** 

When the Watchdog Timer is configured so that a watchdog event will cause a reset and the counter reaches zero, the CPU will be reset, loading the stack pointer and program counter from the vector table as for an external reset. The Watchdog time-out flag (WDTOF) can be examined to determine if the Watchdog has caused the reset condition. The WDTOF flag must be cleared by software.

When the Watchdog Timer is configured to generate a warning interrupt, the interrupt will occur when the counter matches the value defined by the WARNINT register.

# 17.5.1 Block diagram

The block diagram of the Watchdog is shown below in the <u>Figure 43</u>. The synchronization logic (PCLK - WDCLK) is not shown in the block diagram.



# 17.5.2 Clocking and power control

The watchdog timer block uses two clocks: PCLK and WDCLK. PCLK is used for the APB accesses to the watchdog registers and is derived from the system clock (see Figure 4). The WDCLK is used for the watchdog timer counting and is derived from the watchdog oscillator.

The synchronization logic between the two clock domains works as follows: When the MOD and TC registers are updated by APB operations, the new value will take effect in 3 WDCLK cycles on the logic in the WDCLK clock domain.

When the watchdog timer is counting on WDCLK, the synchronization logic will first lock the value of the counter on WDCLK and then synchronize it with PCLK, so that the CPU can read the WDTV register.

UM11021

#### Chapter 17: LPC83x Windowed Watchdog Timer (WWDT)

**Remark:** Because of the synchronization step, software must add a delay of three WDCLK clock cycles between the feed sequence and the time the WDPROTECT bit is enabled in the MOD register. The length of the delay depends on the selected watchdog clock WDCLK.

**User manual** 

### 17.5.3 Using the WWDT lock features

The WWDT supports several lock features which can be enabled to ensure that the WWDT is running at all times:

- Disabling the WWDT clock source
- Changing the WWDT reload value

#### 17.5.3.1 Disabling the WWDT clock source

If bit 5 in the WWDT MOD register is set, the WWDT clock source is locked and can not be disabled either by software or by hardware when Sleep, Deep-sleep or Power-down modes are entered. Therefore, the user must ensure that the watchdog oscillator for each power mode is enabled **before** setting bit 5 in the MOD register.

In Deep power-down mode, no clock locking mechanism is in effect because no clocks are running. However, an additional lock bit in the PMU can be set to prevent the part from even entering Deep power-down mode (see <u>Table 59</u>).

#### 17.5.3.2 Changing the WWDT reload value

If bit 4 is set in the WWDT MOD register, the watchdog time-out value (TC) can be changed only after the counter is below the value of WDWARNINT and WDWINDOW.

The reload overwrite lock mechanism can only be disabled by a reset of any type.

# 17.6 Register description

The Watchdog Timer contains the registers shown in Table 249.

The reset value reflects the data stored in used bits only. It does not include the content of reserved bits.

| Name    | Access | Address<br>offset | Description                                                                                                                                           | Reset<br>value | Reference        |
|---------|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| MOD     | R/W    | 0x000             | Watchdog mode register. This register contains the basic mode and status of the Watchdog Timer.                                                       | 0              | <u>Table 250</u> |
| TC      | R/W    | 0x004             | Watchdog timer constant register.<br>This 24-bit register determines the<br>time-out value.                                                           | 0xFF           | <u>Table 252</u> |
| FEED    | WO     | 0x008             | Watchdog feed sequence register.<br>Writing 0xAA followed by 0x55 to this<br>register reloads the Watchdog timer<br>with the value contained in WDTC. | NA             | Table 253        |
| TV      | RO     | 0x00C             | Watchdog timer value register. This 24-bit register reads out the current value of the Watchdog timer.                                                | 0xFF           | <u>Table 254</u> |
| -       | -      | 0x010             | Reserved                                                                                                                                              | -              | -                |
| WARNINT | R/W    | 0x014             | Watchdog Warning Interrupt compare value.                                                                                                             | 0              | Table 255        |
| WINDOW  | R/W    | 0x018             | Watchdog Window compare value.                                                                                                                        | 0xFF FFFF      | Table 256        |

 Table 249. Register overview: Watchdog timer (base address 0x4000 0000)

# 17.6.1 Watchdog mode register

The WDMOD register controls the operation of the Watchdog. Note that a watchdog feed must be performed before any changes to the WDMOD register take effect.

| Bit | Symbol  | Value | Description                                                                                                                                                                                    | Reset<br>value                         |
|-----|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| 0   | WDEN    |       | Watchdog enable bit. Once this bit has been written with<br>a 1, it cannot be re-written with a 0. Once this bit is set<br>to one, the watchdog timer starts running after a<br>watchdog feed. | 0                                      |
|     |         | 0     | The watchdog timer is stopped.                                                                                                                                                                 |                                        |
|     |         | 1     | The watchdog timer is running.                                                                                                                                                                 |                                        |
| 1   | WDRESET |       | Watchdog reset enable bit. Once this bit has been written with a 1 it cannot be re-written with a 0.                                                                                           | 0                                      |
|     |         | 0     | A watchdog time-out will not cause a chip reset.                                                                                                                                               |                                        |
|     |         | 1     | A watchdog time-out will cause a chip reset.                                                                                                                                                   |                                        |
| 2   | WDTOF   |       | Watchdog time-out flag. Set when the watchdog timer<br>times out, by a feed error, or by events associated with<br>WDPROTECT. Cleared by software. Causes a chip<br>reset if WDRESET = 1.      | 0 (only<br>after<br>external<br>reset) |

UM11021

| Bit  | Symbol    | Value | Description                                                                                                                                         | Reset<br>value |
|------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3    | WDINT     |       | Warning interrupt flag. Set when the timer reaches the value in WDWARNINT. Cleared by software.                                                     | 0              |
| 4    | WDPROTECT |       | Watchdog update mode. This bit can be set once by software and is only cleared by a reset.                                                          | 0              |
|      |           | 0     | The watchdog time-out value (TC) can be changed at any time.                                                                                        | -              |
|      |           | 1     | The watchdog time-out value (TC) can be changed only after the counter is below the value of WDWARNINT and WDWINDOW.                                |                |
| 5    | LOCK      |       | A 1 in this bit prevents disabling or powering down the watchdog oscillator. This bit can be set once by software and is only cleared by any reset. | 0              |
| 31:6 | -         |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                  | NA             |

| Table 250. Wa | atchdog mode register | <sup>•</sup> (MOD, 0x4000 | 0000) bit description |
|---------------|-----------------------|---------------------------|-----------------------|
|---------------|-----------------------|---------------------------|-----------------------|

Once the **WDEN**, **WDPROTECT**, or **WDRESET** bits are set they can not be cleared by software. Both flags are cleared by an external reset or a Watchdog timer reset.

**WDTOF** The Watchdog time-out flag is set when the Watchdog times out, when a feed error occurs, or when PROTECT =1 and an attempt is made to write to the TC register. This flag is cleared by software writing a 0 to this bit.

**WDINT** The Watchdog interrupt flag is set when the Watchdog counter reaches the value specified by WARNINT. This flag is cleared when any reset occurs, and is cleared by software by writing a 0 to this bit.

In all power modes except Deep power-down mode, a Watchdog reset or interrupt can occur when the watchdog is running and has an operating clock source. The watchdog oscillator can be configured to keep running in Sleep, Deep-sleep modes, and Power-down modes.

If a watchdog interrupt occurs in Sleep, Deep-sleep mode, or Power-down mode, and the WWDT interrupt is enabled in the NVIC, the device will wake up. Note that in Deep-sleep and Power-down modes, the WWDT interrupt must be enabled in the STARTERP1 register in addition to the NVIC.

See the following registers:

Table 49 "Start logic 1 interrupt wake-up enable register (STARTERP1, address 0x4004 8214) bit description"

| WDEN | WDRESET    | Mode of Operation                                                                                                                                                                                                                                                                                                                         |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | X (0 or 1) | Debug/Operate without the Watchdog running.                                                                                                                                                                                                                                                                                               |
| 1    | 0          | Watchdog interrupt mode: the watchdog warning interrupt will be generated but watchdog reset will not.                                                                                                                                                                                                                                    |
|      |            | When this mode is selected, the watchdog counter reaching the value specified by WDWARNINT will set the WDINT flag and the Watchdog interrupt request will be generated.                                                                                                                                                                  |
| 1    | 1          | Watchdog reset mode: both the watchdog interrupt and watchdog reset are enabled.                                                                                                                                                                                                                                                          |
|      |            | When this mode is selected, the watchdog counter reaching the value specified by WDWARNINT will set the WDINT flag and the Watchdog interrupt request will be generated, and the watchdog counter reaching zero will reset the microcontroller. A watchdog feed prior to reaching the value of WDWINDOW will also cause a watchdog reset. |

#### Table 251. Watchdog operating modes selection

#### 17.6.2 Watchdog Timer Constant register

The TC register determines the time-out value. Every time a feed sequence occurs the value in the TC is loaded into the Watchdog timer. The TC resets to 0x00 00FF. Writing a value below 0xFF will cause 0x00 00FF to be loaded into the TC. Thus the minimum time-out interval is  $T_{WDCLK} \times 256 \times 4$ .

If the WDPROTECT bit in WDMOD = 1, an attempt to change the value of TC before the watchdog counter is below the values of WDWARNINT and WDWINDOW will cause a watchdog reset and set the WDTOF flag.

| Table | Table 252. Watchdog Timer Constant register (TC, 0x4000 0004) bit description |             |       |  |  |  |
|-------|-------------------------------------------------------------------------------|-------------|-------|--|--|--|
| Bit   | Symbol                                                                        | Description | Reset |  |  |  |
|       |                                                                               |             | Value |  |  |  |

|       |       |                                                                                                                    | Value     |
|-------|-------|--------------------------------------------------------------------------------------------------------------------|-----------|
| 23:0  | COUNT | Watchdog time-out value.                                                                                           | 0x00 00FF |
| 31:24 | -     | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA        |

# 17.6.3 Watchdog Feed register

Writing 0xAA followed by 0x55 to this register will reload the Watchdog timer with the WDTC value. This operation will also start the Watchdog if it is enabled via the WDMOD register. Setting the WDEN bit in the WDMOD register is not sufficient to enable the Watchdog. A valid feed sequence must be completed after setting WDEN before the Watchdog is capable of generating a reset. Until then, the Watchdog will ignore feed errors.

After writing 0xAA to WDFEED, access to any Watchdog register other than writing 0x55 to WDFEED causes an immediate reset/interrupt when the Watchdog is enabled, and sets the WDTOF flag. The reset will be generated during the second PCLK following an incorrect access to a Watchdog register during a feed sequence.

It is good practice to disable interrupts around a feed sequence, if the application is such that an interrupt might result in rescheduling processor control away from the current task in the middle of the feed, and then lead to some other access to the WDT before control is returned to the interrupted task.

UM11021

| Bit  | Symbol | Description                                                                                                           | Reset Value |
|------|--------|-----------------------------------------------------------------------------------------------------------------------|-------------|
| 7:0  | FEED   | Feed value should be 0xAA followed by 0x55.                                                                           | NA          |
| 31:8 | -      | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined. | NA          |

#### Table 253. Watchdog Feed register (FEED, 0x4000 0008) bit description

### 17.6.4 Watchdog Timer Value register

The WDTV register is used to read the current value of Watchdog timer counter.

When reading the value of the 24-bit counter, the lock and synchronization procedure takes up to 6 WDCLK cycles plus 6 PCLK cycles, so the value of WDTV is older than the actual value of the timer when it's being read by the CPU.

| Bit   | Symbol | Description                                                                                                        | Reset<br>Value |
|-------|--------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | COUNT  | Counter timer value.                                                                                               | 0x00 00FF      |
| 31:24 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

# 17.6.5 Watchdog Timer Warning Interrupt register

The WDWARNINT register determines the watchdog timer counter value that will generate a watchdog interrupt. When the watchdog timer counter matches the value defined by WARNINT, an interrupt will be generated after the subsequent WDCLK.

A match of the watchdog timer counter to WARNINT occurs when the bottom 10 bits of the counter have the same value as the 10 bits of WARNINT, and the remaining upper bits of the counter are all 0. This gives a maximum time of 1,023 watchdog timer counts (4,096 watchdog clocks) for the interrupt to occur prior to a watchdog event. If WARNINT is 0, the interrupt will occur at the same time as the watchdog event.

 Table 255. Watchdog Timer Warning Interrupt register (WARNINT, 0x4000 0014) bit description

| Bit   | Symbol  | Description                                                                                                        | Reset<br>Value |
|-------|---------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 9:0   | WARNINT | Watchdog warning interrupt compare value.                                                                          | 0              |
| 31:10 | -       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

#### 17.6.6 Watchdog Timer Window register

The WINDOW register determines the highest WDTV value allowed when a watchdog feed is performed. If a feed sequence occurs when WDTV is greater than the value in WINDOW, a watchdog event will occur.

WINDOW resets to the maximum possible WDTV value, so windowing is not in effect.

#### Chapter 17: LPC83x Windowed Watchdog Timer (WWDT)

Table 256. Watchdog Timer Window register (WINDOW, 0x4000 0018) bit description

| Bit   | Symbol | Description                                                                                                           | Reset<br>Value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | WINDOW | Watchdog window value.                                                                                                | 0xFF FFFF      |
| 31:24 | -      | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined. | NA             |

# **17.7 Functional description**









Chapter 18: LPC83x Self-wake-up timer (WKT)

Rev. 1.1 — 5 October 2016

**User manual** 

# 18.1 How to read this chapter

The self-wake-up timer is available on all LPC83x parts.

# **18.2 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: The IRC, the internal low-power oscillator, or the WKTCLKIN pin. The low-power oscillator and the external clock are valid clock sources in all power modes including deep power-down. The IRC can be used in sleep and active mode only.
- Depending on the clock source, the WKT can be used for waking up the part from any low power mode or for general-purpose timing.

# **18.3 Basic configuration**

- In the SYSAHBCLKCTRL register, set bit 9 (<u>Table 33</u>) to enable the clock to the register interface.
- Clear the WKT reset using the PRESETCTRL register (<u>Table 21</u>).
- The WKT interrupt is connected to interrupt #15 in the NVIC. See <u>Table 4</u>.
- Enable the low power oscillator in the PMU (Table 61).
- Enable the IRC and IRC output in the PDRUNCFG register if used as the clock source for the timer (Table 52).
- To use an external clock source for the self-wake-up timer, enable the clock input for pin PIO0\_28 in the DPDCRTL register (<u>Table 61</u>) and enable the external clock option in the self-wake-up timer CTRL register (see <u>Table 258</u>). The external clock source can be used in all power modes including deep power-down mode.
- Disable the external clock input in the DPDCTRL register to minimize power consumption if not using the external clock source option. See Table 61.
- Disable the WAKEUP function in the DPDCTRL register to minimize power consumption if the part does not need to wake up from deep power-down mode via a pin. See <u>Table 61</u>.
- See <u>Section 6.7.1</u> to enable the various power down modes.

### Chapter 18: LPC83x Self-wake-up timer (WKT)

UM11021



# **18.4 Pin description**

The WKT can use a clock input on the external pin PIO0\_28 for clocking the wake-up timer in sleep, deep-sleep, power-down, and deep power-down modes. Select the external clock source by setting bit SET\_EXTCLK in the CTRL register (see <u>Table 258</u>).

# **18.5 General description**

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 being used as a wake up timer, this write can occur just prior to entering a reduced power mode.

When a starting count value is loaded, the self-wake-up timer automatically turns on, counts from the pre-loaded value down to zero, generates an interrupt and/or a wake up request, and then turns itself off until re-launched by a subsequent software write.

# 18.5.1 WKT clock sources

The self-wake-up timer can be clocked from two alternative clock sources:

- A 750 kHz clock derived from the IRC oscillator. This is the default clock,
- A 10 kHz, low-power clock with a dedicated on-chip oscillator as clock source.
- An external clock on the WKTCLKIN pin.

The IRC-derived clock is much more accurate than the alternative, low-power clock. However, the IRC is not available in most low-power modes. This clock must not be selected when the timer is being used to wake up from a power mode where the IRC is disabled.

The alternative clock source is a (nominally) 10 kHz, low-power clock, sourced from a dedicated oscillator. This oscillator resides in the always-on voltage domain, so it can be programmed to continue operating in Deep power-down mode when power is removed from the rest of the part. This clock is also be available during other low-power modes when the IRC clock is shut-down.

The Low-Power oscillator is not accurate (approximately +/- 40 % over process and temperature). The frequency may still drift while counting is in progress due to reduced chip temperature after a low-power mode is entered.

An external clock on the WKTCLKIN pin can be used to time the self-wake-up timer in all low power modes, including deep power-down.

# **18.6 Register description**

| Name  | Access | Address<br>offset | Description                          | Reset value | Reference |
|-------|--------|-------------------|--------------------------------------|-------------|-----------|
| CTRL  | R/W    | 0x0               | Self-wake-up timer control register. | 0           | Table 258 |
| COUNT | R/W    | 0xC               | Counter register.                    | -           | Table 259 |

# 18.6.1 Control register

The WKT interrupt must be enabled in the NVIC to wake up the part using the self-wake-up counter.

Table 257, Register overview: WKT (base address 0x4000 8000)

#### Table 258. Control register (CTRL, address 0x4000 8000) bit description

| Bit | Symbol | Value                                                                                                   | Description                                                                                                                                                                                                                        | Reset<br>value |
|-----|--------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | CLKSEL |                                                                                                         | Select the self-wake-up timer clock source.                                                                                                                                                                                        | 0              |
|     |        |                                                                                                         | Remark: This bit only has an effect if the SEL_EXTCLK bit is not set.                                                                                                                                                              |                |
|     |        | 0                                                                                                       | Divided IRC clock. This clock runs at 750 kHz and provides time-out periods of up to approximately 95 minutes in 1.33 $\mu$ s increments.                                                                                          |                |
|     |        | deep power-down modes<br>wake up from one of thes1Low power clock. This is<br>periods of up to approxim | <b>Remark:</b> This clock is not available in not available in Deep-sleep, power-down, deep power-down modes. Do not select this option if the timer is to be used to wake up from one of these modes.                             | _              |
|     |        |                                                                                                         | Low power clock. This is the (nominally) 10 kHz clock and provides time-out periods of up to approximately 119 hours in 100 $\mu$ s increments. The accuracy of this clock is limited to +/- 40 % over temperature and processing. |                |
|     |        |                                                                                                         | <b>Remark:</b> This clock is available in all power modes. Prior to use, the low-power oscillator must be enabled. The oscillator must also be set to remain active in Deep power-down if needed.                                  |                |

| Bit         | Symbol     | Value | Description                                                                                                                                                                                                                                                    | Reset<br>value                                |  |
|-------------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--|
| 1           | ALARMFLAG  |       | Wake-up or alarm timer flag.                                                                                                                                                                                                                                   | -                                             |  |
|             |            | 0     | No time-out. The self-wake-up timer has not timed out. Writing a 0 to has no effect.                                                                                                                                                                           | _                                             |  |
|             |            | 1     | Time-out. The self-wake-up timer has timed out. This flag generates an interrupt request which can wake up the part from any reduced power mode including Deep power-down if the clock source is the low power oscillator. Writing a 1 clears this status bit. |                                               |  |
| 2           | CLEARCTR   |       | Clears the self-wake-up timer.                                                                                                                                                                                                                                 | 0                                             |  |
|             |            |       | 0                                                                                                                                                                                                                                                              | No effect. Reading this bit always returns 0. |  |
|             |            | 1     | Clear the counter. Counting is halted until a new count value is loaded.                                                                                                                                                                                       | -                                             |  |
| 3 SEL_EXTCL | SEL_EXTCLK |       | Select external or internal clock source for the self-wake-up timer. The internal clock source is selected by the CLKSEL bit in this register if SET_EXTCLK is set to internal.                                                                                | 0                                             |  |
|             |            | 0     | Internal. The clock source is the internal clock selected by the CLKSEL bit.                                                                                                                                                                                   |                                               |  |
|             |            | 1     | External. The self-wake-up timer uses the external WKTCLKIN pin.                                                                                                                                                                                               | 1                                             |  |
| 31:4        | -          |       | Reserved.                                                                                                                                                                                                                                                      | -                                             |  |

#### Table 258. Control register (CTRL, address 0x4000 8000) bit description

#### 18.6.2 Count register

Do not write to this register while the counting is in progress.

**Remark:** In general, reading the timer state is not recommended. There is no mechanism to ensure that some bits of this register don't change while a read is in progress if the read happens to coincide with an self-wake-up timer clock edge. If you must read this value, it is recommended to read it twice in succession.

#### Table 259. Counter register (COUNT, address 0x4000 800C) bit description

| Bit  | Symbol |                                                                                                            | Reset<br>value |
|------|--------|------------------------------------------------------------------------------------------------------------|----------------|
| 31:0 | VALUE  | A write to this register pre-loads start count value into the timer<br>and starts the count-down sequence. | -              |
|      |        | A read reflects the current value of the timer.                                                            |                |

UM11021

Chapter 19: LPC83x Multi-Rate Timer (MRT)

Rev. 1.1 — 5 October 2016

**User manual** 

# 19.1 How to read this chapter

The MRT is available on all LPC83x parts.

# **19.2 Features**

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

# **19.3 Basic configuration**

Configure the MRT using the following registers:

- In the SYSAHBCLKCTRL register, set bit 10 (<u>Table 33</u>) to enable the clock to the register interface.
- Clear the MRT reset using the PRESETCTRL register (Table 21).
- The global MRT interrupt is connected to interrupt #10 in the NVIC.



# **19.4 Pin description**

The MRT has no configurable pins.

# **19.5 General description**

The Multi-Rate Timer (MRT) provides a repetitive interrupt timer with four channels. Each channel can be programmed with an independent time interval.

Each channel operates independently from the other channels in one of the following modes:

• Repeat interrupt mode. See Section 19.5.1.

UM11021

- One-shot interrupt mode. See <u>Section 19.5.2</u>.
- Bus-stall mode.

The modes for each timer are set in the timer's control register. See Table 263.



#### 19.5.1 Repeat interrupt mode

The repeat interrupt mode generates repeated interrupts after a selected time interval. This mode can be used for software-based PWM or PPM applications.

When the timer n is in idle state, writing a non-zero value IVALUE to the INTVALn register immediately loads the time interval value IVALUE - 1, and the timer begins to count down from this value. When the timer reaches zero, an interrupt is generated, the value in the INTVALn register IVALUE - 1 is reloaded automatically, and the timer starts to count down again.

While the timer is running in repeat interrupt mode, you can perform the following actions:

- Change the interval value on the next timer cycle by writing a new value (>0) to the INTVALn register and setting the LOAD bit to 0. An interrupt is generated when the timer reaches zero. On the next cycle, the timer counts down from the new value.
- Change the interval value on-the-fly immediately by writing a new value (>0) to the INTVALn register and setting the LOAD bit to 1. The timer immediately starts to count down from the new timer interval value. An interrupt is generated when the timer reaches 0.
- Stop the timer at the end of time interval by writing a 0 to the INTVALn register and setting the LOAD bit to 0. An interrupt is generated when the timer reaches zero.
- Stop the timer immediately by writing a 0 to the INTVALn register and setting the LOAD bit to 1. No interrupt is generated when the INTVALn register is written.

© NXP Semiconductors N.V. 2016. All rights reserved.

#### 19.5.2 One-shot interrupt mode

The one-shot interrupt generates one interrupt after a one-time count. With this mode, you can generate a single interrupt at any point. This mode can be used to introduce a specific delay in a software task.

When the timer is in the idle state, writing a non-zero value IVALUE to the INTVALn register immediately loads the time interval value IVALUE - 1, and the timer starts to count down. When the timer reaches 0, an interrupt is generated and the timer stops and enters the idle state.

While the timer is running in the one-shot interrupt mode, you can perform the following actions:

- Update the INTVALn register with a new time interval value (>0) and set the LOAD bit to 1. The timer immediately reloads the new time interval, and starts counting down from the new value. No interrupt is generated when the TIME\_INTVALn register is updated.
- Write a 0 to the INTVALn register and set the LOAD bit to 1. The timer immediately stops counting and moves to the idle state. No interrupt is generated when the INTVALn register is updated.

#### 19.5.3 One-shot bus stall mode

The one-shot bus stall mode stalls the bus interface for IVALUE +3 cycles of the system clock. For the Cortex-M0+, this mode effectively stops all CPU activity until the MRT has finished counting down to zero. At the end of the count-down, no interrupt is generated, instead the bus resumes its transactions. The bus stall mode allows to halt an application for a predefined amount of time and then resume, as opposed to creating a software loop or polling a timer. Since in bus-stall mode, there are no bus transactions while the MRT is counting down, the CPU consumes a minimum amount of power during that time. Typically, this mode can be used when an application must be idle for a short time (in the order of µs or 10 to 50 clock cycles) - for example when compensating for a settling time and thus no CPU activity is required.

For longer wait times, use the one-shot interrupt mode, which allows other enabled interrupts to be serviced.

**Remark:** Because the MRT resides on the APB, the total amount of wait cycles inserted in bus stall mode, 3 cycles have to be added to IVALUE to account for the AHB-to-APB bridge.

# **19.6 Register description**

The reset values shown in Table 260 are POR reset values.

| Name     | Access | Address<br>offset | Description                                                                        | Reset value | Reference        |
|----------|--------|-------------------|------------------------------------------------------------------------------------|-------------|------------------|
| INTVAL0  | R/W    | 0x0               | MRT0 Time interval value register. This value is loaded into the TIMER0 register.  | 0           | <u>Table 261</u> |
| TIMER0   | R      | 0x4               | MRT0 Timer register. This register reads the value of the down counter.            | 0x7FFF FFFF | <u>Table 262</u> |
| CTRL0    | R/W    | 0x8               | MRT0 Control register. This register controls the MRT0 modes.                      | 0           | <u>Table 263</u> |
| STAT0    | R/W    | 0xC               | MRT0 Status register.                                                              | 0           | Table 264        |
| INTVAL1  | R/W    | 0x10              | MRT1 Time interval value register. This value is loaded into the TIMER1 register.  | 0           | <u>Table 261</u> |
| TIMER1   | R/W    | 0x14              | MRT1 Timer register. This register reads the value of the down counter.            | 0x7FFF FFFF | <u>Table 262</u> |
| CTRL1    | R/W    | 0x18              | MRT1 Control register. This register controls the MRT1 modes.                      | 0           | <u>Table 263</u> |
| STAT1    | R/W    | 0x1C              | MRT1 Status register.                                                              | 0           | Table 264        |
| INTVAL2  | R/W    | 0x20              | MRT2 Time interval value register. This value is loaded into the TIMER2 register.  | 0           | <u>Table 261</u> |
| TIMER2   | R/W    | 0x24              | MRT2 Timer register. This register reads the value of the down counter.            | 0x7FFF FFFF | <u>Table 262</u> |
| CTRL2    | R/W    | 0x28              | MRT2 Control register. This register controls the MRT2 modes.                      | 0           | <u>Table 263</u> |
| STAT2    | R/W    | 0x2C              | MRT2 Status register.                                                              | 0           | Table 264        |
| INTVAL3  | R/W    | 0x30              | MRT3 Time interval value register. This value is loaded into the TIMER3 register.  | 0           | <u>Table 261</u> |
| TIMER3   | R/W    | 0x34              | MRT3 Timer register. This register reads the value of the down counter.            | 0x7FFF FFFF | <u>Table 262</u> |
| CTRL3    | R/W    | 0x38              | MRT3 Control register. This register controls the MRT modes.                       | 0           | <u>Table 263</u> |
| STAT3    | R/W    | 0x3C              | MRT3 Status register.                                                              | 0           | Table 264        |
| IDLE_CH  | R      | 0xF4              | Idle channel register. This register returns the number of the first idle channel. | 0           | <u>Table 265</u> |
| IRQ_FLAG | R/W    | 0xF8              | Global interrupt flag register                                                     | 0           | Table 266        |

#### Table 260. Register overview: MRT (base address 0x4000 4000)

# 19.6.1 Time interval register

This register contains the MRT load value and controls how the timer is reloaded. The load value is IVALUE -1.

| Bit  | Symbol | Value | Description                                                                                                                                            | Reset<br>value |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 30:0 | IVALUE |       | Time interval load value. This value is loaded into the TIMERn register and the MRTn starts counting down from IVALUE -1.                              | 0              |
|      |        |       | If the timer is idle, writing a non-zero value to this bit field starts the timer immediately.                                                         |                |
|      |        |       | If the timer is running, writing a zero to this bit field does the following:                                                                          |                |
|      |        |       | <ul> <li>If LOAD = 1, the timer stops immediately.</li> </ul>                                                                                          |                |
|      |        |       | <ul> <li>If LOAD = 0, the timer stops at the end of the time<br/>interval.</li> </ul>                                                                  |                |
| 31   | LOAD   |       | Determines how the timer interval value IVALUE -1 is<br>loaded into the TIMERn register. This bit is write-only.<br>Reading this bit always returns 0. | 0              |
|      |        | 0     | No force load. The load from the INTVALn register to the TIMERn register is processed at the end of the time interval if the repeat mode is selected.  |                |
|      |        | 1     | Force load. The INTVALn interval value IVALUE -1 is immediately loaded into the TIMERn register while TIMERn is running.                               |                |

# Table 261. Time interval register (INTVAL[0:3], address 0x4000 4000 (INTVAL0) to 0x40004030 (INTVAL3)) bit description

### **19.6.2 Timer register**

The timer register holds the current timer value. This register is read-only.

# Table 262. Timer register (TIMER[0:3], address 0x4000 4004 (TIMER0) to 0x4000 4034 (TIMER3)) bit description

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                            | Reset<br>value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 30:0 | VALUE  | Holds the current timer value of the down counter. The initial value<br>of the TIMERn register is loaded as IVALUE - 1 from the INTVALn<br>register either at the end of the time interval or immediately in the<br>following cases:<br>INTVALn register is updated in the idle state. | 0x00FF<br>FFFF |
|      |        | INTVALn register is updated with LOAD = 1.                                                                                                                                                                                                                                             |                |
|      |        | When the timer is in idle state, reading this bit fields returns -1 (0x00FF FFFF).                                                                                                                                                                                                     |                |
| 31   | -      | Reserved.                                                                                                                                                                                                                                                                              | 0              |

# **19.6.3 Control register**

The control register configures the mode for each MRT and enables the interrupt.

| Table 263. | Control register (CTRL[0:3], address 0x4000 4008 (CTRL0) to 0x4000 4038 |
|------------|-------------------------------------------------------------------------|
|            | (CTRL3)) bit description                                                |

| Bit  | Symbol | Value | Description                  | Reset<br>value |
|------|--------|-------|------------------------------|----------------|
| 0    | INTEN  |       | Enable the TIMERn interrupt. | 0              |
|      |        | 0     | Disable.                     |                |
|      |        | 1     | Enable.                      |                |
| 2:1  | MODE   |       | Selects timer mode.          | 0              |
|      |        | 0x0   | Repeat interrupt mode.       |                |
|      |        | 0x1   | One-shot interrupt mode.     |                |
|      |        | 0x2   | One-shot bus stall mode.     |                |
|      |        | 0x3   | Reserved.                    |                |
| 31:3 | -      |       | Reserved.                    | 0              |

#### 19.6.4 Status register

This register indicates the status of each MRT.

# Table 264. Status register (STAT[0:3], address 0x4000 400C (STAT0) to 0x4000 403C (STAT3)) bit description

| Bit  | Symbol  | Value | Description                                                                                                                                                                                                                                | Reset<br>value |
|------|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | INTFLAG |       | Monitors the interrupt flag.                                                                                                                                                                                                               | 0              |
|      |         | 0     | No pending interrupt. Writing a zero is equivalent to no operation.                                                                                                                                                                        |                |
|      |         | 1     | Pending interrupt. The interrupt is pending because<br>TIMERn has reached the end of the time interval. If the<br>INTEN bit in the CONTROLn is also set to 1, the<br>interrupt for timer channel n and the global interrupt are<br>raised. |                |
|      |         |       | Writing a 1 to this bit clears the interrupt request.                                                                                                                                                                                      |                |
| 1    | RUN     |       | Indicates the state of TIMERn. This bit is read-only.                                                                                                                                                                                      | 0              |
|      |         | 0     | Idle state. TIMERn is stopped.                                                                                                                                                                                                             |                |
|      |         | 1     | Running. TIMERn is running.                                                                                                                                                                                                                |                |
| 31:2 | -       |       | Reserved.                                                                                                                                                                                                                                  | 0              |

#### 19.6.5 Idle channel register

The idle channel register returns the lowest idle channel number. The channel is considered idle when both flags is the STATUS register (RUN and INTFLAG) are zero.

In an application with multiple timers running independently, you can calculate the register offset of the next idle timer by reading the idle channel number in this register. The idle channel register allows you set up the next idle timer without checking the idle state of each timer.

| Bit  | Symbol | Description                                                                                                              | Reset<br>value |
|------|--------|--------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0  | -      | Reserved.                                                                                                                | 0              |
| 7:4  | CHAN   | Idle channel. Reading the CHAN bits, returns the lowest idle timer channel. If all timer channels are running, CHAN = 4. | 0              |
| 31:8 | -      | Reserved.                                                                                                                | 0              |

# 19.6.6 Global interrupt flag register

The global interrupt register combines the interrupt flags from the individual timer channels in one register. Setting and clearing each flag behaves in the same way as setting and clearing the INTFLAG bit in each of the STATUSn registers.

| Bit  | Symbol | Value | Description                                                                                                                                                                                                                                      | Reset<br>value |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | GFLAG0 |       | Monitors the interrupt flag of TIMER0.                                                                                                                                                                                                           | 0              |
|      |        | 0     | No pending interrupt. Writing a zero is equivalent to no operation.                                                                                                                                                                              |                |
|      |        | 1     | Pending interrupt. The interrupt is pending because TIMER0 has reached the end of the time interval. If the INTEN bit in the CONTROL0 register is also set to 1, the interrupt for timer channel 0 and the global interrupt are raised.          | _              |
|      |        |       | Writing a 1 to this bit clears the interrupt request.                                                                                                                                                                                            |                |
| 1    | GFLAG1 |       | Monitors the interrupt flag of TIMER1.                                                                                                                                                                                                           | 0              |
|      |        | 0     | No pending interrupt. Writing a zero is equivalent to no operation.                                                                                                                                                                              |                |
|      |        | 1     | Pending interrupt. The interrupt is pending because TIMER1 has reached the end of the time interval. If the INTEN bit in the CONTROL1 register is also set to 1, the interrupt for timer channel 1 and the global interrupt are raised.          | _              |
|      |        |       | Writing a 1 to this bit clears the interrupt request.                                                                                                                                                                                            |                |
| 2    | GFLAG2 |       | Monitors the interrupt flag of TIMER2.                                                                                                                                                                                                           | 0              |
|      |        | 0     | No pending interrupt. Writing a zero is equivalent to no operation.                                                                                                                                                                              |                |
|      |        | 1     | Pending interrupt. The interrupt is pending because TIMER2<br>has reached the end of the time interval. If the INTEN bit in the<br>CONTROL2 register is also set to 1, the interrupt for timer<br>channel 2 and the global interrupt are raised. | _              |
|      |        |       | Writing a 1 to this bit clears the interrupt request.                                                                                                                                                                                            |                |
| 3    | GFLAG3 |       | Monitors the interrupt flag of TIMER3.                                                                                                                                                                                                           | 0              |
|      |        | 0     | No pending interrupt. Writing a zero is equivalent to no operation.                                                                                                                                                                              |                |
|      |        | 1     | Pending interrupt. The interrupt is pending because TIMER3 has reached the end of the time interval. If the INTEN bit in the CONTROL3 register is also set to 1, the interrupt for timer channel 3 and the global interrupt are raised.          |                |
|      |        |       | Writing a 1 to this bit clears the interrupt request.                                                                                                                                                                                            |                |
| 31:4 | -      |       | Reserved.                                                                                                                                                                                                                                        | 0              |

Table 266. Global interrupt flag register (IRQ\_FLAG, address 0x4000 40F8) bit description

Chapter 20: LPC83x System tick timer (SysTick)

Rev. 1.1 — 5 October 2016

**User manual** 

# 20.1 How to read this chapter

The SysTick timer is available on all LPC83x parts.

# 20.2 Features

- Simple 24-bit timer.
- Uses dedicated exception vector.
- Clocked internally by the system clock or the system clock/2.

# 20.3 Basic configuration

The system tick timer is configured using the following registers:

- 1. The system tick timer is enabled through the SysTick control register (<u>Table 268</u>). The system tick timer clock is fixed to half of the system clock frequency.
- Enable the clock source for the SysTick timer in the SYST\_CSR register (<u>Table 268</u>).
- The calibration value of the SysTick timer is contained in the SYSTCKCAL register in the system configuration block SYSCON (see <u>Table 44</u>).

# 20.4 Pin description

The SysTick has no configurable pins.

# 20.5 General description

The block diagram of the SysTick timer is shown in Figure 50.



**User manual** 

The SysTick timer is an integral part of the Cortex-M0+. The SysTick timer is intended to generate a fixed 10 millisecond interrupt for use by an operating system or other system management software.

Since the SysTick timer is a part of the Cortex-M0+, it facilitates porting of software by providing a standard timer that is available on Cortex-M0 based devices. The SysTick timer can be used for:

- An RTOS tick timer which fires at a programmable rate (for example 100 Hz) and invokes a SysTick routine.
- A high-speed alarm timer using the core clock.
- A simple counter. Software can use this to measure time to completion and time used.
- An internal clock source control based on missing/meeting durations. The COUNTFLAG bit-field in the control and status register can be used to determine if an action completed within a set duration, as part of a dynamic clock management control loop.

Refer to Ref. 6 for details.

# 20.6 Register description

The SysTick timer registers are located on the ARM Cortex-M0+ private peripheral bus (see Figure 2), and are part of the ARM Cortex-M0+ core peripherals. For details, see Ref. 6.

| Table 267. | Register | overview: S | SvsTick timer | (base address | 0xE000 E000) |
|------------|----------|-------------|---------------|---------------|--------------|
|            |          |             |               |               |              |

| Name       | Access | Address<br>offset | Description                              | Reset value <sup>[1]</sup> |
|------------|--------|-------------------|------------------------------------------|----------------------------|
| SYST_CSR   | R/W    | 0x010             | System Timer Control and status register | 0x000 0000                 |
| SYST_RVR   | R/W    | 0x014             | System Timer Reload value register       | 0                          |
| SYST_CVR   | R/W    | 0x018             | System Timer Current value register      | 0                          |
| SYST_CALIB | R/W    | 0x01C             | System Timer Calibration value register  | 0x4                        |

[1] Reset Value reflects the data stored in used bits only. It does not include content of reserved bits.

# 20.6.1 System Timer Control and status register

The SYST\_CSR register contains control information for the SysTick timer and provides a status flag. This register is part of the ARM Cortex-M0+ core system timer register block. For a bit description of this register, see Ref. 6.

This register determines the clock source for the system tick timer.

#### Chapter 20: LPC83x System tick timer (SysTick)

# Table 268. SysTick Timer Control and status register (SYST\_CSR, 0xE000 E010) bit description

| Bit Symbol |                                                                                                     | Description                                                                                                                                                                                                        |    |  |  |  |
|------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|
| 0          | ENABLE System Tick counter enable. When 1, the counter is enabled. When 0, the counter is disabled. |                                                                                                                                                                                                                    |    |  |  |  |
| 1          | TICKINT                                                                                             | System Tick interrupt enable. When 1, the System Tick interrupt is enabled. When 0, the System Tick interrupt is disabled. When enabled, the interrupt is generated when the System Tick counter counts down to 0. | 0  |  |  |  |
| 2          | CLKSOURCE                                                                                           | System Tick clock source selection. When 1, the system clock (CPU) clock is selected. When 0, the system clock/2 is selected as the reference clock.                                                               |    |  |  |  |
| 15:3       | -                                                                                                   | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined.                                                                                              | NA |  |  |  |
| 16         | COUNTFLAG                                                                                           | Returns 1 if the SysTick timer counted to 0 since the last read of<br>his register.                                                                                                                                |    |  |  |  |
| 31:17      | -                                                                                                   | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined.                                                                                              | NA |  |  |  |

#### 20.6.2 System Timer Reload value register

The SYST\_RVR register is set to the value that will be loaded into the SysTick timer whenever it counts down to zero. This register is loaded by software as part of timer initialization. The SYST\_CALIB register may be read and used as the value for SYST\_RVR register if the CPU is running at the frequency intended for use with the SYST\_CALIB value.

#### Table 269. System Timer Reload value register (SYST\_RVR, 0xE000 E014) bit description

| Bit   | Symbol | Description                                                                                                           | Reset<br>value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | RELOAD | This is the value that is loaded into the System Tick counter when it counts down to 0.                               | 0              |
| 31:24 | -      | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined. | NA             |

#### 20.6.3 System Timer Current value register

The SYST\_CVR register returns the current count from the System Tick counter when it is read by software.

#### Table 270. System Timer Current value register (SYST\_CVR, 0xE000 E018) bit description

| Bit   | Symbol  |                                                                                                                                                               | Reset<br>value |
|-------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | CURRENT | Reading this register returns the current value of the System Tick counter. Writing any value clears the System Tick counter and the COUNTFLAG bit in STCTRL. | 0              |
| 31:24 | -       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                            | NA             |

### 20.6.4 System Timer Calibration value register

The value of the SYST\_CALIB register is driven by the value of the SYSTCKCAL register in the system configuration block SYSCON (see Table 44).

Table 271. System Timer Calibration value register (SYST\_CALIB, 0xE000 E01C) bit description

| Bit   | Symbol | Value | Description                                                                                                        | Reset<br>value |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 23:0  | TENMS  |       | See <u>Ref. 6</u> .                                                                                                | 0x4            |
| 29:24 | -      |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |
| 30    | SKEW   |       | See <u>Ref. 6</u> .                                                                                                | 0              |
| 31    | NOREF  |       | See <u>Ref. 6</u> .                                                                                                | 0              |

# **20.7 Functional description**

The SysTick timer is a 24-bit timer that counts down to zero and generates an interrupt. The intent is to provide a fixed 10 millisecond time interval between interrupts. The SysTick timer is clocked from the CPU clock (the system clock, see Figure 4) or from the reference clock, which is fixed to half the frequency of the CPU clock. In order to generate recurring interrupts at a specific interval, the SYST\_RVR register must be initialized with the correct value for the desired interval. A default value is provided in the SYST\_CALIB register and may be changed by software.

#### 20.7.1 Example timer calculation

To use the system tick timer, do the following:

- 1. Program the SYST\_RVR register with the reload value RELOAD to obtain the desired time interval.
- 2. Clear the SYST\_CVR register by writing to it. This ensures that the timer will count from the SYST\_RVR value rather than an arbitrary value when the timer is enabled.
- Program the SYST\_SCR register with the value 0x7 which enables the SysTick timer and the SysTick timer interrupt.

The following example illustrates selecting the SysTick timer reload value to obtain a 10 ms time interval with the system clock set to 20 MHz.

#### Example (system clock = 20 MHz)

The system tick clock = system clock = 20 MHz. Bit CLKSOURCE in the SYST\_CSR register set to 1 (system clock).

RELOAD = (system tick clock frequency  $\times$  10 ms) -1 = (20 MHz  $\times$  10 ms) -1 = 200000 -1 = 199999 = 0x00030D3F.

Chapter 21: 12-bit Analog-to-Digital Converter (ADC)

Rev. 1.1 — 5 October 2016

**User manual** 

# 21.1 How to read this chapter

The ADC is available on all parts. The number of available ADC channels depends on the package type.

#### Table 272. Pinout summary

| Package | ADC channels available              |
|---------|-------------------------------------|
| TSSOP20 | ADC_2, ADC_3, ADC_9, ADC_10, ADC_11 |
| HVQFN33 | ADC_0 to ADC_11                     |

# 21.2 Features

- 12-bit successive approximation analog to digital converter.
- Input multiplexing among 12 pins.
- 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 (typically 3 V; not to exceed VDDA voltage level).
- 12-bit conversion rate of up to 1.2 Msamples/s.
- Burst conversion mode for single or multiple inputs.
- DMA support.
- Hardware calibration mode.

# 21.3 Basic configuration

Configure the ADC as follows:

- Use the PDRUNCFG register to power the ADC. See <u>Table 52</u>. Once the ADC is powered by the PDRUNCFG register bit, the low-power mode bit in the ADC CTRL register can be used to turn off the ADC when it is not sampling and turn on the ADC automatically when any of the ADC conversion triggers are raised. See <u>Table 277</u> and <u>Section 21.7.5</u>.
- Use the SYSAHBCLKCTRL register (<u>Table 33</u>) to enable the clock to the ADC register interface and the ADC clock.
- The ADC block creates four interrupts with individual entries in the NVIC. See Table 4.
- The ADC analog inputs are enabled in the switch matrix block.See <u>Table 76</u>.
- The power to the ADC block is controlled by the PDRUNCFG register in the SYSCON block. See <u>Table 52</u>.
- Calibration is required after every power-up or wake-up from Deep power-down mode. See <u>Section 21.3.4 "Hardware self-calibration"</u>.

- For a sampling rate higher than 1 Msamples/s, VDDA must be higher than 2.7 V. See <u>Table 277</u>.
- Configure the ADC for the appropriate analog supply voltage using the TRM register (Table 290). The default setting assumes  $V_{DDA} \ge 2.7 \text{ V}$ .



#### 21.3.1 Perform a single ADC conversion using a software trigger

**Remark:** When A/D conversions are triggered by software only and hardware triggers are not used in the conversion sequence, set the trigger source in the SEQA\_CTRL and SEQB\_CTRL registers to 0x0 (default).

Once the sequence is enabled, the ADC converts a sample whenever the START bit is written to. The TRIGPOL bit can be set in the same write that sets the SEQ\_ENA and the START bits. Be careful not to modify the TRIGGER, TRIGPOL, and SEQ\_ENA bits on subsequent writes to the START bit. See also <u>Section 21.7.2.1 "Avoiding spurious hardware triggers"</u>.

The ADC converts an analog input signal VIN on the ADC\_[11:0]. The VREFP and VREFN pins provide a positive and negative reference voltage input. The result of the conversion is  $(4095 \times VIN)/(VREFP - VREFN)$ . The result of an input voltage below VREFN is 0, and the result of an input voltage above VREFP is 4095 (0xFFF).

To perform a single ADC conversion for ADC0 channel 1 using the analog signal on pin ADC\_1, follow these steps:

- 1. Enable the analog function ADC\_1.
- 2. Configure the system clock to be 25 MHz and select a CLKDIV value of 0 for a sampling rate of 1 Msamples/s using the ADC CTRL register.
- 3. Select ADC channel 1 to perform the conversion by setting the CHANNELS bits to 0x2 in the SEQA\_CTL register.
- 4. Set the TRIGPOL bit to 1 and the SEQA\_ENA bit to 1 in the SEQA\_CTRL register.
- 5. Set the START bit to 1 in the SEQA\_CTRL register.
- 6. Read the RESULT bits in the DAT1 register for the conversion result.

#### 21.3.2 Perform a sequence of conversions triggered by an external pin

The ADC can perform conversions on a sequence of selected channels. Each individual conversion of the sequence (single-step) or the entire sequence can be triggered by hardware. Hardware triggers are either a signal from an external pin or an internal signal. See Section 21.3.3.

To perform a single-step conversion on the first four channels of ADC0 triggered by a rising edge on ADC\_PINTRIG0 pin, follow these steps:

- 1. Enable the analog functions ADC\_0 to ADC\_3 through the switch matrix. See <u>Table 275</u>.
- 2. Configure the system clock to be 25 MHz and select a CLKDIV value of 0 for a sampling rate of 1 Msamples/s using the ADC CTRL register.
- Select ADC channels 0 to 3 to perform the conversion by setting the CHANNELS bits to 0xF in the SEQA\_CTL register.
- Select ADC\_PINTRIG0 by writing 0x1 to the TRIGGER bits in the SEQA\_CTRL register.
- 5. Assign the ADC\_PINTRIG0 function to pin PIO0\_15 through the switch matrix register PINASSIGN10. See <u>Table 275</u>.
- To generate one interrupt at the end of the entire sequence, set the MODE bit to 1 in the SEQA\_CTRL register.
- Select single-step mode by setting the SINGLESTEP bit in the SEQA\_CTRL register to 1.
- 8. Enable the Sequence A by setting the SEQA\_ENA bit.

A conversion on ADC0 channel 0 will be triggered whenever the pin PIO0\_15 goes from LOW to HIGH. The conversion on the next channel (channel 1) is triggered on the next rising edge of PIO0\_15. The ADC\_SEQA\_IRQ interrupt is generated when the sequence has finished after four rising edges on PIO0\_15.

9. Read the RESULT bits in the DAT0 to DAT3 registers for the conversion result.

#### 21.3.3 ADC hardware trigger inputs

An analog-to-digital conversion can be initiated by a hardware trigger. You can select the trigger independently for each of the two conversion sequences in the ADC SEQA\_CTRL or SEQB\_CTRL registers by programming the hardware trigger input # into the TRIGGER bits.

Related registers:

- <u>Table 278 "A/D Conversion Sequence A Control Register (SEQA\_CTRL, address</u> <u>0x4001 C008) bit description</u>"
- <u>Table 279 "A/D Conversion Sequence A Control Register (SEQA\_CTRL, address</u> 0x4001 C008) bit description"

| Input # | Source       | Description                                                                                                                                                                                 |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | -            | This source is always a logic HIGH. Use this trigger<br>source when running the ADC without hardware<br>triggers or when using a software trigger to avoid<br>spurious conversion triggers. |
| 1       | ADC_PINTRG0  | ADC pin trigger 0. Connect to an external pin through the switch matrix.                                                                                                                    |
| 2       | ADC_PINTRIG1 | ADC pin trigger 1. Connect to an external pin through the switch matrix.                                                                                                                    |
| 3       | SCT0_OUT3    | SCT output 3.                                                                                                                                                                               |
| 4       | -            | Reserved.                                                                                                                                                                                   |
| 5       | ARM_TXEV     | ARM core TXEV event.                                                                                                                                                                        |

 Table 273. ADC hardware trigger inputs

# 21.3.4 Hardware self-calibration

The A/D converter includes a built-in, hardware self-calibration mode. In order to achieve the specified ADC accuracy, the A/D converter must be recalibrated, at a minimum, following every chip reset before initiating normal ADC operation.

The calibration voltage level is VREFP - VREFN.

To calibrate the ADC follow these steps:

- 1. Save the current contents of the ADC CTRL register if different from default.
- 2. In a single write to the ADC CTRL register, do the following to start the calibration:
  - Set the calibration mode bit CALMODE.
  - Write a divider value to the CLKDIV bit field that divides the system clock to yield an ADC clock of about 500 kHz.
  - Clear the LPWR bit.
- 3. Poll the CALMODE bit until it is cleared.

Before launching a new A/D conversion, restore the contents of the CTRL register or use the default values.

A calibration cycle requires approximately 290 µs to complete. While calibration is in progress, normal ADC conversions cannot be launched, and the ADC Control Register must not be written to. The calibration procedure does not use the CPU or memory, so other processes can be executed during calibration.

# 21.4 Pin description

The ADC cell can measure the voltage on any of the input signals on the analog input channel. Digital signals are disconnected from the ADC input pins when the ADC function is selected on that pin in the IOCON register.

**Remark:** If the ADC is used, signal levels on analog input pins must not be above the level of  $V_{DD}$  at any time. Otherwise, ADC readings will be invalid. If the ADC is not used in an application, then the pins associated with ADC inputs can be configured as digital I/O pins and are 5 V tolerant.

The VREFP and VREFN pins provide a positive and negative reference voltage input. The result of the conversion is (4095 x input voltage VIN)/(VREFP - VREFN). The result of an input voltage below VREFN is 0, and the result of an input voltage above VREFP is 4095 (0xFFF).

When the ADC is not used, tie VREFP to VDD and VREFP to  $V_{SS}$ .

**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$ 

#### Table 274. ADC supply and reference voltage pins

| Function           | Description                                                                                                                                                                    |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>REFP</sub>  | Positive voltage reference. The VREFP voltage level must be between 2.4 V and V <sub>DDA</sub> . For best performance, select VREFP = V <sub>DDA</sub> and VREFN = $V_{SSA}$ . |
| V <sub>REFN</sub>  | Negative voltage reference.                                                                                                                                                    |
| $V_{DDA} = V_{DD}$ | The analog supply voltage is internally connected to $V_{\text{DD}}$ .                                                                                                         |
| $V_{SSA} = V_{SS}$ | ADC ground is internally connected to VSS.                                                                                                                                     |

#### Table 275. ADC pin description

| Function     | Direction | Туре            | Connect to | Use register | Reference | Description              |
|--------------|-----------|-----------------|------------|--------------|-----------|--------------------------|
| ADC_0        | AI        | external to pin | PIO0_7     | PINENABLE0   | Table 76  | Analog input channel 0.  |
| ADC_1        | AI        | external to pin | PIO0_6     | PINENABLE0   | Table 76  | Analog input channel 1.  |
| ADC_2        | AI        | external to pin | PIO0_14    | PINENABLE0   | Table 76  | Analog input channel 2.  |
| ADC_3        | AI        | external to pin | PIO0_23    | PINENABLE0   | Table 76  | Analog input channel 3.  |
| ADC_4        | AI        | external to pin | PIO0_22    | PINENABLE0   | Table 76  | Analog input channel 4.  |
| ADC_5        | AI        | external to pin | PIO0_21    | PINENABLE0   | Table 76  | Analog input channel 5.  |
| ADC_6        | AI        | external to pin | PIO0_20    | PINENABLE0   | Table 76  | Analog input channel 6.  |
| ADC_7        | AI        | external to pin | PIO0_19    | PINENABLE0   | Table 76  | Analog input channel 7.  |
| ADC_8        | AI        | external to pin | PIO0_18    | PINENABLE0   | Table 76  | Analog input channel 8.  |
| ADC_9        | AI        | external to pin | PIO0_17    | PINENABLE0   | Table 76  | Analog input channel 9.  |
| ADC_10       | AI        | external to pin | PIO0_13    | PINENABLE0   | Table 76  | Analog input channel 10. |
| ADC_11       | AI        | external to pin | PIO0_4     | PINENABLE0   | Table 76  | Analog input channel 11. |
| ADC_PINTRIG0 | 1         | external to pin | any GPIO   | PINASSIGN10  | Table 74  | ADC pin trigger 0.       |
| ADC_PINTRIG1 | I         | external to pin | any GPIO   | PINASSIGN11  | Table 75  | ADC pin trigger 1.       |

# 21.4.1 ADC vs. digital receiver

The ADC function must be selected via the switch matrix registers in order to get accurate voltage readings on the monitored pin. The MODE bits in the IOCON register should also disable both pull-up and pull-down resistors. For a pin hosting an ADC input, it is not possible to have a have a digital function selected and yet get valid ADC readings. An inside circuit disconnects ADC hardware from the associated pin whenever a digital function is selected on that pin.

# 21.5 General description



The ADC controller provides great flexibility in launching and controlling sequences of A/D conversions using the associated 12-bit, successive approximation A/D converter. A/D conversion sequences can be initiated under software control or in response to a selected hardware trigger. The ADC supports eight hardware triggers.

Once the triggers are set up (software and hardware triggers can be mixed), the ADC runs through the pre-defined conversion sequence, converting a sample whenever a trigger signal arrives, until the sequence is disabled.

The ADC controller uses the system clock as a bus clock. The ADC clock is derived from the system clock. A programmable divider is included to scale the system clock to the maximum ADC clock rate of 30 MHz. The ADC clock drives the successive approximation process.

A fully accurate conversion requires 25 of these ADC clocks.

# **21.6 Register description**

The reset value reflects the data stored in used bits only. It does not include reserved bits content.

#### Chapter 21: 12-bit Analog-to-Digital Converter (ADC)

#### Table 276. Register overview : ADC (base address 0x4001 C000 )

| Name      | Access | Address<br>offset | Description                                                                                                                                                    | Reset<br>value | Reference        |
|-----------|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| CTRL      | R/W    | 0x000             | A/D Control Register. Contains the clock divide value, enable bits for each sequence and the A/D power-down bit.                                               | 0x0            | Table 277        |
| -         | -      | 0x004             | Reserved.                                                                                                                                                      | -              | -                |
| SEQA_CTRL | R/W    | 0x008             | A/D Conversion Sequence-A control Register: Controls triggering and channel selection for conversion sequence-A. Also specifies interrupt mode for sequence-A. | 0x0            | <u>Table 278</u> |
| SEQB_CTRL | R/W    | 0x00C             | A/D Conversion Sequence-B Control Register: Controls triggering and channel selection for conversion sequence-B. Also specifies interrupt mode for sequence-B. | 0x0            | <u>Table 279</u> |
| SEQA_GDAT | R/W    | 0x010             | A/D Sequence-A Global Data Register. This register contains<br>the result of the most recent A/D conversion performed<br>under sequence-A                      | NA             | <u>Table 280</u> |
| SEQB_GDAT | R/W    | 0x014             | A/D Sequence-B Global Data Register. This register contains the result of the most recent A/D conversion performed under sequence-B                            | NA             | <u>Table 281</u> |
| DAT0      | RO     | 0x020             | A/D Channel 0 Data Register. This register contains the result of the most recent conversion completed on channel 0.                                           | NA             | Table 282        |
| DAT1      | RO     | 0x024             | A/D Channel 1 Data Register. This register contains the result of the most recent conversion completed on channel 1.                                           | NA             | Table 282        |
| DAT2      | RO     | 0x028             | A/D Channel 2 Data Register. This register contains the result of the most recent conversion completed on channel 2.                                           | NA             | Table 282        |
| DAT3      | RO     | 0x02C             | A/D Channel 3 Data Register. This register contains the result of the most recent conversion completed on channel 3.                                           | NA             | <u>Table 282</u> |
| DAT4      | RO     | 0x030             | A/D Channel 4 Data Register. This register contains the result of the most recent conversion completed on channel 4.                                           | NA             | Table 282        |
| DAT5      | RO     | 0x034             | A/D Channel 5 Data Register. This register contains the result of the most recent conversion completed on channel 5.                                           | NA             | Table 282        |
| DAT6      | RO     | 0x038             | A/D Channel 6 Data Register. This register contains the result of the most recent conversion completed on channel 6.                                           | NA             | <u>Table 282</u> |
| DAT7      | RO     | 0x03C             | A/D Channel 7 Data Register. This register contains the result of the most recent conversion completed on channel 7.                                           | NA             | <u>Table 282</u> |
| DAT8      | RO     | 0x040             | A/D Channel 8 Data Register. This register contains the result of the most recent conversion completed on channel 7.                                           | NA             | Table 282        |
| DAT9      | RO     | 0x044             | A/D Channel 9 Data Register. This register contains the result of the most recent conversion completed on channel 7.                                           | NA             | <u>Table 282</u> |
| DAT10     | RO     | 0x048             | A/D Channel 10 Data Register. This register contains the result of the most recent conversion completed on channel 7.                                          | NA             | <u>Table 282</u> |
| DAT11     | RO     | 0x04C             | A/D Channel 11 Data Register. This register contains the result of the most recent conversion completed on channel 7.                                          | NA             | Table 282        |
| THR0_LOW  | R/W    | 0x050             | A/D Low Compare Threshold Register 0 : Contains the lower threshold level for automatic threshold comparison for any channels linked to threshold pair 0.      | 0x0            | <u>Table 283</u> |
| THR1_LOW  | R/W    | 0x054             | A/D Low Compare Threshold Register 1: Contains the lower threshold level for automatic threshold comparison for any channels linked to threshold pair 1.       | 0x0            | Table 284        |

| Name        | Access | Address<br>offset | Description                                                                                                                                                                                                       | Reset<br>value | Reference        |
|-------------|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|
| THR0_HIGH   | R/W    | 0x058             | A/D High Compare Threshold Register 0: Contains the upper threshold level for automatic threshold comparison for any channels linked to threshold pair 0.                                                         | 0x0            | Table 285        |
| THR1_HIGH   | R/W    | 0x05C             | A/D High Compare Threshold Register 1: Contains the upper threshold level for automatic threshold comparison for any channels linked to threshold pair 1.                                                         | 0x0            | Table 286        |
| CHAN_THRSEL | R/W    | 0x060             | A/D Channel-Threshold Select Register. Specifies which set of threshold compare registers are to be used for each channel                                                                                         | 0x0            | Table 287        |
| INTEN       | R/W    | 0x064             | A/D Interrupt Enable Register. This register contains enable<br>bits that enable the sequence-A, sequence-B, threshold<br>compare and data overrun interrupts to be generated.                                    | 0x0            | Table 288        |
| FLAGS       | R/W    | 0x068             | A/D Flags Register. Contains the four interrupt request flags<br>and the individual component overrun and<br>threshold-compare flags. (The overrun bits replicate<br>information stored in the result registers). | 0x0            | Table 289        |
| TRM         | R/W    | 0x06C             | ADC trim register.                                                                                                                                                                                                | 0x0000<br>0F00 | <u>Table 290</u> |

#### Table 276. Register overview : ADC (base address 0x4001 C000 )

#### 21.6.1 ADC Control Register

This register specifies the clock divider value to be used to generate the ADC clock and general operating mode bits including a low power mode that allows the A/D to be turned off to save power when not in use.

#### Table 277. A/D Control Register (CTRL, addresses 0x4001 C000) bit description

| Bit | Symbol | Value | Description                                                                                                                                                                                                              | Reset<br>value |
|-----|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7:0 | CLKDIV |       | The system clock is divided by this value plus one to produce the sampling clock.<br>The sampling clock should be less than or equal to 30 MHz for 1.2 Msamples/s.                                                       | 0              |
|     |        |       | Typically, software should program the smallest value in this field that yields this maximum clock rate or slightly less, but in certain cases (such as a high-impedance analog source) a slower clock may be desirable. |                |
| 9:8 | -      |       | Reserved.Do not write a one to these bits.                                                                                                                                                                               | 0              |

| Bit   | Symbol   | Value | Description                                                                                                                                                                                                                                                                                                                                                                                      | Reset<br>value |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 10    | LPWRMODE |       | Select low-power ADC mode.                                                                                                                                                                                                                                                                                                                                                                       | 0              |
|       |          |       | The analog circuitry is automatically powered-down when no conversions are taking place. When any (hardware or software) triggering event is detected, the analog circuitry is enabled. After the required start-up time, the requested conversion will be launched. Once the conversion completes, the analog-circuitry will again be powered-down provided no further conversions are pending. |                |
|       |          |       | Using this mode can save an appreciable amount of current when conversions are required relatively infrequently.                                                                                                                                                                                                                                                                                 |                |
|       |          |       | The penalty for using this mode is an approximately 15 ADC clock delay, based on the frequency specified in the CLKDIV field, from the time the trigger event occurs until sampling of the A/D input commences.                                                                                                                                                                                  |                |
|       |          |       | <b>Remark:</b> This mode will NOT power-up the ADC when the ADC analog block is powered down in the system control block.                                                                                                                                                                                                                                                                        |                |
|       |          | 0     | Disabled. The low-power ADC mode is disabled.<br>The analog circuitry remains activated even when no conversions are requested.                                                                                                                                                                                                                                                                  |                |
|       |          | 1     | Enabled. The low-power ADC mode is enabled.                                                                                                                                                                                                                                                                                                                                                      |                |
| 29:11 |          |       | Reserved, do not write ones to reserved bits.                                                                                                                                                                                                                                                                                                                                                    | 0              |
| 30    | CALMODE  |       | Writing a 1 to this bit initiates a self-calibration cycle. This bit will be automatically cleared by hardware after the calibration cycle is complete. To calibrate the ADC, set the ADC clock to 500 kHz.                                                                                                                                                                                      | 0              |
|       |          |       | <b>Remark:</b> Other bits of this register may be written to concurrently with setting this bit, however once this bit has been set no further writes to this register are permitted until the full calibration cycle has ended.                                                                                                                                                                 |                |
| 31    | -        |       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                        | 0              |

#### Table 277. A/D Control Register (CTRL, addresses 0x4001 C000) bit description

# 21.6.2 A/D Conversion Sequence A Control Register

There are two, independent conversion sequences that can be configured, each consisting of a set of conversions on one or more channels. This control register specifies the channel selection and trigger conditions for the A sequence and contains bits to allow software to initiate that conversion sequence.

To avoid conversions on spurious triggers, only change the trigger configuration when the conversion sequence is disabled. A conversion can be triggered by software or hardware in the conversion sequence, but if conversions are triggered by software only, spurious hardware triggers must be prevented. See <u>Section 21.3.1 "Perform a single ADC</u> conversion using a software trigger".

**Remark:** Set the BURST and SEQU\_ENA bits at the same time.

# Chapter 21: 12-bit Analog-to-Digital Converter (ADC)

#### Table 278. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

| Bit   | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                        | Reset<br>value |
|-------|------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 11:0  | CHANNELS   |       | Selects which one or more of the twelve channels will be sampled and converted when this sequence is launched. A 1 in any bit of this field will cause the corresponding channel to be included in the conversion sequence, where bit 0 corresponds to channel 0, bit 1 to channel 1 and so forth.                                                                 | 0x00           |
|       |            |       | When this conversion sequence is triggered, either by a hardware trigger or via software command, A/D conversions will be performed on each enabled channel, in sequence, beginning with the lowest-ordered channel.                                                                                                                                               |                |
|       |            |       | <b>Remark:</b> This field can ONLY be changed while the SEQA_ENA bit (bit 31) is LOW. It is allowed to change this field and set bit 31 in the same write.                                                                                                                                                                                                         |                |
| 14:12 | TRIGGER    |       | Selects which of the available hardware trigger sources will cause this conversion sequence to be initiated. Program the trigger input number in this field.                                                                                                                                                                                                       | 0x0            |
|       |            |       | Remark: In order to avoid generating a spurious trigger, it is recommended                                                                                                                                                                                                                                                                                         |                |
|       |            |       | writing to this field only when the SEQA_ENA bit (bit 31) is low. It is safe to                                                                                                                                                                                                                                                                                    |                |
|       |            |       | change this field and set bit 31 in the same write.                                                                                                                                                                                                                                                                                                                |                |
| 17:15 | -          |       | Reserved.                                                                                                                                                                                                                                                                                                                                                          | -              |
| 18    | TRIGPOL    |       | Select the polarity of the selected input trigger for this conversion sequence.                                                                                                                                                                                                                                                                                    | 0              |
|       |            |       | Remark: In order to avoid generating a spurious trigger, it is recommended                                                                                                                                                                                                                                                                                         |                |
|       |            |       | writing to this field only when the SEQA_ENA bit (bit 31) is low. It is safe to                                                                                                                                                                                                                                                                                    |                |
|       |            |       | change this field and set bit 31 in the same write.                                                                                                                                                                                                                                                                                                                |                |
|       |            | 0     | Negative edge. A negative edge launches the conversion sequence on the selected trigger input.                                                                                                                                                                                                                                                                     |                |
|       |            | 1     | Positive edge. A positive edge launches the conversion sequence on the selected trigger input.                                                                                                                                                                                                                                                                     |                |
| 19    | SYNCBYPASS |       | Setting this bit allows the hardware trigger input to bypass synchronization<br>flip-flops stages and therefore shorten the time between the trigger input<br>signal and the start of a conversion. There are slightly different criteria for<br>whether or not this bit can be set depending on the clock operating mode:                                         | 0              |
|       |            |       | Synchronous mode: Synchronization may be bypassed (this bit may be set) if the selected trigger source is already synchronous with the main system clock (eg. coming from an on-chip, system-clock-based timer). Whether this bit is set or not, a trigger pulse must be maintained for at least one system clock period.                                          |                |
|       |            |       | Asynchronous mode: Synchronization may be bypassed (this bit may be set) if it is certain that the duration of a trigger input pulse will be at least one cycle of the ADC clock (regardless of whether the trigger comes from and on-chip or off-chip source). If this bit is NOT set, the trigger pulse must at least be maintained for one system clock period. |                |
|       |            | 0     | Enable synchronization. The hardware trigger bypass is not enabled.                                                                                                                                                                                                                                                                                                |                |
|       |            | 1     | Bypass synchronization. The hardware trigger bypass is enabled.                                                                                                                                                                                                                                                                                                    |                |
| 25:20 | -          |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                 | N/A            |
| 26    | START      |       | Writing a 1 to this field will launch one pass through this conversion sequence. The behavior will be identical to a sequence triggered by a hardware trigger. Do not write 1 to this bit if the BURST bit is set.                                                                                                                                                 | 0              |
|       |            |       | <b>Remark:</b> This bit is only set to a 1 momentarily when written to launch a conversion sequence. It will consequently always read-back as a zero.                                                                                                                                                                                                              |                |

#### Chapter 21: 12-bit Analog-to-Digital Converter (ADC)

#### Table 278. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

| Bit | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset<br>value |
|-----|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 27  | BURST      |       | Writing a 1 to this bit will cause this conversion sequence to be continuously cycled through. Other sequence A triggers will be ignored while this bit is set. Repeated conversions can be halted by clearing this bit. The sequence                                                                                                                                                                                                                                      | 0              |
|     |            |       | currently in progress will be completed before conversions are terminated.                                                                                                                                                                                                                                                                                                                                                                                                 | -              |
| 28  | SINGLESTEP |       | When this bit is set, a hardware trigger or a write to the START bit will launch<br>a single conversion on the next channel in the sequence instead of the<br>default response of launching an entire sequence of conversions. Once all of<br>the channels comprising a sequence have been converted, a subsequent<br>trigger will repeat the sequence beginning with the first enabled channel.                                                                           | 0              |
|     |            |       | Interrupt generation will still occur either after each individual conversion or at the end of the entire sequence, depending on the state of the MODE bit.                                                                                                                                                                                                                                                                                                                |                |
| 29  | LOWPRIO    |       | Set priority for sequence A.                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0              |
|     |            | 0     | Low priority. Any B trigger which occurs while an A conversion sequence is active will be ignored and lost.                                                                                                                                                                                                                                                                                                                                                                |                |
|     |            | 1     | High priority.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |
|     |            |       | Setting this bit to a 1 will permit any enabled B sequence trigger (including a B sequence software start) to immediately interrupt this sequence and launch a B sequence in it's place. The conversion currently in progress will be terminated.                                                                                                                                                                                                                          |                |
|     |            |       | The A sequence that was interrupted will automatically resume after the B sequence completes. The channel whose conversion was terminated will be re-sampled and the conversion sequence will resume from that point.                                                                                                                                                                                                                                                      |                |
| 30  | MODE       |       | Indicates whether the primary method for retrieving conversion results for<br>this sequence will be accomplished via reading the global data register<br>(SEQA_GDAT) at the end of each conversion, or the individual channel<br>result registers at the end of the entire sequence.<br>Impacts when conversion-complete interrupt/DMA triggers for sequence-A<br>will be generated and which overrun conditions contribute to an overrun<br>interrupt as described below: | 0              |
|     |            | 0     | End of conversion. The sequence A interrupt/DMA flag will be set at the end<br>of each individual A/D conversion performed under sequence A. This flag will<br>mirror the DATAVALID bit in the SEQA_GDAT register.<br>The OVERRUN bit in the SEQA_GDAT register will contribute to generation<br>of an overrun interrupt if enabled.                                                                                                                                       | _              |
|     |            | 1     | End of sequence. The sequence A interrupt/DMA flag will be set when the<br>entire set of sequence-A conversions completes. This flag will need to be<br>explicitly cleared by software or by the DMA-clear signal in this mode.<br>The OVERRUN bit in the SEQA_GDAT register will NOT contribute to<br>generation of an overrun interrupt/DMA trigger since it is assumed this<br>register may not be utilized in this mode.                                               |                |

| Bit | Symbol   | Value                                                                                                                                                                                                                                                                                                                             | Description                                                                                                                                                                                                                                                                                                                    | Reset<br>value |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 31  | SEQA_ENA | SEQA_ENA Sequence Enable. In order to avoid spuriously triggering the sequence, ca<br>should be taken to only set the SEQA_ENA bit when the selected trigger<br>input is in its INACTIVE state (as defined by the TRIGPOL bit). If this<br>condition is not met, the sequence will be triggered immediately upon bein<br>enabled. | 0                                                                                                                                                                                                                                                                                                                              |                |
|     | 0        | 0                                                                                                                                                                                                                                                                                                                                 | Disabled. Sequence A is disabled. Sequence A triggers are ignored. If this bit is cleared while sequence A is in progress, the sequence will be halted at the end of the current conversion. After the sequence is re-enabled, a new trigger will be required to restart the sequence beginning with the next enabled channel. |                |
|     |          | 1                                                                                                                                                                                                                                                                                                                                 | Enabled. Sequence A is enabled.                                                                                                                                                                                                                                                                                                | 1              |

#### Table 278. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

## 21.6.3 A/D Conversion Sequence B Control Register

There are two, independent conversion sequences that can be configured, each consisting of a set of conversions on one or more channels. This control register specifies the channel selection and trigger conditions for the B sequence, as well bits to allow software to initiate that conversion sequence.

To avoid conversions on spurious triggers, only change the trigger configuration when the conversion sequence is disabled. A conversion can be triggered by software or hardware in the conversion sequence, but if conversions are triggered by software only, spurious hardware triggers must be prevented. See <u>Section 21.3.1 "Perform a single ADC</u> conversion using a software trigger".

**Remark:** Set the BURST and SEQU\_ENA bits at the same time.

UM11021

#### Table 279. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

| Bit   | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                                       | Reset<br>value |
|-------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 11:0  | CHANNELS   |       | Selects which one or more of the twelve channels will be sampled<br>and converted when this sequence is launched. A 1 in any bit of this<br>field will cause the corresponding channel to be included in the<br>conversion sequence, where bit 0 corresponds to channel 0, bit 1 to<br>channel 1 and so forth.                                                                    | 0x00           |
|       |            |       | When this conversion sequence is triggered, either by a hardware trigger or via software command, A/D conversions will be performed on each enabled channel, in sequence, beginning with the lowest-ordered channel.                                                                                                                                                              |                |
|       |            |       | <b>Remark:</b> This field can ONLY be changed while the SEQB_ENA bit (bit 31) is LOW. It is permissible to change this field and set bit 31 in the same write.                                                                                                                                                                                                                    |                |
| 14:12 | TRIGGER    |       | Selects which of the available hardware trigger sources will cause<br>this conversion sequence to be initiated. Program the trigger input<br>number in this field.                                                                                                                                                                                                                | 0x0            |
|       |            |       | <b>Remark:</b> In order to avoid generating a spurious trigger, it is recommended writing to this field only when the SEQA_ENA bit (bit 31) is low. It is safe to change this field and set bit 31 in the same write.                                                                                                                                                             |                |
| 17:15 | -          |       | Reserved.                                                                                                                                                                                                                                                                                                                                                                         | -              |
| 18    | TRIGPOL    |       | Select the polarity of the selected input trigger for this conversion sequence.                                                                                                                                                                                                                                                                                                   | 0              |
|       |            |       | <b>Remark:</b> In order to avoid generating a spurious trigger, it is recommended writing to this field only when the SEQA_ENA bit (bit 31) is low. It is safe to change this field and set bit 31 in the same write.                                                                                                                                                             |                |
|       |            | 0     | Negative edge. A negative edge launches the conversion sequence<br>on the selected trigger input.                                                                                                                                                                                                                                                                                 | -              |
|       |            | 1     | Positive edge. A positive edge launches the conversion sequence on the selected trigger input.                                                                                                                                                                                                                                                                                    |                |
| 19    | SYNCBYPASS |       | Setting this bit allows the hardware trigger input to bypass<br>synchronization flip-flops stages and therefore shorten the time<br>between the trigger input signal and the start of a conversion. There<br>are slightly different criteria for whether or not this bit can be set<br>depending on the clock operating mode:                                                     | 0              |
|       |            |       | Synchronous mode: Synchronization may be bypassed (this bit may<br>be set) if the selected trigger source is already synchronous with the<br>main system clock (eg. coming from an on-chip, system-clock-based<br>timer). Whether this bit is set or not, a trigger pulse must be<br>maintained for at least one system clock period.                                             |                |
|       |            |       | Asynchronous mode: Synchronization may be bypassed (this bit<br>may be set) if it is certain that the duration of a trigger input pulse will<br>be at least one cycle of the ADC clock (regardless of whether the<br>trigger comes from and on-chip or off-chip source). If this bit is NOT<br>set, the trigger pulse must at least be maintained for one system<br>clock period. |                |
|       |            | 0     | Enable synchronization. The hardware trigger bypass is not enabled.                                                                                                                                                                                                                                                                                                               | 1              |
|       |            | 1     | Bypass synchronization. The hardware trigger bypass is enabled.                                                                                                                                                                                                                                                                                                                   | -              |

| Bit   | Symbol     | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset<br>value |
|-------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 25:20 | -          |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                        | N/A            |
| 26    | START      |       | Writing a 1 to this field will launch one pass through this conversion sequence. The behavior will be identical to a sequence triggered by a hardware trigger. Do not write a 1 to this bit if the BURST bit is set.<br><b>Remark:</b> This bit is only set to a 1 momentarily when written to launch a conversion sequence. It will consequently always                                                                                                                  | 0              |
| 27    | BURST      |       | read-back as a zero.<br>Writing a 1 to this bit will cause this conversion sequence to be<br>continuously cycled through. Other B triggers will be ignored while<br>this bit is set.                                                                                                                                                                                                                                                                                      | 0              |
|       |            |       | Repeated conversions can be halted by clearing this bit. The sequence currently in progress will be completed before conversions are terminated.                                                                                                                                                                                                                                                                                                                          |                |
| 28    | SINGLESTEP |       | When this bit is set, a hardware trigger or a write to the START bit<br>will launch a single conversion on the next channel in the sequence<br>instead of the default response of launching an entire sequence of<br>conversions. Once all of the channels comprising a sequence have<br>been converted, a subsequent trigger will repeat the sequence<br>beginning with the first enabled channel.                                                                       | 0              |
|       |            |       | Interrupt generation will still occur either after each individual conversion or at the end of the entire sequence, depending on the state of the MODE bit.                                                                                                                                                                                                                                                                                                               |                |
| 29    | -          |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                        | N/A            |
| 30    | MODE       |       | Indicates whether the primary method for retrieving conversion<br>results for this sequence will be accomplished via reading the global<br>data register (SEQB_GDAT) at the end of each conversion, or the<br>individual channel result registers at the end of the entire sequence.<br>Impacts when conversion-complete interrupt/DMA trigger for<br>sequence-B will be generated and which overrun conditions<br>contribute to an overrun interrupt as described below: | 0              |
|       |            | 0     | End of conversion. The sequence B interrupt/DMA flag will be set at<br>the end of each individual A/D conversion performed under<br>sequence B. This flag will mirror the DATAVALID bit in the<br>SEQB_GDAT register.                                                                                                                                                                                                                                                     | _              |
|       |            |       | The OVERRUN bit in the SEQB_GDAT register will contribute to generation of an overrun interrupt if enabled.                                                                                                                                                                                                                                                                                                                                                               |                |
|       |            | 1     | End of sequence. The sequence B interrupt/DMA flag will be set<br>when the entire set of sequence B conversions completes. This flag<br>will need to be explicitly cleared by software or by the DMA-clear<br>signal in this mode.                                                                                                                                                                                                                                        |                |
|       |            |       | The OVERRUN bit in the SEQB_GDAT register will NOT contribute<br>to generation of an overrun interrupt since it is assumed this register<br>will not be utilized in this mode.                                                                                                                                                                                                                                                                                            |                |

#### Table 279. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

| Bit | Symbol                   | Value                                                                                                                            | Description                                                                                                                                                                                                                                                                                                     | Reset<br>value |
|-----|--------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 31  | SEQB_ENA                 |                                                                                                                                  | Sequence Enable. In order to avoid spuriously triggering the sequence, care should be taken to only set the SEQA_ENA bit when the selected trigger input is in its INACTIVE state (as defined by the TRIGPOL bit). If this condition is not met, the sequence will be triggered immediately upon being enabled. | 0              |
|     | If thi<br>will I<br>sequ | If this bit is cleared while sequence B is in progress, the seque will be halted at the end of the current conversion. After the | sequence is re-enabled, a new trigger will be required to restart the                                                                                                                                                                                                                                           |                |
|     |                          | Enabled. Sequence B is enabled.                                                                                                  | 1                                                                                                                                                                                                                                                                                                               |                |

#### Table 279. A/D Conversion Sequence A Control Register (SEQA\_CTRL, address 0x4001 C008) bit description

## 21.6.4 A/D Global Data Register A and B

The A/D Global Data Registers contain the result of the most recent A/D conversion completed under each conversion sequence.

Results of A/D conversions can be read in one of two ways. One is to use these A/D Global Data Registers to read data from the ADC at the end of each A/D conversion. Another is to read the individual A/D Channel Data Registers, typically after the entire sequence has completed. It is recommended to use one method consistently for a given conversion sequence.

The global registers are useful in conjunction with DMA operation - particularly when the channels selected for conversion are not sequential (hence the addresses of the individual result registers will not be sequential, making it difficult for the DMA engine to address them). For interrupt-driven code it will more likely be advantageous to wait for an entire sequence to complete and then retrieve the results from the individual channel registers.

**Remark:** The method to be employed for each sequence should be reflected in the MODE bit in the corresponding ADSEQn\_CTRL register since this will impact interrupt and overrun flag generation.

UM11021

#### Table 280. A/D Sequence A Global Data Register (SEQA\_GDAT, address 0x4001 C010) bit description

| Bit   | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset<br>value |
|-------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | NA             |
| 15:4  | RESULT     | This field contains the 12-bit A/D conversion result from the most recent conversion performed under conversion sequence associated with this register.<br>The result is the a binary fraction representing the voltage on the currently-selected input channel as it falls within the range of $V_{REFP}$ to $V_{REFN}$ . Zero in the field indicates that the voltage on the input pin was less than, equal to, or close to that on $V_{REFN}$ , while 0xFFF indicates that the voltage on the input was close to, equal to, or greater than that on $V_{REFP}$ .<br>DATAVALID = 1 indicates that this result has not yet been read. | NA             |
| 17:16 | THCMPRANGE | Indicates whether the result of the last conversion performed was above, below or within the range established by the designated threshold comparison registers (THRn_LOW and THRn_HIGH).                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |
| 19:18 | THCMPCROSS | Indicates whether the result of the last conversion performed represented a crossing of the threshold level established by the designated LOW threshold comparison register (THRn_LOW) and, if so, in what direction the crossing occurred.                                                                                                                                                                                                                                                                                                                                                                                            |                |
| 25:20 | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | NA             |
| 29:26 | CHN        | These bits contain the channel from which the RESULT bits were converted (e.g. 0000 identifies channel 0, 0001 channel 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | NA             |
| 30    | OVERRUN    | This bit is set if a new conversion result is loaded into the RESULT field before a previous result has been read - i.e. while the DATAVALID bit is set. This bit is cleared, along with the DATAVALID bit, whenever this register is read.<br>This bit will contribute to an overrun interrupt request if the MODE bit (in SEQA_CTRL) for the corresponding sequence is set to '0' (and if the overrun interrupt is enabled).                                                                                                                                                                                                         | 0              |
| 31    | DATAVALID  | This bit is set to '1' at the end of each conversion when a new result is loaded into the RESULT field. It is cleared whenever this register is read.<br>This bit will cause a conversion-complete interrupt for the corresponding sequence if the MODE bit (in SEQA_CTRL) for that sequence is set to 0 (and if the interrupt is enabled).                                                                                                                                                                                                                                                                                            | 0              |

#### Table 281. A/D Sequence B Global Data Register (SEQB\_GDAT, address 0x4001 C014) bit description

| Bit   | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                         | Reset<br>value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                  | NA             |
| 15:4  | RESULT     | This field contains the 12-bit A/D conversion result from the most recent conversion performed under conversion sequence associated with this register.                                                                                                                                                                                                                                             | NA             |
|       |            | This will be a binary fraction representing the voltage on the currently-selected input channel as it falls within the range of $V_{REFP}$ to $V_{REFN}$ . Zero in the field indicates that the voltage on the input pin was less than, equal to, or close to that on $V_{REFN}$ , while 0xFFF indicates that the voltage on the input was close to, equal to, or greater than that on $V_{REFP}$ . |                |
|       |            | DATAVALID = 1 indicates that this result has not yet been read.                                                                                                                                                                                                                                                                                                                                     |                |
| 17:16 | THCMPRANGE | Indicates whether the result of the last conversion performed was above, below or within the range established by the designated threshold comparison registers (THRn_LOW and THRn_HIGH).                                                                                                                                                                                                           |                |
|       |            | Threshold Range Comparison result.                                                                                                                                                                                                                                                                                                                                                                  |                |
|       |            | 0x0 = In Range: The last completed conversion was greater than or equal to the value programmed into the designated LOW threshold register (THRn_LOW) but less than or equal to the value programmed into the designated HIGH threshold register (THRn_HIGH).                                                                                                                                       |                |
|       |            | 0x1 = Below Range: The last completed conversion on was less than the value programmed into the designated LOW threshold register (THRn_LOW).                                                                                                                                                                                                                                                       |                |
|       |            | 0x2 = Above Range: The last completed conversion was greater than the value programmed into the designated HIGH threshold register (THRn_HIGH).                                                                                                                                                                                                                                                     |                |
|       |            | 0x3 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |                |
| 19:18 | THCMPCROSS | Indicates whether the result of the last conversion performed represented a crossing of the threshold level established by the designated LOW threshold comparison register (THRn_LOW) and, if so, in what direction the crossing occurred.                                                                                                                                                         |                |
|       |            | 0x0 = No threshold Crossing detected:<br>The most recent completed conversion on this channel had the same relationship<br>(above or below) to the threshold value established by the designated LOW<br>threshold register (THRn_LOW) as did the previous conversion on this channel.                                                                                                               |                |
|       |            | 0x1 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |                |
|       |            | 0x2 = Downward Threshold Crossing Detected. Indicates that a threshold crossing<br>in the downward direction has occurred - i.e. the previous sample on this channel<br>was above the threshold value established by the designated LOW threshold<br>register (THRn_LOW) and the current sample is below that threshold.                                                                            |                |
|       |            | 0x3 = Upward Threshold Crossing Detected. Indicates that a threshold crossing in the upward direction has occurred - i.e. the previous sample on this channel was below the threshold value established by the designated LOW threshold register (THRn_LOW) and the current sample is above that threshold.                                                                                         |                |
| 25:20 | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                  | NA             |

User manual

| Bit   | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                  | Reset<br>value |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 29:26 | CHN       | These bits contain the channel from which the RESULT bits were converted (e.g. 0b0000 identifies channel 0, 0b0001 channel 1).                                                                                                                                                                                                                                                                                               | NA             |
| 30    | OVERRUN   | This bit is set if a new conversion result is loaded into the RESULT field before a previous result has been read - i.e. while the DATAVALID bit is set. This bit is cleared, along with the DATAVALID bit, whenever this register is read.<br>This bit will contribute to an overrun interrupt request if the MODE bit (in SEQB_CTRL) for the corresponding sequence is set to 0 (and if the overrun interrupt is enabled). | 0              |
| 31    | DATAVALID | This bit is set to 1 at the end of each conversion when a new result is loaded into the RESULT field. It is cleared whenever this register is read.<br>This bit will cause a conversion-complete interrupt for the corresponding sequence if the MODE bit (in SEQB_CTRL) for that sequence is set to 0 (and if the interrupt is enabled).                                                                                    | 0              |

#### Table 281. A/D Sequence B Global Data Register (SEQB\_GDAT, address 0x4001 C014) bit description

### 21.6.5 A/D Channel Data Registers 0 to 11

The A/D Channel Data Registers hold the result of the last conversion completed for each A/D channel. They also include status bits to indicate when a conversion has been completed, when a data overrun has occurred, and where the most recent conversion fits relative to the range dictated by the high and low threshold registers.

Results of A/D conversion can be read in one of two ways. One is to use the A/D Global Data Registers for each of the sequences to read data from the ADC at the end of each A/D conversion. Another is to use these individual A/D Channel Data Registers, typically after the entire sequence has completed. It is recommended to use one method consistently for a given conversion sequence.

**Remark:** The method to be employed for each sequence should be reflected in the MODE bit in the corresponding SEQ\_CTRL register since this will impact interrupt and overrun flag generation.

The information presented in the DAT registers always pertains to the most recent conversion completed on that channel regardless of what sequence requested the conversion or which trigger caused it.

The OVERRUN fields for each channel are also replicated in the FLAGS register.

#### Table 282. A/D Data Registers (DAT[0:11], address 0x4001 C020 (DAT0) to 0x4001 C04C (DAT11)) bit description

| Bit   | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset<br>value |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                                      | NA             |
| 15:4  | RESULT     | This field contains the 12-bit A/D conversion result from the last conversion performed on this channel. This will be a binary fraction representing the voltage on the AD0[n] pin, as it falls within the range of $V_{REFP}$ to $V_{REFN}$ . Zero in the field indicates that the voltage on the input pin was less than, equal to, or close to that on $V_{REFN}$ , while 0xFFF indicates that the voltage on the input was close to, equal to, or greater than that on $V_{REFP}$ . | NA             |
| 17:16 | THCMPRANGE | Threshold Range Comparison result.                                                                                                                                                                                                                                                                                                                                                                                                                                                      | NA             |
|       |            | 0x0 = In Range: The last completed conversion was greater than or equal to the value programmed into the designated LOW threshold register (THRn_LOW) but less than or equal to the value programmed into the designated HIGH threshold register (THRn_HIGH).                                                                                                                                                                                                                           |                |
|       |            | 0x1 = Below Range: The last completed conversion on was less than the value programmed into the designated LOW threshold register (THRn_LOW).                                                                                                                                                                                                                                                                                                                                           |                |
|       |            | 0x2 = Above Range: The last completed conversion was greater than the value programmed into the designated HIGH threshold register (THRn_HIGH).                                                                                                                                                                                                                                                                                                                                         |                |
|       |            | 0x3 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |
| 19:18 | THCMPCROSS | Threshold Crossing Comparison result.                                                                                                                                                                                                                                                                                                                                                                                                                                                   | NA             |
|       |            | 0x0 = No threshold Crossing detected:<br>The most recent completed conversion on this channel had the same relationship<br>(above or below) to the threshold value established by the designated LOW threshold<br>register (THRn_LOW) as did the previous conversion on this channel.<br>0x1 = Reserved.                                                                                                                                                                                |                |
|       |            | 0x2 = Downward Threshold Crossing Detected. Indicates that a threshold crossing in the downward direction has occurred - i.e. the previous sample on this channel was above the threshold value established by the designated LOW threshold register (THRn_LOW) and the current sample is below that threshold.                                                                                                                                                                         |                |
|       |            | $0x3 = Upward$ Threshold Crossing Detected. Indicates that a threshold crossing in the upward direction has occurred - i.e. the previous sample on this channel was below the threshold value established by the designated LOW threshold register (THRn_LOW) and the current sample is above that threshold.                                                                                                                                                                           |                |
| 25:20 | -          | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                                                                                                                                                                      | NA             |

| Bit   | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 29:26 | CHANNEL   | This field is hard-coded to contain the channel number that this particular register relates to (i.e. this field will contain 0b0000 for the DAT0 register, 0b0001 for the DAT1 register, etc)                                                                                                                                                              | NA             |
| 30    | OVERRUN   | This bit will be set to a 1 if a new conversion on this channel completes and overwrites the previous contents of the RESULT field before it has been read - i.e. while the DONE bit is set.                                                                                                                                                                | NA             |
|       |           | This bit is cleared, along with the DONE bit, whenever this register is read or when the data related to this channel is read from either of the global SEQn_GDAT registers.                                                                                                                                                                                |                |
|       |           | This bit (in any of the 12 registers) will cause an overrun interrupt request to be asserted if the overrun interrupt is enabled.                                                                                                                                                                                                                           |                |
|       |           | <b>Remark:</b> While it is allowed to include the same channels in both conversion sequences, doing so may cause erratic behavior of the DONE and OVERRUN bits in the data registers associated with any of the channels that are shared between the two sequences. Any erratic OVERRUN behavior will also affect overrun interrupt generation, if enabled. |                |
| 31    | DATAVALID | This bit is set to 1 when an A/D conversion on this channel completes.                                                                                                                                                                                                                                                                                      | NA             |
|       |           | This bit is cleared whenever this register is read or when the data related to this channel is read from either of the global SEQn_GDAT registers.                                                                                                                                                                                                          |                |
|       |           | <b>Remark:</b> While it is allowed to include the same channels in both conversion sequences, doing so may cause erratic behavior of the DONE and OVERRUN bits in the data registers associated with any of the channels that are shared between the two sequences. Any erratic OVERRUN behavior will also affect overrun interrupt generation, if enabled. |                |

#### Table 282. A/D Data Registers (DAT[0:11], address 0x4001 C020 (DAT0) to 0x4001 C04C (DAT11)) bit description

### 21.6.6 A/D Compare Low Threshold Registers 0 and 1

These registers set the LOW threshold levels against which A/D conversions on all channels will be compared.

Each channel will either be compared to the THR0\_LOW/HIGH registers or to the THR1\_LOW/HIGH registers depending on what is specified for that channel in the CHAN\_THRSEL register.

A conversion result LESS THAN this value on any channel will cause the THCMP\_RANGE status bits for that channel to be set to 0b01. This result will also generate an interrupt request if enabled to do so via the ADCMPINTEN bits associated with each channel in the INTEN register.

If, for two successive conversions on a given channel, one result is below this threshold and the other is equal-to or above this threshold, than a threshold crossing has occurred. In this case the MSB of the THCMP\_CROSS status bits will indicate that a threshold crossing has occurred and the LSB will indicate the direction of the crossing. A threshold crossing event will also generate an interrupt request if enabled to do so via the ADCMPINTEN bits associated with each channel in the INTEN register.

**User manual** 

## Table 283. A/D Compare Low Threshold register 0 (THR0\_LOW, address 0x4001 C050) bit description

| Bit   | Symbol | Description                                                                                                        | Reset<br>value |
|-------|--------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   |        | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |
| 15:4  | THRLOW | Low threshold value against which A/D results will be compared                                                     | 0x000          |
| 31:16 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

## Table 284. A/D Compare Low Threshold register 1 (THR1\_LOW, address 0x4001 C054) bit description

| Bit   | Symbol | Description                                                                                                        | Reset<br>value |
|-------|--------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   |        | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |
| 15:4  | THRLOW | Low threshold value against which A/D results will be compared                                                     | 0x000          |
| 31:16 | -      | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

## 21.6.7 A/D Compare High Threshold Registers 0 and 1

These registers set the HIGH threshold level against which A/D conversions on all channels will be compared.

Each channel will either be compared to the THR0\_LOW/HIGH registers or to the THR1\_LOW/HIGH registers depending on what is specified for that channel in the CHAN\_THRSEL register.

A conversion result greater than this value on any channel will cause the THCMP status bits for that channel to be set to 0b10. This result will also generate an interrupt request if enabled to do so via the ADCMPINTEN bits associated with each channel in the INTEN register.

| Bit   | Symbol  | Description                                                                                                        | Reset<br>value |
|-------|---------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   |         | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |
| 15:4  | THRHIGH | High threshold value against which A/D results will be compared                                                    | 0x000          |
| 31:16 | -       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

## Table 285. Compare High Threshold register0 (THR0\_HIGH, address 0x4001 C058) bit description

| Table 286. | Compare High Threshold register 1 (THR1_HIGH, address 0x4001 C05C) bit |
|------------|------------------------------------------------------------------------|
|            | description                                                            |

| Bit   | Symbol  |                                                                                                                    | Reset<br>value |
|-------|---------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 3:0   |         | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |
| 15:4  | THRHIGH | High threshold value against which A/D results will be compared                                                    | 0x000          |
| 31:16 | -       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

## 21.6.8 A/D Channel Threshold Select register

For each channel, this register indicates which pair of threshold registers conversion results should be compared to.

Table 287. A/D Channel Threshold Select register (CHAN\_THRSEL, addresses 0x4001 C060) bit description

| Bit | Symbol     | Value                                | Description                                                                                                                    | Reset<br>value |
|-----|------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | CH0_THRSEL |                                      | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 0 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 0 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 1   | CH1_THRSEL |                                      | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 1 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 1 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 2   | CH2_THRSEL |                                      | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 2 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 2 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 3   | CH3_THRSEL | _THRSEL Threshold select by channel. | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 3 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 3 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 4   | CH4_THRSEL |                                      | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 4 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 4 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 5   | CH5_THRSEL |                                      | Threshold select by channel.                                                                                                   | 0              |
|     |            | 0                                    | Threshold 0. Channel 5 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|     |            | 1                                    | Threshold 1. Channel 5 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |

| Bit   | Symbol      | Value                                                                                                                     | Description                                                                                                                     | Reset<br>value |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------------|
| 6     | CH6_THRSEL  |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 6 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers  |                |
|       |             | 1                                                                                                                         | Threshold 1. Channel 6 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers  |                |
| 7     | CH7_THRSEL  |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 7 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers  |                |
|       |             | 1                                                                                                                         | Threshold 1. Channel 7 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers  |                |
| 8     | CH8_THRSEL  |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 8 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers  |                |
|       |             | 1 Threshold 1. Channel 8 results will be compared against the threshold indicated in the THR1_LOW and THR1_HIGH registers | Threshold 1. Channel 8 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers  |                |
| 9     | CH9_THRSEL  |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 9 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers  |                |
|       |             | 1                                                                                                                         | Threshold 1. Channel 9 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers  |                |
| 10    | CH10_THRSEL |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 10 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|       |             | 1                                                                                                                         | Threshold 1. Channel 10 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 11    | CH11_THRSEL |                                                                                                                           | Threshold select by channel.                                                                                                    | 0              |
|       |             | 0                                                                                                                         | Threshold 0. Channel 11 results will be compared against the threshold levels indicated in the THR0_LOW and THR0_HIGH registers |                |
|       |             | 1                                                                                                                         | Threshold 1. Channel 11 results will be compared against the threshold levels indicated in the THR1_LOW and THR1_HIGH registers |                |
| 31:12 |             |                                                                                                                           | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.              | NA             |

#### 21.6.9 A/D Interrupt Enable Register

There are four separate interrupt requests generated by the ADC: conversion-complete or sequence-complete interrupts for each of the two sequences, a threshold-comparison out-of-range interrupt, and a data overrun interrupt. The two conversion/sequence-complete interrupts can also serve as DMA triggers.

These interrupts may be combined into one request on some chips if there is a limited number of interrupt slots. This register contains the interrupt-enable bits for each interrupt.

In this register, threshold events selected in the ADCMPINTENn bits are described as follows:

UM11021

- Disabled: Threshold comparisons on channel n will not generate an A/D threshold-compare interrupt request.
- Outside threshold: A conversion result on channel n which is outside the range specified by the designated HIGH and LOW threshold registers will set the channel n THCMP flag in the FLAGS register and generate an A/D threshold-compare interrupt request.
- Crossing threshold: Detection of a threshold crossing on channel n will set the channel n THCMP flag in the ADFLAGS register and generate an A/D threshold-compare interrupt request.

**Remark:** Overrun and threshold-compare interrupts related to a particular channel will occur regardless of which sequence was in progress at the time the conversion was performed or what trigger caused the conversion.

| Bit | Symbol      | Value | Description                                                                                                                                                                                                                                                                                   | Reset<br>value |
|-----|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | SEQA_INTEN  |       | Sequence A interrupt enable.                                                                                                                                                                                                                                                                  | 0              |
|     |             | 0     | Disabled. The sequence A interrupt/DMA trigger is disabled.                                                                                                                                                                                                                                   |                |
|     |             | 1     | Enabled. The sequence A interrupt/DMA trigger is enabled and will be<br>asserted either upon completion of each individual conversion performed as<br>part of sequence A, or upon completion of the entire A sequence of<br>conversions, depending on the MODE bit in the SEQA_CTRL register. |                |
| 1   | SEQB_INTEN  |       | Sequence B interrupt enable.                                                                                                                                                                                                                                                                  | 0              |
|     |             | 0     | Disabled. The sequence B interrupt/DMA trigger is disabled.                                                                                                                                                                                                                                   |                |
|     |             | 1     | Enabled. The sequence B interrupt/DMA trigger is enabled and will be<br>asserted either upon completion of each individual conversion performed as<br>part of sequence B, or upon completion of the entire B sequence of<br>conversions, depending on the MODE bit in the SEQB_CTRL register. |                |
| 2   | OVR_INTEN   |       | Overrun interrupt enable.                                                                                                                                                                                                                                                                     | 0              |
|     |             | 0     | Disabled. The overrun interrupt is disabled.                                                                                                                                                                                                                                                  |                |
|     |             | 1     | Enabled. The overrun interrupt is enabled. Detection of an overrun condition<br>on any of the 12 channel data registers will cause an overrun interrupt<br>request.                                                                                                                           |                |
|     |             |       | In addition, if the MODE bit for a particular sequence is 0, then an overrun in the global data register for that sequence will also cause this interrupt request to be asserted.                                                                                                             |                |
| 4:3 | ADCMPINTEN0 |       | Threshold comparison interrupt enable.                                                                                                                                                                                                                                                        | 00             |
|     |             | 0x0   | Disabled.                                                                                                                                                                                                                                                                                     |                |
|     |             | 0x1   | Outside threshold.                                                                                                                                                                                                                                                                            |                |
|     |             | 0x2   | Crossing threshold.                                                                                                                                                                                                                                                                           |                |
|     |             | 0x3   | Reserved                                                                                                                                                                                                                                                                                      |                |
| 6:5 | ADCMPINTEN1 |       | Threshold comparison interrupt enable.                                                                                                                                                                                                                                                        | 00             |
|     |             | 0x0   | Disabled.                                                                                                                                                                                                                                                                                     |                |
|     |             | 0x1   | Outside threshold.                                                                                                                                                                                                                                                                            |                |
|     |             | 0x2   | Crossing threshold.                                                                                                                                                                                                                                                                           |                |
|     |             | 0x3   | Reserved.                                                                                                                                                                                                                                                                                     |                |

#### Table 288. A/D Interrupt Enable register (INTEN, address 0x4001 C064 ) bit description

| Bit   | Symbol      | Value | Description                            | Reset<br>value |
|-------|-------------|-------|----------------------------------------|----------------|
| 8:7   | ADCMPINTEN2 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 10:9  | ADCMPINTEN3 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 12:11 | ADCMPINTEN4 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 14:13 | ADCMPINTEN5 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 16:15 | ADCMPINTEN6 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved.                              |                |
| 18:17 | ADCMPINTEN7 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 20:19 | ADCMPINTEN8 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |
| 22:21 | ADCMPINTEN9 |       | Threshold comparison interrupt enable. | 00             |
|       |             | 0x0   | Disabled.                              |                |
|       |             | 0x1   | Outside threshold.                     |                |
|       |             | 0x2   | Crossing threshold.                    |                |
|       |             | 0x3   | Reserved                               |                |

#### Table 288. A/D Interrupt Enable register (INTEN, address 0x4001 C064 ) bit description

User manual

| Bit   | Symbol       | Value | Description                                                                                                        | Reset<br>value |
|-------|--------------|-------|--------------------------------------------------------------------------------------------------------------------|----------------|
| 24:23 | ADCMPINTEN10 |       | Threshold comparison interrupt enable.                                                                             | 00             |
|       |              | 0x0   | Disabled.                                                                                                          |                |
|       |              | 0x1   | Outside threshold.                                                                                                 |                |
|       |              | 0x2   | Crossing threshold.                                                                                                |                |
|       |              | 0x3   | Reserved                                                                                                           |                |
| 26:25 | ADCMPINTEN11 |       | Threshold comparison interrupt enable.                                                                             | 00             |
|       |              | 0x0   | Disabled.                                                                                                          |                |
|       |              | 0x1   | Outside threshold.                                                                                                 |                |
|       |              | 0x2   | Crossing threshold.                                                                                                |                |
|       |              | 0x3   | Reserved                                                                                                           |                |
| 31:27 | -            |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined. | NA             |

#### 21.6.10 A/D Flag register

The A/D Flags registers contains the four interrupt request flags along with the individual overrun flags that contribute to an overrun interrupt and the component threshold-comparison flags that contribute to that interrupt.

The channel OVERRUN flags, mirror those in the appearing in the individual ADDAT registers for each channel, indicate a data overrun in each of those registers.

Likewise, the SEQA\_OVR and SEQB\_OVR bits mirror the OVERRUN bits in the two global data registers (SEQA\_GDAT and SEQB\_GDAT).

**Remark:** The SEQn\_INT conversion/sequence-complete flags also serve as DMA triggers.

 Table 289.
 A/D Flags register (FLAGS, address 0x4001 C068) bit description

| Bit | Symbol | Description                                                                                                                                                                                        | Reset<br>value |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0   | THCMP0 | Threshold comparison event on Channel 0. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1. | 0              |
| 1   | THCMP1 | Threshold comparison event on Channel 1. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1. | 0              |
| 2   | THCMP2 | Threshold comparison event on Channel 2. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1. | 0              |
| 3   | THCMP3 | Threshold comparison event on Channel 3. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1. | 0              |
| 4   | THCMP4 | Threshold comparison event on Channel 4. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1. | 0              |

| Bit   | Symbol    | Description                                                                                                                                                                                                                                                                                        | Reset<br>value |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 5     | THCMP5    | Threshold comparison event on Channel 5. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                 | 0              |
| 6     | THCMP6    | Threshold comparison event on Channel 6. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                 | 0              |
| 7     | THCMP7    | Threshold comparison event on Channel 7. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                 | 0              |
| 8     | THCMP8    | Threshold comparison event on Channel 8. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                 | 0              |
| 9     | ТНСМР9    | Threshold comparison event on Channel 9. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                 | 0              |
| 10    | THCMP10   | Threshold comparison event on Channel 10. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                | 0              |
| 11    | THCMP11   | Threshold comparison event on Channel 11. Set to 1 upon either an out-of-range result or a threshold-crossing result if enabled to do so in the INTEN register. This bit is cleared by writing a 1.                                                                                                | 0              |
| 12    | OVERRUN0  | Mirrors the OVERRRUN status flag from the result register for A/D channel 0                                                                                                                                                                                                                        | 0              |
| 13    | OVERRUN1  | Mirrors the OVERRRUN status flag from the result register for A/D channel 1                                                                                                                                                                                                                        | 0              |
| 14    | OVERRUN2  | Mirrors the OVERRRUN status flag from the result register for A/D channel 2                                                                                                                                                                                                                        | 0              |
| 15    | OVERRUN3  | Mirrors the OVERRRUN status flag from the result register for A/D channel 3                                                                                                                                                                                                                        | 0              |
| 16    | OVERRUN4  | Mirrors the OVERRRUN status flag from the result register for A/D channel 4                                                                                                                                                                                                                        | 0              |
| 17    | OVERRUN5  | Mirrors the OVERRRUN status flag from the result register for A/D channel 5                                                                                                                                                                                                                        | 0              |
| 18    | OVERRUN6  | Mirrors the OVERRRUN status flag from the result register for A/D channel 6                                                                                                                                                                                                                        | 0              |
| 19    | OVERRUN7  | Mirrors the OVERRRUN status flag from the result register for A/D channel 7                                                                                                                                                                                                                        | 0              |
| 20    | OVERRUN8  | Mirrors the OVERRRUN status flag from the result register for A/D channel 8                                                                                                                                                                                                                        | 0              |
| 21    | OVERRUN9  | Mirrors the OVERRRUN status flag from the result register for A/D channel 9                                                                                                                                                                                                                        | 0              |
| 22    | OVERRUN10 | Mirrors the OVERRRUN status flag from the result register for A/D channel 10                                                                                                                                                                                                                       | 0              |
| 23    | OVERRUN11 | Mirrors the OVERRRUN status flag from the result register for A/D channel 11                                                                                                                                                                                                                       | 0              |
| 24    | SEQA_OVR  | Mirrors the global OVERRUN status flag in the SEQA_GDAT register                                                                                                                                                                                                                                   | 0              |
| 25    | SEQB_OVR  | Mirrors the global OVERRUN status flag in the SEQB_GDAT register                                                                                                                                                                                                                                   | 0              |
| 27:26 | -         | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                 | NA             |
| 28    | SEQA_INT  | Sequence A interrupt/DMA flag.                                                                                                                                                                                                                                                                     | 0              |
|       |           | If the MODE bit in the SEQA_CTRL register is 0, this flag will mirror the DATAVALID bit in the sequence A global data register (SEQA_GDAT), which is set at the end of every A/D conversion performed as part of sequence A. It will be cleared automatically when the SEQA_GDAT register is read. |                |
|       |           | If the MODE bit in the SEQA_CTRL register is 1, this flag will be set upon completion of an entire A sequence. In this case it must be cleared by writing a 1 to this SEQA_INT bit.                                                                                                                |                |
|       |           | This interrupt must be enabled in the INTEN register.                                                                                                                                                                                                                                              |                |

#### Table 289. A/D Flags register (FLAGS, address 0x4001 C068) bit description

| Bit | Symbol    | Description                                                                                                                                                                                                                                                                                        | Reset<br>value |
|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 29  | SEQB_INT  | Sequence A interrupt/DMA flag.                                                                                                                                                                                                                                                                     | 0              |
|     |           | If the MODE bit in the SEQB_CTRL register is 0, this flag will mirror the DATAVALID bit in the sequence A global data register (SEQB_GDAT), which is set at the end of every A/D conversion performed as part of sequence B. It will be cleared automatically when the SEQB_GDAT register is read. |                |
|     |           | If the MODE bit in the SEQB_CTRL register is 1, this flag will be set upon completion of an entire B sequence. In this case it must be cleared by writing a 1 to this SEQB_INT bit.                                                                                                                |                |
|     |           | This interrupt must be enabled in the INTEN register.                                                                                                                                                                                                                                              |                |
| 30  | THCMP_INT | Threshold Comparison Interrupt/DMA flag.                                                                                                                                                                                                                                                           | 0              |
|     |           | This bit will be set if any of the 12 THCMP flags in the lower bits of this register are set to 1 (due to an enabled out-of-range or threshold-crossing event on any channel).                                                                                                                     |                |
|     |           | Each type of threshold comparison interrupt on each channel must be individually enabled in the INTEN register to cause this interrupt.                                                                                                                                                            |                |
|     |           | This bit will be cleared when all of the component flags in bits 11:0 are cleared via writing 1s to those bits.                                                                                                                                                                                    |                |
| 31  | OVR_INT   | Overrun Interrupt flag.                                                                                                                                                                                                                                                                            | 0              |
|     |           | Any overrun bit in any of the individual channel data registers will cause this interrupt. In addition, if the MODE bit in either of the SEQn_CTRL registers is 0 then the OVERRUN bit in the corresponding SEQn_GDAT register will also cause this interrupt.                                     |                |
|     |           | This interrupt must be enabled in the INTEN register.                                                                                                                                                                                                                                              |                |
|     |           | This bit will be cleared when all of the individual overrun bits have been cleared via reading the corresponding data registers.                                                                                                                                                                   |                |

#### Table 289. A/D Flags register (FLAGS, address 0x4001 C068) bit description

#### 21.6.11 A/D trim register

The A/D trim register configures the ADC for the appropriate operating range of the analog supply voltage VDDA.

**Remark:** Failure to set the VRANGE bit correctly causes the ADC to return incorrect conversion results.

| Bit  | Symbol | Value | Description                          | Reset<br>value |
|------|--------|-------|--------------------------------------|----------------|
| 4:0  | -      |       | Reserved.                            | -              |
| 5    | VRANGE |       | Reserved.                            | 0              |
|      |        | 0     | High voltage. VDD = 2.7 V to 3.6 V.  |                |
|      |        | 1     | Low voltage. $VDD = 2.4 V$ to 2.7 V. |                |
| 31:6 | -      |       | Reserved.                            | -              |

Table 290. A/D Flags register (TRM, addresses 0x4001 C06C) bit description

## **21.7 Functional description**

#### 21.7.1 Conversion Sequences

A conversion sequence is a single pass through a series of A/D conversions performed on a selected set of A/D channels. Software can set-up two independent conversion sequences, either of which can be triggered by software or by a transition on one of the hardware triggers. Each sequence can be triggered by a different hardware trigger. One of these conversion sequences is referred to as the A sequence and the other as the B sequence. It is not necessary to employ both sequences.

An optional single-step mode allows advancing through the channels of a sequence one at a time on each successive occurrence of a trigger.

The user can select whether a trigger on the B sequence can interrupt an already-in-progress A sequence. The B sequence, however, can never be interrupted by an A trigger.

### 21.7.2 Hardware-triggered conversion

Software can select which of these hardware triggers will launch each conversion sequence and it can specify the active edge for the selected trigger independently for each conversion sequence.

For each conversion sequence, if a designated trigger event occurs, one single cycle through that conversion sequence will be launched unless:

- The BURST bit in the ADSEQn\_CTRL register for this sequence is set to 1.
- The requested conversion sequence is already in progress.
- A set of conversions for the alternate conversion sequence is already in progress except in the case of a B trigger interrupting an A sequence if the A sequence is set to LOWPRIO.

If any of these conditions is true, the new trigger event will be ignored and will have no effect.

In addition, if the single-step bit for a sequence is set, each new trigger will cause a single conversion to be performed on the next channel in the sequence rather than launching a pass through the entire sequence.

If the A sequence is enabled to be interrupted (i.e. the LOWPRIO bit in the SEQA\_CTRL register is set) and a B trigger occurs while an A sequence is in progress, then the following will occur:

- The A/D conversion which is currently in-progress will be aborted.
- The A sequence will be paused, and the B sequence will immediately commence.
- The interrupted A sequence will resume after the B sequence completes, beginning with the conversion that was aborted when the interruption occurred. The channel for that conversion will be re-sampled.

#### 21.7.2.1 Avoiding spurious hardware triggers

Care should be taken to avoid generating a spurious trigger when writing to the SEQn\_CTRL register to change the trigger selected for the sequence, switch the polarity of the selected trigger, or to enable the sequence for operation.

In general, the TRIGGER and TRIGPOL bits in the SEQn\_CTRL register should only be written to when the sequence is disabled (while the SEQn\_ENA bit is LOW). The SEQn\_ENA bit itself should only be set when the selected trigger input is in its INACTIVE

state (as designated by the TRIGPOL bit). If this condition is not met, a trigger will be generated immediately upon enabling the sequence - even though no actual transition has occurred on the trigger input.

#### 21.7.3 Software-triggered conversion

There are two ways that software can trigger a conversion sequence:

- 1. Start Bit: The first way to software-trigger an sequence is by setting the START bit in the corresponding SEQn\_CTRL register. The response to this is identical to occurrence of a hardware trigger on that sequence. Specifically, one cycle of conversions through that conversion sequence will be immediately triggered except as indicated above.
- Burst Mode: The other way to initiate conversions is to set the BURST bit in the SEQn\_CTRL register. As long as this bit is 1 the designated conversion sequence will be continuously and repetitively cycled through. Any new software or hardware trigger on this sequence will be ignored.

If a bursting A sequence is allowed to be interrupted (i.e. the LOWPRIO bit in its SEQA\_CTRL register is set to 1 and a software or hardware trigger for the B sequence occurs, then the burst will be immediately interrupted and a B sequence will be initiated. The interrupted A sequence will resume continuous cycling, starting with the aborted conversion, after the alternate sequence has completed.

#### 21.7.4 Interrupts

There are four interrupts that can be generated by the ADC:

- · Conversion-Complete or Sequence-Complete interrupts for sequences A and B
- Threshold-Compare Out-of-Range Interrupt
- Data Overrun Interrupt

Any of these interrupt requests may be individually enabled or disabled in the INTEN register.

#### 21.7.4.1 Conversion-Complete or Sequence-Complete interrupts

For each of the two sequences, an interrupt request can either be asserted at the end of each A/D conversion performed as part of that sequence or when the entire sequence of conversions is completed. The MODE bits in the SEQn\_CTRL registers select between these alternative behaviors.

If the MODE bit for a sequence is 0 (conversion-complete mode) then the interrupt flag for that sequence will reflect the state of the DATAVALID bit in the global data register (SEQn\_GDAT) for that sequence. In this case, reading the SEQn\_GDAT register will automatically clear the interrupt request.

If the MODE bit for the sequence is 1 (sequence-complete mode) then the interrupt flag must be written-to by software to clear it (except when used as a DMA trigger, in which case it will be cleared in hardware by the DMA engine).

#### 21.7.4.2 Threshold-Compare Out-of-Range Interrupt

Every conversion performed on any channel is automatically compared against a designated set of low and high threshold levels specified in the THRn\_HIGH and THRn\_LOW registers. The results of this comparison on any individual channel(s) can be enabled to cause a threshold-compare interrupt if that result was above or below the range specified by the two thresholds or, alternatively, if the result represented a crossing of the low threshold in either direction.

This flag must be cleared by a software write to clear the individual THCMP flags in the FLAGS register.

#### 21.7.4.3 Data Overrun Interrupt

This interrupt request will be asserted if any of the OVERRUN bits in the individual channel data registers are set. In addition, the OVERRUN bits in the two sequence global data (SEQn\_GDAT) registers will cause this interrupt request IF the MODE bit for that sequence is set to 0 (conversion-complete mode).

This flag will be cleared when the OVERRUN bit that caused it is cleared via reading the register containing it.

Note that the OVERRUN bits in the individual data registers are cleared when data related to that channel is read from either of the global data registers as well as when the individual data registers themselves are read.

#### 21.7.5 Optional operating modes

The following optional mode of A/D operation may be selected in the CTRL register:

Low-power mode. When this mode is selected, the analog portions of the ADC are automatically shut down when no conversions are in progress. The ADC is automatically restarted whenever any hardware or software trigger event occurs. This mode can save an appreciable amount of power when the ADC is not in continuous use, but at the expense of a delay between the trigger event and the onset of sampling and conversion.

#### 21.7.6 DMA control

The sequence-A or sequence-B conversion/sequence-complete interrupts may also be used to generate a DMA trigger. To trigger a DMA transfer, the same conditions must be met as the conditions for generating an interrupt (see <u>Section 21.7.4</u> and <u>Section 21.6.9</u>).

**Remark:** If the DMA is used, the ADC interrupt must be disabled in the NVIC.

For DMA transfers, only burst requests are supported. The burst size can be set to one in the DMA channel control register (see <u>Table 169</u>). If the number of ADC channels is not equal to one of the other DMA-supported burst sizes (applicable DMA burst sizes are 1, 4, 8), set the burst size to one.

The DMA transfer size determines when a DMA interrupt is generated. The transfer size can be set to the number of ADC channels being converted. Non-contiguous channels can be transferred by the DMA using the scatter/gather linked lists.

## 21.7.7 Hardware Trigger Source Selection

Each ADC has a selection of several on-chip and off-chip hardware trigger sources. The trigger to be used for each conversion sequence is specified in the TRIGGER fields in the two SEQn\_CTRL registers.

UM11021

## **UM11021**

Chapter 22: LPC83x CRC engine

Rev. 1.1 — 5 October 2016

**User manual** 

## 22.1 How to read this chapter

The CRC engine is available on all LPC83x parts.

## 22.2 Features

- Supports three common polynomials CRC-CCITT, CRC-16, and CRC-32.
  - CRC-CCITT:  $x^{16} + x^{12} + x^5 + 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.
- 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 x 2-cycle)
  - 32-bit write: 4-cycle operation (8-bit x 4-cycle)

## 22.3 Basic configuration

Enable the clock to the CRC engine in the SYSAHBCLKCTRL register (Table 33, bit 13).

## 22.4 Pin description

The CRC engine has no configurable pins.

## 22.5 General description

The Cyclic Redundancy Check (CRC) generator with programmable polynomial settings supports several CRC standards commonly used.



User manual

## 22.6 Register description

#### Table 291. Register overview: CRC engine (base address 0x5000 0000)

| Name    | Access | Address<br>offset | Description           | Reset value | Reference        |
|---------|--------|-------------------|-----------------------|-------------|------------------|
| MODE    | R/W    | 0x000             | CRC mode register     | 0x0000 0000 | <u>Table 292</u> |
| SEED    | R/W    | 0x004             | CRC seed register     | 0x0000 FFFF | Table 293        |
| SUM     | RO     | 0x008             | CRC checksum register | 0x0000 FFFF | Table 294        |
| WR_DATA | WO     | 0x008             | CRC data register     | -           | <u>Table 295</u> |

#### 22.6.1 CRC mode register

#### Table 292. CRC mode register (MODE, address 0x5000 0000) bit description

| Bit  | Symbol      | Description                                        | Reset value |
|------|-------------|----------------------------------------------------|-------------|
| 1:0  | CRC_POLY    | CRC polynom:                                       | 00          |
|      |             | 1X= CRC-32 polynomial                              |             |
|      |             | 01= CRC-16 polynomial                              |             |
|      |             | 00= CRC-CCITT polynomial                           |             |
| 2    | BIT_RVS_WR  | Data bit order:                                    | 0           |
|      |             | 1= Bit order reverse for CRC_WR_DATA (per byte)    |             |
|      |             | 0= No bit order reverse for CRC_WR_DATA (per byte) |             |
| 3    | CMPL_WR     | Data complement:                                   | 0           |
|      |             | 1= 1's complement for CRC_WR_DATA                  |             |
|      |             | 0= No 1's complement for CRC_WR_DATA               |             |
| 4    | BIT_RVS_SUM | CRC sum bit order:                                 | 0           |
|      |             | 1= Bit order reverse for CRC_SUM                   |             |
|      |             | 0= No bit order reverse for CRC_SUM                |             |
| 5    | CMPL_SUM    | CRC sum complement:                                | 0           |
|      |             | 1= 1's complement for CRC_SUM                      |             |
|      |             | 0=No 1's complement for CRC_SUM                    |             |
| 31:6 | Reserved    | Always 0 when read                                 | 0x0000000   |

#### 22.6.2 CRC seed register

#### Table 293. CRC seed register (SEED, address 0x5000 0004) bit description

| Bit  | Symbol   | Description                                                                                                                            | Reset value |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31:0 | CRC_SEED | A write access to this register will load CRC seed value to CRC_SUM register with selected bit order and 1's complement pre-processes. | 0x0000 FFFF |
|      |          | <b>Remark:</b> A write access to this register will overrule the CRC calculation in progresses.                                        |             |

## 22.6.3 CRC checksum register

This register is a Read-only register containing the most recent checksum. The read request to this register is automatically delayed by a finite number of wait states until the results are valid and the checksum computation is complete.

| T-1-1-004  |                  |               |                  |                      |
|------------|------------------|---------------|------------------|----------------------|
| Table 294. | CRC checksum reg | gister (Suwi, | address 0x5000 0 | 008) bit description |

| Bit  | Symbol | Description                                                                                                          | Reset value |
|------|--------|----------------------------------------------------------------------------------------------------------------------|-------------|
| 31:0 |        | The most recent CRC sum can be read through this register with selected bit order and 1's complement post-processes. | 0x0000 FFFF |

#### 22.6.4 CRC data register

This register is a Write-only register containing the data block for which the CRC sum will be calculated.

| Table 295. | CRC data register () | WR_DATA, | address 0x5000 0008 | ) bit description |
|------------|----------------------|----------|---------------------|-------------------|
|------------|----------------------|----------|---------------------|-------------------|

| Bit  | Symbol      | Description                                                                                                                                                                                                     | Reset<br>value |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 31:0 | CRC_WR_DATA | Data written to this register will be taken to perform CRC calculation with selected bit order and 1's complement pre-process. Any write size 8, 16 or 32-bit are allowed and accept back-to-back transactions. | -              |

## 22.7 Functional description

The following sections describe the register settings for each supported CRC standard:

#### 22.7.1 CRC-CCITT set-up

Polynomial =  $x^{16} + x^{12} + x^5 + 1$ Seed Value = 0xFFF Bit order reverse for data input: NO 1's complement for data input: NO Bit order reverse for CRC sum: NO 1's complement for CRC sum: NO CRC\_MODE = 0x0000 0000 CRC\_SEED = 0x0000 FFFF

#### 22.7.2 CRC-16 set-up

Polynomial =  $x^{16} + x^{15} + x^2 + 1$ Seed Value = 0x0000 Bit order reverse for data input: YES 1's complement for data input: NO Bit order reverse for CRC sum: YES 1's complement for CRC sum: NO CRC\_MODE = 0x0000 0015 CRC\_SEED = 0x0000 0000

#### 22.7.3 CRC-32 set-up

Polynomial =  $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 Seed Value = 0xFFFF FFF Bit order reverse for data input: YES 1's complement for data input: NO Bit order reverse for CRC sum: YES 1's complement for CRC sum: YES CRC\_MODE = 0x0000 0036 CRC\_SEED = 0xFFFF FFFF

**User manual** 

## **UM11021**

Chapter 23: LPC83x Flash controller

Rev. 1.1 — 5 October 2016

**User manual** 

## 23.1 How to read this chapter

The flash controller is identical on all LPC83x parts.

## 23.2 Features

- Controls flash access time.
- Provides registers for flash signature generation.

## 23.3 General description

The flash controller is accessible for programming flash wait states and for generating the flash signature.

## 23.4 Register description

#### Table 296. Register overview: FMC (base address 0x4004 0000)

|          | 3      |                   |                                  |                |           |
|----------|--------|-------------------|----------------------------------|----------------|-----------|
| Name     | Access | Address<br>offset | Description                      | Reset<br>value | Reference |
| FLASHCFG | R/W    | 0x010             | Flash configuration register     | -              | Table 297 |
| FMSSTART | R/W    | 0x020             | Signature start address register | 0              | Table 298 |
| FMSSTOP  | R/W    | 0x024             | Signature stop-address register  | 0              | Table 299 |
| FMSW0    | R      | 0x02C             | Signature word                   | -              | Table 300 |

## 23.4.1 Flash configuration register

Access time to the flash memory can be configured independently of the system frequency by writing to the FLASHCFG register.

| Table | 297. Flash c | configura | tion register (FLASHCFG, address 0x4004 0010) bit descr                                                    | iption         |
|-------|--------------|-----------|------------------------------------------------------------------------------------------------------------|----------------|
| Bit   | Symbol       | Value     | Description                                                                                                | Reset<br>value |
| 1:0   | FLASHTIM     |           | Flash memory access time. FLASHTIM +1 is equal to the number of system clocks used for flash access.       | 0x1            |
|       |              | 0x0       | 1 system clock flash access time.                                                                          |                |
|       |              | 0x1       | 2 system clocks flash access time.                                                                         |                |
|       |              | 0x2       | Reserved.                                                                                                  |                |
|       |              | 0x3       | Reserved.                                                                                                  |                |
| 31:2  | -            | -         | Reserved. User software must not change the value of these bits. Bits 31:2 must be written back exactly as | -              |

#### ----~ ... .....

UM11021

read.

### 23.4.2 Flash signature start address register

#### Table 298. Flash Module Signature Start register (FMSSTART, 0x4004 0020) bit description

| Bit   | Symbol | Description                                                                                                           | Reset<br>value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------|----------------|
| 16:0  | START  | Signature generation start address (corresponds to AHB byte address bits[18:2]).                                      | 0              |
| 31:17 | -      | Reserved, user software should not write ones to reserved bits.<br>The value read from a reserved bit is not defined. | NA             |

#### 23.4.3 Flash signature stop address register

 Table 299.
 Flash Module Signature Stop register (FMSSTOP, 0x4004 0024) bit description

| Bit   | Symbol   | Value | Description                                                                                                                                               | Reset<br>value |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 16:0  | STOPA    |       | Stop address for signature generation (the word specified by STOPA is included in the address range). The address is in units of memory words, not bytes. | 0              |
| 30:17 | -        |       | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                        | 0              |
| 31    | STRTBIST |       | When this bit is written to 1, signature generation starts.<br>At the end of signature generation, this bit is<br>automatically cleared.                  | 0              |

#### 23.4.4 Flash signature generation result register

The signature generation result register returns the flash signature produced by the embedded signature generator.

The generated flash signature can be used to verify the flash memory contents. The generated signature can be compared with an expected signature and thus makes saves time and code space. The method for generating the signature is described in Section 23.5.1.

#### Table 300. FMSW0 register bit description (FMSW0, address: 0x4004 002C)

| Bit  | Symbol | Description       | Reset value |
|------|--------|-------------------|-------------|
| 31:0 | SIG    | 32-bit signature. | -           |

## 23.5 Functional description

#### 23.5.1 Flash signature generation

The flash module contains a built-in signature generator. This generator can produce a 32-bit signature from a range of flash memory. A typical usage is to verify the flashed contents against a calculated signature (e.g. during programming).

The address range for generating a signature must be aligned on flash-word boundaries, i.e. 32-bit boundaries. Once started, signature generation completes independently. While signature generation is in progress, the flash memory cannot be accessed for other purposes, and an attempted read will cause a wait state to be asserted until signature

generation is complete. Code outside of the flash (e.g. internal RAM) can be executed during signature generation. This can include interrupt services, if the interrupt vector table is re-mapped to memory other than the flash memory. The code that initiates signature generation should also be placed outside of the flash memory.

#### 23.5.1.1 Signature generation address and control registers

These registers control automatic signature generation. A signature can be generated for any part of the flash memory contents. The address range to be used for generation is defined by writing the start address to the signature start address register (FMSSTART) and the stop address to the signature stop address register (FMSSTOP. The start and stop addresses must be aligned to 32-bit boundaries.

Signature generation is started by setting the STRTBIST bit in the FMSSTOP register. Setting the STRTBIST bit is typically combined with the signature stop address in a single write.

<u>Table 298</u> and <u>Table 299</u> show the bit assignments in the FMSSTART and FMSSTOP registers respectively.

#### 23.5.1.2 Signature generation

A signature can be generated for any part of the flash contents. The address range to be used for signature generation is defined by writing the start address to the FMSSTART register, and the stop address to the FMSSTOP register.

The signature generation is started by writing a 1 to the SIG\_START bit in the FMSSTOP register. Starting the signature generation is typically combined with defining the stop address, which is done in the STOP bits of the same register.

The time that the signature generation takes is proportional to the address range for which the signature is generated. Reading of the flash memory for signature generation uses a self-timed read mechanism and does not depend on any configurable timing settings for the flash. A safe estimation for the duration of the signature generation is:

Duration =  $int((60 / tcy) + 3) \times (FMSSTOP - FMSSTART + 1)$ 

When signature generation is triggered via software, the duration is in AHB clock cycles, and tcy is the time in ns for one AHB clock.

After signature generation, a 32-bit signature can be read from the FMSW0 register. The 32-bit signature reflects the corrected data read from the flash and the flash parity bits and check bit values.

#### 23.5.1.3 Content verification

The signature as it is read from the FMSW0 register must be equal to the reference signature. The following pseudo-code shows the algorithm to derive the reference signature:

```
sign = 0
FOR address = FMSSTART.START to FMSSTOP.STOPA
{
    FOR i = 0 TO 30
    {
        nextSign[i] = f_Q[address][i] XOR sign[i + 1]
```

UM11021

```
}
nextSign[31] = f_Q[address][31] XOR sign[0] XOR sign[10] XOR sign[30] XOR
sign[31]
sign = nextSign
}
signature32 = sign
```

User manual

# UM11021

Chapter 24: LPC83x Flash In-System and In-Application Programming (ISP and IAP)

Rev. 1.1 — 5 October 2016

**User manual** 

## 24.1 How to read this chapter

See <u>Table 301</u> for different flash configurations.

## 24.2 Features

- In-System Programming: In-System programming (ISP) is programming or reprogramming the on-chip flash memory, using the bootloader software and UART serial port.
- In-Application Programming: In-Application (IAP) programming is performing erase and write operation on the on-chip flash memory, as directed by the end-user application code.
- You can use ISP and IAP when the part resides in the end-user board.
- Flash page write and erase supported.

## 24.3 Basic configuration

To use the IAP calls, enable the IRC and the IRC output in the PDRUNCFG register (see <u>Table 52 "Power configuration register (PDRUNCFG, address 0x4004 8238) bit</u> <u>description</u>").

## 24.4 Pin description

When the ISP entry pin (PIO0\_12) is pulled LOW on reset, the part enters ISP mode and the ISP command handler starts up. In ISP mode, pin PIO0\_0 is connected to function U0\_RXD and pin PIO0\_4 is connected to function U0\_TXD on the USART0 block.

## 24.5 General description

### 24.5.1 Flash configuration

Most IAP and ISP commands operate on sectors and specify sector numbers. In addition a page erase command is supported. The following table shows the correspondence between page numbers, sector numbers, and memory addresses.

The size of a sector is 1 KB and the size of a page is 64 Byte. One sector contains 16 pages.

| Table 301. LPC83x flash configuratio | n |
|--------------------------------------|---|
|--------------------------------------|---|

| Sector<br>number | Sector<br>size [KB] | Page number | Address range             | 16 KB<br>flash | 32 KB<br>flash |
|------------------|---------------------|-------------|---------------------------|----------------|----------------|
| 0                | 1                   | 0 -15       | 0x0000 0000 - 0x0000 03FF | yes            | yes            |
| 1                | 1                   | 16 - 31     | 0x0000 0400 - 0x0000 07FF | yes            | yes            |
| 2                | 1                   | 32 - 47     | 0x0000 0800 - 0x0000 0BFF | yes            | yes            |
| 3                | 1                   | 48 - 63     | 0x0000 0C00 - 0x0000 0FFF | yes            | yes            |
| 4                | 1                   | 64 - 79     | 0x0000 1000 - 0x0000 13FF | yes            | yes            |
| 5                | 1                   | 80 - 95     | 0x0000 1400 - 0x0000 17FF | yes            | yes            |
| 6                | 1                   | 96 - 111    | 0x0000 1800 - 0x0000 1BFF | yes            | yes            |
| 7                | 1                   | 112 - 127   | 0x0000 1C00 - 0x0000 1FFF | yes            | yes            |
| 8                | 1                   | 128 - 143   | 0x0000 2000 - 0x0000 23FF | yes            | yes            |
| 9                | 1                   | 144 - 159   | 0x0000 2400 - 0x0000 27FF | yes            | yes            |
| 10               | 1                   | 160 - 175   | 0x0000 2800 - 0x0000 2BFF | yes            | yes            |
| 11               | 1                   | 176 - 191   | 0x0000 2C00 - 0x0000 2FFF | yes            | yes            |
| 12               | 1                   | 192 - 207   | 0x0000 3000 - 0x0000 33FF | yes            | yes            |
| 13               | 1                   | 208 - 223   | 0x0000 3400 - 0x0000 37FF | yes            | yes            |
| 14               | 1                   | 224 - 239   | 0x0000 3800 - 0x0000 3BFF | yes            | yes            |
| 15               | 1                   | 240 - 255   | 0x0000 3C00 - 0x0000 3FFF | yes            | yes            |
| 16               | 1                   | 256 - 271   | 0x0000 4000 - 0x0000 43FF | -              | yes            |
| 17               | 1                   | 272 - 287   | 0x0000 4400 - 0x0000 47FF | -              | yes            |
| 18               | 1                   | 288 - 303   | 0x0000 4800 - 0x0000 4BFF | -              | yes            |
| 19               | 1                   | 304 - 319   | 0x0000 4C00 - 0x0000 4FFF | -              | yes            |
| 20               | 1                   | 320 - 335   | 0x0000 5000 - 0x0000 53FF | -              | yes            |
| 21               | 1                   | 336 - 351   | 0x0000 5400 - 0x0000 57FF | -              | yes            |
| 22               | 1                   | 352 - 367   | 0x0000 5800 - 0x0000 5BFF | -              | yes            |
| 23               | 1                   | 368 - 383   | 0x0000 5C00 - 0x0000 5FFF | -              | yes            |
| 24               | 1                   | 384 - 399   | 0x0000 6000 - 0x0000 63FF | -              | yes            |
| 25               | 1                   | 400 - 415   | 0x0000 6400 - 0x0000 67FF | -              | yes            |
| 26               | 1                   | 416 - 431   | 0x0000 6800 - 0x0000 6BFF | -              | yes            |
| 27               | 1                   | 432 - 447   | 0x0000 6C00 - 0x0000 6FFF | -              | yes            |
| 28               | 1                   | 448 - 463   | 0x0000 7000 - 0x0000 73FF | -              | yes            |
| 29               | 1                   | 464 - 479   | 0x0000 7400 - 0x0000 77FF | -              | yes            |
| 30               | 1                   | 480 - 495   | 0x0000 7800 - 0x0000 7BFF | -              | yes            |
| 31               | 1                   | 496 - 511   | 0x0000 7C00 - 0x0000 7FFF | -              | yes            |

#### 24.5.2 Flash content protection mechanism

The part is equipped with the Error Correction Code (ECC) capable Flash memory. The purpose of an error correction module is twofold:

The ECC first decodes data words read from the memory into output data words. Then, the ECC encodes data words to be written to the memory. The error correction capability consists of single bit error correction with Hamming code.

UM11021

The operation of the ECC is transparent to the running application. The ECC content itself is stored in a flash memory not accessible by the user's code to either read from it or write into it on its own. Six bits of ECC corresponds to every consecutive 32 bit of the user accessible Flash. Consequently, Flash bytes from 0x0000 0000 to 0x0000 0003 are protected by the first 6 bit ECC, Flash bytes from 0x0000 0004 to 0x0000 0007 are protected by the second 6-bit ECC byte, etc.

Whenever the CPU requests a read from the user accessible Flash, both 32 bits of raw data containing the specified memory location and the matching ECC byte are evaluated. If the ECC mechanism detects a single error in the fetched data, a correction will be applied before data are provided to the CPU. When a write request into the user accessible Flash is made, writing the user specified content is accompanied by a matching ECC value calculated and stored in the ECC memory.

When a sector of Flash memory is erased, the corresponding ECC bits are also erased. Once a 6-bit ECC is written, it can not be updated unless it is erased first. Therefore, for the implemented ECC mechanism to perform properly, data must be written into the flash memory in groups of 4 bytes (or multiples of 4), aligned as described above.

### 24.5.3 Code Read Protection (CRP)

Code Read Protection is a mechanism that allows the user to enable different levels of security in the system so that access to the on-chip flash and use of the ISP can be restricted. When needed, CRP is invoked by programming a specific pattern in flash location at 0x0000 02FC. IAP commands are not affected by the code read protection.

Important: any CRP change becomes effective only after the device has gone through a power cycle.

UM11021

| Name   | Pattern<br>programmed in<br>0x0000 02FC | Description                                                                                                                                                                                                                                                                |
|--------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO_ISP | 0x4E69 7370                             | Prevents sampling of the ISP entry pin for entering ISP mode. The ISP entry pin is available for other uses.                                                                                                                                                               |
| CRP1   | 0x12345678                              | Access to chip via the SWD pins is disabled. This mode allows partial flash update using the following ISP commands and restrictions:                                                                                                                                      |
|        |                                         | <ul> <li>Write to RAM command should not access RAM below 0x1000 0300. Access to<br/>addresses below 0x1000 0200 is disabled.</li> </ul>                                                                                                                                   |
|        |                                         | <ul> <li>Copy RAM to flash command can not write to Sector 0.</li> </ul>                                                                                                                                                                                                   |
|        |                                         | • Erase command can erase Sector 0 only when all sectors are selected for erase.                                                                                                                                                                                           |
|        |                                         | Compare command is disabled.                                                                                                                                                                                                                                               |
|        |                                         | Read Memory command is disabled.                                                                                                                                                                                                                                           |
|        |                                         | This mode is useful when CRP is required and flash field updates are needed but all sectors can not be erased. Since compare command is disabled in case of partial updates the secondary loader should implement checksum mechanism to verify the integrity of the flash. |
| CRP2   | 0x87654321                              | Access to chip via the SWD pins is disabled. The following ISP commands are disabled:                                                                                                                                                                                      |
|        |                                         | Read Memory                                                                                                                                                                                                                                                                |
|        |                                         | Write to RAM                                                                                                                                                                                                                                                               |
|        |                                         | • Go                                                                                                                                                                                                                                                                       |
|        |                                         | Copy RAM to flash                                                                                                                                                                                                                                                          |
|        |                                         | Compare                                                                                                                                                                                                                                                                    |
|        |                                         | When CRP2 is enabled the ISP erase command only allows erasure of all user sectors.                                                                                                                                                                                        |
| CRP3   | 0x43218765                              | Access to chip via the SWD pins is disabled. ISP entry by pulling the ISP entry pin LOW is disabled if a valid user code is present in flash sector 0.                                                                                                                     |
|        |                                         | This mode effectively disables ISP override using the ISP entry pin. It is up to the user's application to provide a flash update mechanism using IAP calls or call re-invoke ISP command to enable flash update via UART.                                                 |
|        |                                         | Caution: If CRP3 is selected, no future factory testing can be performed on the device.                                                                                                                                                                                    |

#### Table 302. Code Read Protection options

#### Table 303. Code Read Protection hardware/software interaction

| CRP option | User Code<br>Valid | ISP entry pin<br>at reset | SWD enabled | Part enters<br>ISP mode | partial flash<br>update in ISP<br>mode |
|------------|--------------------|---------------------------|-------------|-------------------------|----------------------------------------|
| None       | No                 | x                         | Yes         | Yes                     | Yes                                    |
| None       | Yes                | High                      | Yes         | No                      | NA                                     |
| None       | Yes                | Low                       | Yes         | Yes                     | Yes                                    |
| CRP1       | Yes                | High                      | No          | No                      | NA                                     |
| CRP1       | Yes                | Low                       | No          | Yes                     | Yes                                    |
| CRP2       | Yes                | High                      | No          | No                      | NA                                     |
| CRP2       | Yes                | Low                       | No          | Yes                     | No                                     |
| CRP3       | Yes                | x                         | No          | No                      | NA                                     |
| CRP1       | No                 | x                         | No          | Yes                     | Yes                                    |
| CRP2       | No                 | x                         | No          | Yes                     | No                                     |
| CRP3       | No                 | x                         | No          | Yes                     | No                                     |

| ISP command                           | CRP1                                                                | CRP2                     | CRP3 (no entry in ISP mode allowed) |
|---------------------------------------|---------------------------------------------------------------------|--------------------------|-------------------------------------|
| Unlock                                | yes                                                                 | yes                      | n/a                                 |
| Set Baud Rate                         | yes                                                                 | yes                      | n/a                                 |
| Echo                                  | yes                                                                 | yes                      | n/a                                 |
| Write to RAM                          | yes; above 0x1000 0300<br>only                                      | no                       | n/a                                 |
| Read Memory                           | no                                                                  | no                       | n/a                                 |
| Prepare sector(s) for write operation | yes                                                                 | yes                      | n/a                                 |
| Copy RAM to flash                     | yes; not to sector 0                                                | no                       | n/a                                 |
| Go                                    | no                                                                  | no                       | n/a                                 |
| Erase sector(s)                       | yes; sector 0 can only be<br>erased when all sectors are<br>erased. | yes; all sectors<br>only | n/a                                 |
| Blank check sector(s)                 | no                                                                  | no                       | n/a                                 |
| Read Part ID                          | yes                                                                 | yes                      | n/a                                 |
| Read Boot code version                | yes                                                                 | yes                      | n/a                                 |
| Compare                               | no                                                                  | no                       | n/a                                 |
| ReadUID                               | yes                                                                 | yes                      | n/a                                 |

Table 304. ISP commands allowed for different CRP levels

In case a CRP mode is enabled and access to the chip is allowed via the ISP, an unsupported or restricted ISP command will be terminated with return code CODE\_READ\_PROTECTION\_ENABLED.

#### 24.5.3.1 ISP entry protection

In addition to the three CRP modes, the user can prevent the sampling of the ISP entry pin for entering ISP mode and thereby release the ISP entry pin for other uses. This is called the NO\_ISP mode. The NO\_ISP mode can be entered by programming the pattern 0x4E69 7370 at location 0x0000 02FC.

## 24.6 API description

#### 24.6.1 UART ISP commands

The following commands are accepted by the ISP command handler. Detailed status codes are supported for each command. The command handler sends the return code INVALID\_COMMAND when an undefined command is received. Commands and return codes are in ASCII format.

CMD\_SUCCESS is sent by ISP command handler only when received ISP command has been completely executed and the new ISP command can be given by the host. Exceptions from this rule are "Set Baud Rate", "Write to RAM", "Read Memory", and "Go" commands.

| ISP Command                           | Usage                                                                                | Described in     |
|---------------------------------------|--------------------------------------------------------------------------------------|------------------|
| Unlock                                | U <unlock code=""></unlock>                                                          | Table 306        |
| Set Baud Rate                         | B <baud rate=""> <stop bit=""></stop></baud>                                         | Table 307        |
| Echo                                  | A <setting></setting>                                                                | Table 308        |
| Write to RAM                          | W <start address=""> <number bytes="" of=""></number></start>                        | Table 309        |
| Read Memory                           | R <address> <number bytes="" of=""></number></address>                               | Table 310        |
| Prepare sector(s) for write operation | P <start number="" sector=""> <end number="" sector=""></end></start>                | Table 311        |
| Copy RAM to flash                     | C <flash address=""> <ram address=""> <number bytes="" of=""></number></ram></flash> | Table 312        |
| Go                                    | G <address> <mode></mode></address>                                                  | Table 313        |
| Erase sector(s)                       | E <start number="" sector=""> <end number="" sector=""></end></start>                | Table 314        |
| Blank check sector(s)                 | I <start number="" sector=""> <end number="" sector=""></end></start>                | Table 315        |
| Read Part ID                          | J                                                                                    | Table 316        |
| Read Boot code version                | К                                                                                    | Table 318        |
| Compare                               | M <address1> <address2> <number bytes="" of=""></number></address2></address1>       | <u>Table 319</u> |
| ReadUID                               | Ν                                                                                    | Table 320        |
| Read CRC checksum                     | S <address> <number bytes="" of=""></number></address>                               | Table 321        |

#### Table 305. UART ISP command summary

#### 24.6.1.1 Unlock <Unlock code>

#### Table 306. UART ISP Unlock command

| Command     | U                                                                             |
|-------------|-------------------------------------------------------------------------------|
| Input       | Unlock code: 23130 (decimal)                                                  |
| Return Code | CMD_SUCCESS                                                                   |
|             | INVALID_CODE                                                                  |
|             | PARAM_ERROR                                                                   |
| Description | This command is used to unlock Flash Write, Erase, and Go commands.           |
| Example     | "U 23130 <cr><lf>" unlocks the Flash Write/Erase &amp; Go commands.</lf></cr> |

#### 24.6.1.2 Set Baud Rate <Baud Rate> <stop bit>

#### Table 307. UART ISP Set Baud Rate command

| Command     | В                                                                                                                                         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Baud Rate: 9600   19200   38400   57600   115200                                                                                          |
|             | Stop bit: 1   2                                                                                                                           |
| Return Code | CMD_SUCCESS                                                                                                                               |
|             | INVALID_BAUD_RATE                                                                                                                         |
|             | INVALID_STOP_BIT                                                                                                                          |
|             | PARAM_ERROR                                                                                                                               |
| Description | This command is used to change the baud rate. The new baud rate is effective after the command handler sends the CMD_SUCCESS return code. |
| Example     | "B 57600 1 <cr><lf>" sets the serial port to baud rate 57600 bps and 1 stop bit.</lf></cr>                                                |

## 24.6.1.3 Echo <setting>

#### Table 308. UART ISP Echo command

| Command     | A                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Input       | Setting: ON = 1   OFF = 0                                                                                                    |
| Return Code | CMD_SUCCESS                                                                                                                  |
|             | PARAM_ERROR                                                                                                                  |
| Description | The default setting for echo command is ON. When ON the ISP command handler sends the received serial data back to the host. |
| Example     | "A 0 <cr><lf>" turns echo off.</lf></cr>                                                                                     |

## 24.6.1.4 Write to RAM <start address> <number of bytes>

The host should send the plain binary code after receiving the CMD\_SUCCESS return code. This ISP command handler responds with "OK<CR><LF>" when the transfer has finished.

| Command     | W                                                                                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | <b>Start Address:</b> RAM address where data bytes are to be written. This address should be a word boundary.                                                                           |
|             | Number of Bytes: Number of bytes to be written. Count should be a multiple of 4                                                                                                         |
| Return Code | CMD_SUCCESS                                                                                                                                                                             |
|             | ADDR_ERROR (Address not on word boundary)                                                                                                                                               |
|             | ADDR_NOT_MAPPED                                                                                                                                                                         |
|             | COUNT_ERROR (Byte count is not multiple of 4)                                                                                                                                           |
|             | PARAM_ERROR                                                                                                                                                                             |
|             | CODE_READ_PROTECTION_ENABLED                                                                                                                                                            |
| Description | This command is used to download data to RAM. This command is blocked when code read protection levels 2 or 3 are enabled. Writing to addresses below 0x1000 0300 is disabled for CRP1. |
| Example     | "W 268436224 4 <cr><lf>" writes 4 bytes of data to address 0x1000 0300.</lf></cr>                                                                                                       |

#### Table 309. UART ISP Write to RAM command

## 24.6.1.5 Read Memory <address> <number of bytes>

Reads the plain binary code of the data stream, followed by the CMD\_SUCCESS return code.

| Command     | R                                                                                                                         |
|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Input       | <b>Start Address:</b> Address from where data bytes are to be read. This address should be a word boundary.               |
|             | Number of Bytes: Number of bytes to be read. Count should be a multiple of 4.                                             |
| Return Code | CMD_SUCCESS followed by <actual (plain="" binary)="" data="">  </actual>                                                  |
|             | ADDR_ERROR (Address not on word boundary)                                                                                 |
|             | ADDR_NOT_MAPPED                                                                                                           |
|             | COUNT_ERROR (Byte count is not a multiple of 4)                                                                           |
|             | PARAM_ERROR                                                                                                               |
|             | CODE_READ_PROTECTION_ENABLED                                                                                              |
| Description | This command is used to read data from RAM or flash memory. This command is blocked when code read protection is enabled. |
| Example     | "R 268435456 4 <cr><lf>" reads 4 bytes of data from address 0x1000 0000.</lf></cr>                                        |

#### Table 310. UART ISP Read Memory command

# 24.6.1.6 Prepare sector(s) for write operation <start sector number> <end sector number>

This command makes flash write/erase operation a two step process.

| Command     | Ρ                                                                                                                                                                                                                                                                                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Start Sector Number                                                                                                                                                                                                                                                                                                                                        |
|             | End Sector Number: Should be greater than or equal to start sector number.                                                                                                                                                                                                                                                                                 |
| Return Code | CMD_SUCCESS                                                                                                                                                                                                                                                                                                                                                |
|             | BUSY                                                                                                                                                                                                                                                                                                                                                       |
|             | INVALID_SECTOR                                                                                                                                                                                                                                                                                                                                             |
|             | PARAM_ERROR                                                                                                                                                                                                                                                                                                                                                |
| Description | This command must be executed before executing "Copy RAM to flash" or "Erase Sector(s)" command. Successful execution of the "Copy RAM to flash" or "Erase Sector(s)" command causes relevant sectors to be protected again. The boot block can not be prepared by this command. To prepare a single sector use the same "Start" and "End" sector numbers. |
| Example     | "P 0 0 <cr><lf>" prepares the flash sector 0.</lf></cr>                                                                                                                                                                                                                                                                                                    |

#### Table 311. UART ISP Prepare sector(s) for write operation command

### 24.6.1.7 Copy RAM to flash <Flash address> <RAM address> <no of bytes>

When writing to the flash, the following limitations apply:

- 1. The smallest amount of data that can be written to flash by the copy RAM to flash command is 64 byte (equal to one page).
- One page consists of 16 flash words (lines), and the smallest amount that can be modified per flash write is one flash word (one line). This limitation follows from the application of ECC to the flash write operation, see Section 24.5.2.
- 3. To avoid write disturbance (a mechanism intrinsic to flash memories), an erase should be performed after following 16 consecutive writes inside the same page. Note that the erase operation then erases the entire sector.

**Remark:** Once a page has been written to 16 times, it is still possible to write to other pages within the same sector without performing a sector erase (assuming that those pages have been erased previously).

UM11021

| Command     | c                                                                                                                                                                                                                                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Flash Address (DST): Destination flash address where data bytes are to be written. The destination address should be a 64 byte boundary.                                                                                                                                                                                                                  |
|             | RAM Address (SRC): Source RAM address from where data bytes are to be read                                                                                                                                                                                                                                                                                |
|             | Number of Bytes: Number of bytes to be written. Should be 64   128   256   512   1024.                                                                                                                                                                                                                                                                    |
| Return Code | CMD_SUCCESS                                                                                                                                                                                                                                                                                                                                               |
|             | SRC_ADDR_ERROR (Address not on word boundary)                                                                                                                                                                                                                                                                                                             |
|             | DST_ADDR_ERROR (Address not on correct boundary)                                                                                                                                                                                                                                                                                                          |
|             | SRC_ADDR_NOT_MAPPED                                                                                                                                                                                                                                                                                                                                       |
|             | DST_ADDR_NOT_MAPPED                                                                                                                                                                                                                                                                                                                                       |
|             | COUNT_ERROR (Byte count is not 64   128   256   512   1024)                                                                                                                                                                                                                                                                                               |
|             | SECTOR_NOT_PREPARED_FOR WRITE_OPERATION                                                                                                                                                                                                                                                                                                                   |
|             | BUSY                                                                                                                                                                                                                                                                                                                                                      |
|             | CMD_LOCKED                                                                                                                                                                                                                                                                                                                                                |
|             | PARAM_ERROR                                                                                                                                                                                                                                                                                                                                               |
|             | CODE_READ_PROTECTION_ENABLED                                                                                                                                                                                                                                                                                                                              |
| Description | This command is used to program the flash memory. The "Prepare Sector(s) for Write Operation" command should precede this command. The affected sectors are automatically protected again once the copy command is successfully executed. The boot block cannot be written by this command. This command is blocked when code read protection is enabled. |
| Example     | "C 0 268437504 512 <cr><lf>" copies 512 bytes from the RAM address 0x1000 0800 to the flash address 0.</lf></cr>                                                                                                                                                                                                                                          |

### Table 312. UART ISP Copy RAM to flash command

### 24.6.1.8 Go <address> <mode>

#### Table 313. UART ISP Go command

| Command     | G                                                                                                                                                                                                                                                                                                                    |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | <b>Address:</b> Flash or RAM address from which the code execution is to be started.<br>This address should be on a word boundary.                                                                                                                                                                                   |
|             | Mode: T (Execute program in Thumb Mode).                                                                                                                                                                                                                                                                             |
| Return Code | CMD_SUCCESS                                                                                                                                                                                                                                                                                                          |
|             | ADDR_ERROR                                                                                                                                                                                                                                                                                                           |
|             | ADDR_NOT_MAPPED                                                                                                                                                                                                                                                                                                      |
|             | CMD_LOCKED                                                                                                                                                                                                                                                                                                           |
|             | PARAM_ERROR                                                                                                                                                                                                                                                                                                          |
|             | CODE_READ_PROTECTION_ENABLED                                                                                                                                                                                                                                                                                         |
| Description | This command is used to execute a program residing in RAM or flash memory. It may not be possible to return to the ISP command handler once this command is successfully executed. This command is blocked when code read protection is enabled. The command must be used with an address of 0x0000 0200 or greater. |
| Example     | "G 512 T <cr><lf>" branches to address 0x0000 0200 in Thumb mode.</lf></cr>                                                                                                                                                                                                                                          |

The GO command is usually used after the flash image has been updated and a RESET is desired. For this, the GO command should point to the RESET handler. Since the device is still in ISP, the RESET handler should do the following:

UM11021

- Re-initialize the SP pointer to the application default
- Set the SYSMEMREMAP to either 0x01 or 0x02

While in the ISP mode, the SYSMEMREMAP is set to 0x00.

Alternatively, the following snippet can be loaded into the RAM for execution:

| SCB->AIRCR = 0x05FA0004; | //issue system reset     |
|--------------------------|--------------------------|
| <pre>while(1);</pre>     | //should never come here |

The snippet will issue a system reset request to the core.

## 24.6.1.9 Erase sector(s) <start sector number> <end sector number>

| Command     | E                                                                                                                                                                                                                                |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Start Sector Number                                                                                                                                                                                                              |
|             | End Sector Number: Should be greater than or equal to start sector number.                                                                                                                                                       |
| Return Code | CMD_SUCCESS                                                                                                                                                                                                                      |
|             | BUSY                                                                                                                                                                                                                             |
|             | INVALID_SECTOR                                                                                                                                                                                                                   |
|             | SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION                                                                                                                                                                                          |
|             | CMD_LOCKED                                                                                                                                                                                                                       |
|             | PARAM_ERROR                                                                                                                                                                                                                      |
|             | CODE_READ_PROTECTION_ENABLED                                                                                                                                                                                                     |
| Description | This command is used to erase one or more sector(s) of on-chip flash memory. The boot block can not be erased using this command. This command only allows erasure of all user sectors when the code read protection is enabled. |
| Example     | "E 2 3 <cr><lf>" erases the flash sectors 2 and 3.</lf></cr>                                                                                                                                                                     |

#### Table 314. UART ISP Erase sector command

## 24.6.1.10 Blank check sector(s) <sector number> <end sector number>

#### Table 315. UART ISP Blank check sector command

| Command     |                                                                                                                                                                                       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Start Sector Number:                                                                                                                                                                  |
|             | End Sector Number: Should be greater than or equal to start sector number.                                                                                                            |
| Return Code | CMD_SUCCESS                                                                                                                                                                           |
|             | SECTOR_NOT_BLANK (followed by <offset blank="" first="" location="" non="" of="" the="" word=""> <contents blank="" location="" non="" of="" word="">)  </contents></offset>          |
|             | INVALID_SECTOR                                                                                                                                                                        |
|             | PARAM_ERROR                                                                                                                                                                           |
| Description | This command is used to blank check one or more sectors of on-chip flash memory.                                                                                                      |
|             | Blank check on sector 0 always fails as first 64 bytes are re-mapped to flash boot block.                                                                                             |
|             | When CRP is enabled, the blank check command returns 0 for the offset and value of sectors which are not blank. Blank sectors are correctly reported irrespective of the CRP setting. |
| Example     | "I 2 3 <cr><lf>" blank checks the flash sectors 2 and 3.</lf></cr>                                                                                                                    |

## 24.6.1.11 Read Part Identification number

#### Table 316. UART ISP Read Part Identification command

| Command     | J                                                                            |
|-------------|------------------------------------------------------------------------------|
| Input       | None.                                                                        |
| Return Code | CMD_SUCCESS followed by part identification number in ASCII (see Table 317). |
| Description | This command is used to read the part identification number.                 |

#### Table 317. Part identification numbers

| Device          | Hex coding  |
|-----------------|-------------|
| LPC8341201FHI33 | 0x0000 8341 |
| LPC832M101FDH20 | 0x0000 8322 |

## 24.6.1.12 Read Boot code version number

## Table 318. UART ISP Read Boot Code version number command

| Command     | К                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | None                                                                                                                                                                    |
|             | CMD_SUCCESS followed by 2 bytes of boot code version number in ASCII format.<br>It is to be interpreted as <byte1(major)>.<byte0(minor)>.</byte0(minor)></byte1(major)> |
| Description | This command is used to read the boot code version number.                                                                                                              |

## 24.6.1.13 Compare <address1> <address2> <no of bytes>

#### Table 319. UART ISP Compare command

| Command     | M                                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Address1 (DST): Starting flash or RAM address of data bytes to be compared.<br>This address should be a word boundary.                  |
|             | Address2 (SRC): Starting flash or RAM address of data bytes to be compared.<br>This address should be a word boundary.                  |
|             | Number of Bytes: Number of bytes to be compared; should be a multiple of 4.                                                             |
| Return Code | CMD_SUCCESS   (Source and destination data are equal)                                                                                   |
|             | COMPARE_ERROR   (Followed by the offset of first mismatch)                                                                              |
|             | COUNT_ERROR (Byte count is not a multiple of 4)                                                                                         |
|             | ADDR_ERROR                                                                                                                              |
|             | ADDR_NOT_MAPPED                                                                                                                         |
|             | PARAM_ERROR                                                                                                                             |
| Description | This command is used to compare the memory contents at two locations.                                                                   |
| Example     | "M 8192 268468224 4 <cr><lf>" compares 4 bytes from the RAM address 0x1000 8000 to the 4 bytes from the flash address 0x2000.</lf></cr> |

## 24.6.1.14 ReadUID

#### Table 320. UART ISP ReadUID command

| Command     | Ν                                                                                                                                        |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | None                                                                                                                                     |
|             | CMD_SUCCESS followed by four 32-bit words of E-sort test information in ASCII format. The word sent at the lowest address is sent first. |
| Description | This command is used to read the unique ID.                                                                                              |

## 24.6.1.15 Read CRC checksum <address> <no of bytes>

Get the CRC checksum of a block of RAM or flash. CMD\_SUCCESS followed by 8 bytes of CRC checksum in ASCII format.

The checksum is calculated as follows:

CRC-32 polynomial: x32 + x26 + x23 + x22 + x16 + x12 + x11 + x10 + x8 + x7 + x5 + x4 + x2 + x + 1

Seed Value: 0xFFFF FFFF

No bit order reverse for data input

No 1's complement for data input

No bit order reverse for CRC sum

No 1's complement for CRC sum

### Table 321. UART ISP Read CRC checksum command

| Command     | S                                                                                                                                              |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Address: The data are read from this address for CRC checksum calculation. This address must be on a word boundary.                            |
|             | <b>Number of Bytes:</b> Number of bytes to be calculated for the CRC checksum; must be a multiple of 4.                                        |
| Return Code | CMD_SUCCESS followed by data in plain binary format                                                                                            |
|             | ADDR_ERROR (address not on word boundary)                                                                                                      |
|             | ADDR_NOT_MAPPED                                                                                                                                |
|             | COUNT_ERROR (byte count is not a multiple of 4)                                                                                                |
|             | PARAM_ERROR                                                                                                                                    |
|             | CODE_READ_PROTECTION_ENABLED                                                                                                                   |
| Description | This command is used to read the CRC checksum of a block of RAM or flash memory. This command is blocked when code read protection is enabled. |
| Example     | "S 268436736 4 <cr><lf>" reads the CRC checksum for 4 bytes of data from address 0x1000 0500.</lf></cr>                                        |
|             | If checksum value is 0xCBF43926, then the host will receive:                                                                                   |
|             | "3421780262 <cr><lf>"</lf></cr>                                                                                                                |

## 24.6.1.16 UART ISP Return Codes

#### Table 322. UART ISP Return Codes Summary

| Return<br>Code | Mnemonic                                    | Description                                                                                                                              |
|----------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 0              | CMD_SUCCESS                                 | Command is executed successfully. Sent by ISP handler only when command given by the host has been completely and successfully executed. |
| 1              | INVALID_COMMAND                             | Invalid command.                                                                                                                         |
| 2              | SRC_ADDR_ERROR                              | Source address is not on word boundary.                                                                                                  |
| 3              | DST_ADDR_ERROR                              | Destination address is not on a correct boundary.                                                                                        |
| 4              | SRC_ADDR_NOT_MAPPED                         | Source address is not mapped in the memory map.<br>Count value is taken in to consideration where<br>applicable.                         |
| 5              | DST_ADDR_NOT_MAPPED                         | Destination address is not mapped in the memory<br>map. Count value is taken in to consideration<br>where applicable.                    |
| 6              | COUNT_ERROR                                 | Byte count is not multiple of 4 or is not a permitted value.                                                                             |
| 7              | INVALID_SECTOR                              | Sector number is invalid or end sector number is greater than start sector number.                                                       |
| 8              | SECTOR_NOT_BLANK                            | Sector is not blank.                                                                                                                     |
| 9              | SECTOR_NOT_PREPARED_FOR_<br>WRITE_OPERATION | Command to prepare sector for write operation was not executed.                                                                          |
| 10             | COMPARE_ERROR                               | Source and destination data not equal.                                                                                                   |
| 11             | BUSY                                        | Flash programming hardware interface is busy.                                                                                            |
| 12             | PARAM_ERROR                                 | Insufficient number of parameters or invalid parameter.                                                                                  |
| 13             | ADDR_ERROR                                  | Address is not on word boundary.                                                                                                         |
| 14             | ADDR_NOT_MAPPED                             | Address is not mapped in the memory map. Count value is taken in to consideration where applicable.                                      |
| 15             | CMD_LOCKED                                  | Command is locked.                                                                                                                       |
| 16             | INVALID_CODE                                | Unlock code is invalid.                                                                                                                  |
| 17             | INVALID_BAUD_RATE                           | Invalid baud rate setting.                                                                                                               |
| 18             | INVALID_STOP_BIT                            | Invalid stop bit setting.                                                                                                                |
| 19             | CODE_READ_PROTECTION_<br>ENABLED            | Code read protection enabled.                                                                                                            |

## 24.6.2 IAP commands

For in-application programming the IAP routine should be called with a 32-bit pointer in register r0 pointing to memory (RAM) containing the command code and parameters. Results of the IAP command are returned in the result table pointed-to by register r1. The user can reuse the command table for results by passing the same pointer in both registers, r0 and r1. The parameter table is large enough to hold all the results in case the number of results are more than the number of parameters. Parameter passing is illustrated in Figure 54. The number of parameters and results vary according to the IAP command. The maximum number of parameters is four, passed to the "Copy RAM to FLASH" command (IAP\_CMD\_CODE and four parameters for a total of five items in the

command\_param array). The maximum number of results is four, returned by the "ReadUID" command (IAP\_STAT\_CODE and four parameters for a total of five items in the status\_result array). The command handler returns the status code INVALID\_COMMAND when an undefined command is received. The IAP routine resides at 0x1FFF 1FF0 location and is thumb code.

To call an IAP function, do the following:

Define the IAP location entry point. The 0th bit of the IAP location is set to change to the Thumb instruction set when the program counter branches to this address.

```
#define IAP_LOCATION 0x1ff1ff1
```

Define an array or data structure to pass IAP command table and result table to the IAP function:

```
#define IAP_PARAM_CT [5]
#define IAP_CMD_CODE [0]
#define IAP_PARAM_0 [1]
#define IAP_PARAM_1 [2]
#define IAP_PARAM_2 [3]
#define IAP_PARAM_2 [3]
#define IAP_PARAM_3 [4]
uint32_t command_param[IAP_PARAM_CT];
#define IAP_RESULT_CT [5]
#define IAP_RESULT_CT [5]
#define IAP_RESULT_0 [1]
#define IAP_RESULT_0 [1]
#define IAP_RESULT_1 [2]
#define IAP_RESULT_2 [3]
#define IAP_RESULT_3 [4]
uint32_t status_result[IAP_PARAM_CT];
```

Create a typedef that defines a function pointer, which takes two uint32\_t[] parameters and returns void.

```
typedef void (*IAP)(uint32_t iap_cmd[], uint32_t iap_res[]);
IAP iap_entry;
```

Setting the function pointer:

```
iap_entry=(IAP) IAP_LOCATION;
```

To call the IAP, use the following statement.

iap\_entry (command\_param,status\_result);

The flash memory is not accessible during a write or erase operation. IAP commands, which result in a flash write/erase operation, use the top 32 bytes of the on-chip RAM for IAP command execution. The user should not use this space if IAP flash programming is used in the application.

#### Table 323. IAP Command Summary

| IAP Command                           | Command Code | Described in |
|---------------------------------------|--------------|--------------|
| Prepare sector(s) for write operation | 50 (decimal) | Table 324    |
| Copy RAM to flash                     | 51 (decimal) | Table 325    |
| Erase sector(s)                       | 52 (decimal) | Table 326    |
| Blank check sector(s)                 | 53 (decimal) | Table 327    |
| Read Part ID                          | 54 (decimal) | Table 328    |
| Read Boot code version                | 55 (decimal) | Table 329    |
| Compare                               | 56 (decimal) | Table 330    |
| Reinvoke ISP                          | 57 (decimal) | Table 331    |
| Read UID                              | 58 (decimal) | Table 332    |
| Erase page                            | 59 (decimal) | Table 333    |



## 24.6.2.1 Prepare sector(s) for write operation (IAP)

This command makes flash write/erase operation a two step process.

| Command     | Prepare sector(s) for write operation                                                                                                                                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 50 (decimal)                                                                                                                                                                                                                                                                                                                                  |
|             | Param0: Start Sector Number                                                                                                                                                                                                                                                                                                                                 |
|             | <b>Param1:</b> End Sector Number (should be greater than or equal to start sector number).                                                                                                                                                                                                                                                                  |
| Status code | CMD_SUCCESS                                                                                                                                                                                                                                                                                                                                                 |
|             | BUSY                                                                                                                                                                                                                                                                                                                                                        |
|             | INVALID_SECTOR                                                                                                                                                                                                                                                                                                                                              |
| Result      | None                                                                                                                                                                                                                                                                                                                                                        |
| Description | This command must be executed before executing "Copy RAM to flash" or "Erase Sector(s)" command. Successful execution of the "Copy RAM to flash" or "Erase Sector(s)" command causes relevant sectors to be protected again. The boot sector can not be prepared by this command. To prepare a single sector use the same "Start" and "End" sector numbers. |

## Table 324. IAP Prepare sector(s) for write operation command

## 24.6.2.2 Copy RAM to flash (IAP)

See <u>Section 24.6.1.4</u> for limitations on the write-to-flash process.

| Command     | Copy RAM to flash                                                                                                                                                                                                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 51 (decimal)                                                                                                                                                                                                                                                                                                   |
|             | <b>Param0(DST):</b> Destination flash address where data bytes are to be written. This address should be a 64 byte boundary.                                                                                                                                                                                                 |
|             | <b>Param1(SRC):</b> Source RAM address from which data bytes are to be read. This address should be a word boundary.                                                                                                                                                                                                         |
|             | Param2: Number of bytes to be written. Should be 64   128   256   512   1024.                                                                                                                                                                                                                                                |
|             | Param3: NULL                                                                                                                                                                                                                                                                                                                 |
| Status code | CMD_SUCCESS                                                                                                                                                                                                                                                                                                                  |
|             | SRC_ADDR_ERROR (Address not a word boundary)                                                                                                                                                                                                                                                                                 |
|             | DST_ADDR_ERROR (Address not on correct boundary)                                                                                                                                                                                                                                                                             |
|             | SRC_ADDR_NOT_MAPPED                                                                                                                                                                                                                                                                                                          |
|             | DST_ADDR_NOT_MAPPED                                                                                                                                                                                                                                                                                                          |
|             | COUNT_ERROR (Byte count is not 256   512   1024   4096)                                                                                                                                                                                                                                                                      |
|             | SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION                                                                                                                                                                                                                                                                                      |
|             | BUSY                                                                                                                                                                                                                                                                                                                         |
| Result      | None                                                                                                                                                                                                                                                                                                                         |
| Description | This command is used to program the flash memory. The affected sectors should<br>be prepared first by calling "Prepare Sector for Write Operation" command. The<br>affected sectors are automatically protected again once the copy command is<br>successfully executed. The boot sector can not be written by this command. |
|             | Param3 is overwritten by the fixed value of 12 MHz, which is the IRC reference clock used by the flash controller.                                                                                                                                                                                                           |

Table 325. IAP Copy RAM to flash command

## 24.6.2.3 Erase Sector(s) (IAP)

#### Table 326. IAP Erase Sector(s) command

| Command     | Erase Sector(s)                                                                                                                                                                                                |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 52 (decimal)                                                                                                                                                                                     |
|             | Param0: Start Sector Number                                                                                                                                                                                    |
|             | <b>Param1:</b> End Sector Number (should be greater than or equal to start sector number).                                                                                                                     |
|             | Param2: NULL                                                                                                                                                                                                   |
| Status code | CMD_SUCCESS                                                                                                                                                                                                    |
|             | BUSY                                                                                                                                                                                                           |
|             | SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION                                                                                                                                                                        |
|             | INVALID_SECTOR                                                                                                                                                                                                 |
| Result      | None                                                                                                                                                                                                           |
| Description | This command is used to erase a sector or multiple sectors of on-chip flash memory. The boot sector can not be erased by this command. To erase a single sector use the same "Start" and "End" sector numbers. |
|             | Param2 is overwritten by the fixed value of 12 MHz, which is the IRC reference clock used by the flash controller.                                                                                             |

## 24.6.2.4 Blank check sector(s) (IAP)

#### Table 327. IAP Blank check sector(s) command

| Command     | Blank check sector(s)                                                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 53 (decimal)                                                                                                                                              |
|             | Param0: Start Sector Number                                                                                                                                             |
|             | <b>Param1:</b> End Sector Number (should be greater than or equal to start sector number).                                                                              |
| Status code | CMD_SUCCESS                                                                                                                                                             |
|             | BUSY                                                                                                                                                                    |
|             | SECTOR_NOT_BLANK                                                                                                                                                        |
|             | INVALID_SECTOR                                                                                                                                                          |
| Result      | <b>Result0:</b> Offset of the first non blank word location if the Status Code is SECTOR_NOT_BLANK.                                                                     |
|             | Result1: Contents of non blank word location.                                                                                                                           |
| Description | This command is used to blank check a sector or multiple sectors of on-chip flash memory. To blank check a single sector use the same "Start" and "End" sector numbers. |

## 24.6.2.5 Read Part Identification number (IAP)

#### Table 328. IAP Read Part Identification command

| Command     | Read part identification number                              |
|-------------|--------------------------------------------------------------|
| Input       | Command code: 54 (decimal)                                   |
|             | Parameters: None                                             |
| Status code | CMD_SUCCESS                                                  |
| Result      | Result0: Part Identification Number.                         |
| Description | This command is used to read the part identification number. |

## 24.6.2.6 Read Boot code version number (IAP)

#### Table 329. IAP Read Boot Code version number command

| Command     | Read boot code version number                                                                |
|-------------|----------------------------------------------------------------------------------------------|
| Input       | Command code: 55 (decimal)                                                                   |
|             | Parameters: None                                                                             |
| Status code | CMD_SUCCESS                                                                                  |
| Result      | Result0: 2 bytes of boot code version number. Read as<br><br>byte1(Major)>.<br>byte0(Minor)> |
| Description | This command is used to read the boot code version number.                                   |

## 24.6.2.7 Compare <address1> <address2> <no of bytes> (IAP)

## Table 330. IAP Compare command

| Command     | Compare                                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 56 (decimal)                                                                                              |
|             | <b>Param0(DST):</b> Starting flash or RAM address of data bytes to be compared. This address should be a word boundary. |
|             | <b>Param1(SRC):</b> Starting flash or RAM address of data bytes to be compared. This address should be a word boundary. |
|             | Param2: Number of bytes to be compared; should be a multiple of 4.                                                      |
| Status code | CMD_SUCCESS                                                                                                             |
|             | COMPARE_ERROR                                                                                                           |
|             | COUNT_ERROR (Byte count is not a multiple of 4)                                                                         |
|             | ADDR_ERROR                                                                                                              |
|             | ADDR_NOT_MAPPED                                                                                                         |
| Result      | <b>Result0:</b> Offset of the first mismatch if the Status Code is COMPARE_ERROR.                                       |
| Description | This command is used to compare the memory contents at two locations.                                                   |

## 24.6.2.8 Reinvoke ISP (IAP)

#### Table 331. IAP Reinvoke ISP

| Command                          | Compare                                                                                                                                                                                                                                                                                                    |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Command code: 57 (decimal) |                                                                                                                                                                                                                                                                                                            |
| Status code                      | None                                                                                                                                                                                                                                                                                                       |
| Result                           | None.                                                                                                                                                                                                                                                                                                      |
| Description                      | This command is used to invoke the bootloader in ISP mode. It maps boot vectors, sets PCLK = CCLK, and configures USART0 pins U0_RXD and U0_TXD. This command may be used when a valid user program is present in the internal flash memory and the ISP entry pin is not accessible to force the ISP mode. |

## 24.6.2.9 ReadUID (IAP)

#### Table 332. IAP ReadUID command

| Command     | Compare                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 58 (decimal)                                                                                                                                         |
| Status code | CMD_SUCCESS                                                                                                                                                        |
| Result      | Result0: The first 32-bit word (at the lowest address).<br>Result1: The second 32-bit word.<br>Result2: The third 32-bit word.<br>Result3: The fourth 32-bit word. |
| Description | This command is used to read the unique ID.                                                                                                                        |

## 24.6.2.10 Erase page

#### Table 333. IAP Erase page command

| Command     | Erase page                                                                                                         |
|-------------|--------------------------------------------------------------------------------------------------------------------|
| Input       | Command code: 59 (decimal)                                                                                         |
|             | Param0: Start page number.                                                                                         |
|             | Param1: End page number (should be greater than or equal to start page).                                           |
|             | Param2: NULL                                                                                                       |
| Status code | CMD_SUCCESS                                                                                                        |
|             | BUSY                                                                                                               |
|             | SECTOR_NOT_PREPARED_FOR_WRITE_OPERATION                                                                            |
|             | INVALID_SECTOR                                                                                                     |
| Result      | None                                                                                                               |
| Description | This command is used to erase a page or multiple pages of on-chip flash memory.                                    |
|             | To erase a single page use the same "start" and "end" page numbers.                                                |
|             | Param2 is overwritten by the fixed value of 12 MHz, which is the IRC reference clock used by the flash controller. |

User manual

## 24.6.2.11 IAP Status codes

#### Table 334. IAP Status codes Summary

| Status<br>Code | Mnemonic                                    | Description                                                                                                           |
|----------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| 0              | CMD_SUCCESS                                 | Command is executed successfully.                                                                                     |
| 1              | INVALID_COMMAND                             | Invalid command.                                                                                                      |
| 2              | SRC_ADDR_ERROR                              | Source address is not on a word boundary.                                                                             |
| 3              | DST_ADDR_ERROR                              | Destination address is not on a correct boundary.                                                                     |
| 4              | SRC_ADDR_NOT_MAPPED                         | Source address is not mapped in the memory map.<br>Count value is taken in to consideration where<br>applicable.      |
| 5              | DST_ADDR_NOT_MAPPED                         | Destination address is not mapped in the memory<br>map. Count value is taken in to consideration where<br>applicable. |
| 6              | COUNT_ERROR                                 | Byte count is not multiple of 4 or is not a permitted value.                                                          |
| 7              | INVALID_SECTOR                              | Sector number is invalid.                                                                                             |
| 8              | SECTOR_NOT_BLANK                            | Sector is not blank.                                                                                                  |
| 9              | SECTOR_NOT_PREPARED_<br>FOR_WRITE_OPERATION | Command to prepare sector for write operation was not executed.                                                       |
| 10             | COMPARE_ERROR                               | Source and destination data is not same.                                                                              |
| 11             | BUSY                                        | Flash programming hardware interface is busy.                                                                         |
| 17             | ERR_ISP_IRC_NO_POWER                        | IRC is turned off. The IRC must be running to use the IAP calls.                                                      |
| 18             | ERR_ISP_FLASH_NO_POWER                      | -                                                                                                                     |
| 1B             | ERR_ISP_FLASH_NO_CLOCK                      | -                                                                                                                     |

## 24.7 Functional description

## 24.7.1 UART Communication protocol

All UART ISP commands should be sent as single ASCII strings. Strings should be terminated with Carriage Return (CR) and/or Line Feed (LF) control characters. Extra <CR> and <LF> characters are ignored. All ISP responses are sent as <CR><LF> terminated ASCII strings. Data is sent and received in plain binary format.

## 24.7.1.1 UART ISP command format

"Command Parameter\_0 Parameter\_1 ... Parameter\_n<CR><LF>" "Data" (Data only for Write commands).

## 24.7.1.2 UART ISP response format

"Return\_Code<CR><LF>Response\_0<CR><LF>Response\_1<CR><LF> ... Response\_n<CR><LF>" "Data" (Data only for Read commands).

## 24.7.1.3 UART ISP data format

The data stream is in plain binary format.

## 24.7.2 Memory and interrupt use for ISP and IAP

## 24.7.2.1 Interrupts during UART ISP

The boot block interrupt vectors located in the boot block of the flash are active after any reset.

### 24.7.2.2 Interrupts during IAP

The on-chip flash memory is not accessible during erase/write operations. When the user application code starts executing the interrupt vectors from the user flash area are active. Before making any IAP call, either disable the interrupts or ensure that the user interrupt vectors are active in RAM and that the interrupt handlers reside in RAM. The IAP code does not use or disable interrupts.

#### 24.7.2.3 RAM used by ISP command handler

The stack of ISP commands is located at 0x1000 0270. The maximum stack usage is 540 byte and grows downwards.

#### 24.7.2.4 RAM used by IAP command handler

The maximum stack usage in the user allocated stack space is 148 bytes and grows downwards.

## 24.7.3 Debugging

#### 24.7.3.1 Comparing flash images

Depending on the debugger used and the IDE debug settings, the memory that is visible when the debugger connects might be the boot ROM, the internal SRAM, or the flash. To help determine which memory is present in the current debug environment, check the value contained at flash address 0x0000 0004. This address contains the entry point to the code in the ARM Cortex-M0+ vector table, which is the bottom of the boot ROM, the internal SRAM, or the flash memory respectively.

#### Table 335. Memory mapping in debug mode

| Memory mapping mode | Memory start address visible at 0x0000 0004 |
|---------------------|---------------------------------------------|
| Bootloader mode     | 0x1FFF 0000                                 |
| User flash mode     | 0x0000 0000                                 |
| User SRAM mode      | 0x1000 0000                                 |

#### 24.7.3.2 Serial Wire Debug (SWD) flash programming interface

Debug tools can write parts of the flash image to RAM and then execute the IAP call "Copy RAM to flash" repeatedly with proper offset.

**User manual** 

# **UM11021**

Chapter 25: LPC83x Serial Wire Debug (SWD)

Rev. 1.1 — 5 October 2016

**User manual** 

# 25.1 How to read this chapter

The debug functionality is identical for all LPC83x parts.

# 25.2 Features

- Supports ARM Serial Wire Debug mode.
- Direct debug access to all memories, registers, and peripherals.
- No target resources are required for the debugging session.
- Four breakpoints.
- Two data watchpoints that can also be used as triggers.
- Supports JTAG boundary scan.
- Micro Trace Buffer (MTB) supported.

# **25.3 General description**

Debug functions are integrated into the ARM Cortex-M0+. Serial wire debug functions are supported. The ARM Cortex-M0+ is configured to support up to four breakpoints and two watchpoints.

Support for boundary scan and Micro Trace Buffer is available. In order to use the micro-trace buffer for debugging, enable the MTB clock in the SYSAHBCLKCTRL register (Table 33).

Only RAM0 can be used as trace buffer by MTB, that means the maximum trace buffer size is 4 KB.

# 25.4 Pin description

The SWD functions are assigned to pins through the switch matrix. The SWD functions are fixed-pin functions that are enabled through the switch matrix and can only be assigned to special pins on the package. The SWD functions are enabled by default.

| Function | Туре | Pin                   | Description                                                                                                                                                               | SWM register | Reference |
|----------|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------|
| SWCLK    | I/O  | SWCLK/PIO0_3/<br>TCLK | Serial Wire <b>Clock.</b> This pin is the clock for SWD debug logic when in the Serial Wire Debug mode (SWD). This pin is pulled up internally.                           | PINENABLE0   | Table 76  |
| SWDIO    | I/O  | SWDIO/PIO0_2/<br>TMS  | <b>Serial wire debug data input/output.</b> The SWDIO pin is used by an external debug tool to communicate with and control the LPC800. This pin is pulled up internally. | PINENABLE0   | Table 76  |

Table 336. SWD pin description

The boundary scan mode and the pins needed are selected by hardware (see <u>Section 25.5.3</u>). There is no access to the boundary scan pins through the switch matrix.

**User manual** 

# Chapter 25: LPC83x Serial Wire Debug (SWD)

| Function | Pin name           | Туре | Description                                                                                                                                                                                                                              |
|----------|--------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| тск      | SWCLK/PIO0_3/TCK   | I    | <b>JTAG Test Clock.</b> This pin is the clock for JTAG boundary scan when the RESET pin is LOW.                                                                                                                                          |
| TMS      | SWDIO/PIO0_2/TMS   | I    | JTAG <b>Test Mode Select.</b> The TMS pin selects the next state in the TAP state machine. This pin includes an internal pull-up and is used for JTAG boundary scan when the RESET pin is LOW.                                           |
| TDI      | PIO0_1/CLKIN/TDI   | I    | JTAG <b>Test Data In.</b> This is the serial data input for the shift register. This pin includes an internal pull-up and is used for JTAG boundary scan when the RESET pin is LOW.                                                      |
| TDO      | PIO0_0/TDO         | 0    | JTAG <b>Test Data Output.</b> This is the serial data output from the shift register.<br>Data is shifted out of the device on the negative edge of the TCK signal.<br>This pin is used for JTAG boundary scan when the RESET pin is LOW. |
| TRST     | PIO0_4/WAKEUP/TRST | I    | JTAG <b>Test Reset.</b> The TRST pin can be used to reset the test logic within the debug logic. This pin includes an internal pull-up and is used for JTAG boundary scan when the RESET pin is LOW.                                     |

#### Table 337. JTAG boundary scan pin description

## **25.5 Functional description**

## 25.5.1 Debug limitations

It is recommended not to use the debug mode during Deep-sleep or Power-down mode.

During a debugging session, the System Tick Timer is automatically stopped whenever the CPU is stopped. Other peripherals are not affected.

## 25.5.2 Debug connections for SWD

For debugging purposes, it is useful to provide access to the ISP entry pin PIO0\_12. This pin can be used to recover the part from configurations which would disable the SWD port such as improper PLL configuration, re-configuration of SWD pins, entry into Deep power-down mode out of reset, etc. This pin can be used for other functions such as GPIO, but it should not be held LOW on power-up or reset.

## Chapter 25: LPC83x Serial Wire Debug (SWD)

UM11021



## 25.5.3 Boundary scan

The  $\overline{\text{RESET}}$  pin selects between the JTAG boundary scan ( $\overline{\text{RESET}}$  = LOW) and the ARM SWD debug ( $\overline{\text{RESET}}$  = HIGH). The ARM SWD debug port is disabled while the part is in reset.

To perform boundary scan testing, follow these steps:

- 1. Erase any user code residing in flash.
- 2. Power up the part with the RESET pin pulled HIGH externally.
- 3. Wait for at least 250  $\mu$ s.
- 4. Pull the RESET pin LOW externally.
- 5. Perform boundary scan operations.
- 6. Once the boundary scan operations are completed, assert the TRST pin to enable the SWD debug mode and release the RESET pin (pull HIGH).

**Remark:** The JTAG interface cannot be used for debug purposes.

**Remark:** POR, BOD reset, or a LOW on the TRST pin puts the test TAP controller in the Test-Logic Reset state. The first TCK clock while RESET = HIGH places the test TAP in Run-Test Idle mode.

## 25.5.4 Micro Trace Buffer (MTB)

The MTB registers are located at memory address 0x1400 0000 and are described in <u>Ref. 4</u>. The EXTTRACE register in the SYSCON block (see <u>Section 5.6.21</u>) starts and stops tracing in conjunction with the TSTARTEN and TSTOPEN bits in the MTB MASTER register. The trace is stored in the local SRAM starting at address 0x1000 0000. The trace memory location is configured in the MTB POSITION register.

## Chapter 25: LPC83x Serial Wire Debug (SWD)

**Remark:** The MTB BASE register is not implemented. Reading the BASE register returns 0x0 independently of the SRAM memory area configured for trace.

User manual

# **UM11021**

Chapter 26: LPC83x Code examples

Rev. 1.1 — 5 October 2016

**User manual** 

# 26.1 How to read this chapter

This chapter contains code examples to help understand how to use the registers of various peripheral blocks when writing software drivers. For a comprehensive description of each peripheral and register interface, see the respective chapter.

**Remark:** The code listings are for illustrative purposes only and are not intended to be application-ready functions.

# 26.2 Code examples I2C

## 26.2.1 Definitions

#### Table 338. I2C Code example

| I2C defin | nes                            |
|-----------|--------------------------------|
| #define   | I2C_CFG_MSTEN (0x1)            |
| #define   | I2C_CFG_SLVEN (0x2)            |
| #define   | I2C_STAT_MSTPENDING (0x1)      |
| #define   | I2C_STAT_MSTSTATE (0xe)        |
| #define   | I2C_STAT_MSTST_IDLE (0x0)      |
| #define   | I2C_STAT_MSTST_RX (0x2)        |
| #define   | I2C_STAT_MSTST_TX (0x4)        |
| #define   | I2C_STAT_MSTST_NACK_ADDR (0x6) |
| #define   | I2C_STAT_MSTST_NACK_TX (0x8)   |
| #define   | I2C_STAT_SLVPENDING (0x100)    |
| #define   | I2C_STAT_SLVSTATE (0x600)      |
| #define   | I2C_STAT_SLVST_ADDR (0x000)    |
| #define   | I2C_STAT_SLVST_RX (0x200)      |
| #define   | I2C_STAT_SLVST_TX (0x400)      |
| #define   | I2C_MSTCTL_MSTCONTINUE (0x1)   |
| #define   | I2C_MSTCTL_MSTSTART (0x2)      |
| #define   | I2C_MSTCTL_MSTSTOP (0x4)       |
| #define   | I2C_SLVCTL_SLVCONTINUE (0x1)   |
| #define   | I2C_SLVCTL_SLVNACK (0x2)       |

UM11021

## 26.2.2 Interrupt handler

#### Table 339. I2C Code example

```
Interrupt handler
void I2c_IRQHandler() {
uint32_t intstat = LPC_I2C->INTSTAT;
     uint32_t stat = LPC_I2C->STAT;
     if(intstat & I2C_STAT_MSTPENDING) {
           uint32_t mst_state = stat & I2C_STAT_MSTSTATE;
           if(mst state == I2C STAT MSTST IDLE) {
                LPC_I2C->MSTDAT = (0x23 << 1) | 1; // address and 1 for RWn bit in
     order
// to read data
                LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
          if(mst_state == I2C_STAT_MSTST_RX) {
                uint8_t data;
                data = LPC_I2C->MSTDAT; // receive data
                if(data != 0xdd) abort();
                LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 1 for RWn bit in
     order
// to read data
                LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // repeated start (nack
     implied)
          if(mst_state == I2C_STAT_MSTSTX) {
                LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // stop transaction
                LPC_I2C->INTENCLR = I2C_STAT_MSTPENDING;
           }
     }
```

## 26.2.3 Master write one byte to slave

#### Table 340. I2C Code example

```
Master write one byte to slave. Address 0x23, Data 0xdd. Polling mode.

LPC_I2C->CFG = I2C_CFG_MSTEN;

while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));

if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();

LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 0 for RWn bit

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start

while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));

if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->MSTDAT = 0xdd; // send data

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction

while(!(LPC_I2C->STAT & I2C_STAT_MSTFATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction

while(!(LPC_I2C->STAT & I2C_STAT_MSTFATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTATE) != I2C_STAT_MSTSTX) abort();

LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();

if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.4 Master read one byte from slave

#### Table 341. I2C Code example

```
Master read one byte from slave. Address 0x23. Polling mode. No error checking.
```

```
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 1; // address and 1 for RWn bit
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_RX) abort();
data = LPC_I2C->MSTDAT; // read data
if(data != 0xdd) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // send stop
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.5 Master write one byte to subaddress on slave

#### Table 342. I2C Code example

```
Master write one byte to subaddress on slave. Address 0x23, subaddress 0xaa, Data 0xdd.
Polling mode. No error checking.
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC I2C->STAT & I2C STAT MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 0 for RWn bit in order to write
// subaddress
LPC I2C->MSTCTL = I2C MSTCTL MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC_I2C->MSTDAT = 0xaa; // send subaddress
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC I2C->MSTDAT = 0xdd; // send data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // send stop
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.6 Master read one byte from subaddress on slave

#### Table 343. I2C Code example

Master read one byte from subaddress on slave. Address 0x23, subaddress 0xaa. Polling mode. No error checking.

```
LPC I2C->CFG = I2C CFG MSTEN;
while(!(LPC I2C->STAT & I2C STAT MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC I2C->MSTDAT = (0x23 << 1) | 0; // address and 0 for RWn bit in order to write
// subaddress
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC_I2C->MSTDAT = 0xaa; // send subaddress
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction
while(!(LPC I2C->STAT & I2C STAT MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 1; // address and 1 for RWn bit in order to write
// subaddress
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send repeated start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_RX) abort();
data = LPC_I2C->MSTDAT; // read data
if(data != 0xdd) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // send stop
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.7 Master receiving nack on address

#### Table 344. I2C Code example

```
Master receive nack on address. Address 0x23. Polling mode. No error checking.
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 0 for RWn bit
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_NACK_ADDR) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTATE) != I2C_STAT_MSTST_NACK_ADDR) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // stop transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.8 Master receiving nack on data

#### Table 345. I2C Code example

Master receive nack on data. Address 0x23, data 0xdd. Polling mode. No error checking.

```
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 0 for RWn bit in order to write data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTSTX) abort();
LPC_I2C->MSTDAT = 0xdd; // send data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTCONTINUE; // continue transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_NACKX) abort();
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_NACKX) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTATE) != I2C_STAT_MSTST_NACKX) abort();
if((LPC_I2C->STAT & I2C_STAT_MSTSTOP; // stop transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
```

## 26.2.9 Master sending nack and stop on data

#### Table 346. I2C Code example

```
Master sending nack and stop on data. Address 0x23. Polling mode. No error checking.
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 1; // address and 1 for RWn bit in order to read data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_RX) abort();
data = LPC_I2C->MSTDAT; // receive data
if(data != 0xdd) abort();
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // stop transaction (nack implied)
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTPENDING));
```

## 26.2.10 Master sending nack and repeated start on data

### Table 347. I2C Code example

Master sending nack and repeated start on data. Address 0x23. Polling mode. No error checking.

```
LPC_I2C->CFG = I2C_CFG_MSTEN;
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 1; // address and 1 for RWn bit in order to read data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // send start
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_RX) abort();
data = LPC_I2C->MSTDAT; // receive data
if(data != 0xdd) abort();
LPC_I2C->MSTDAT = (0x23 << 1) | 0; // address and 1 for RWn bit in order to read data
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTART; // repeated start (nack implied)
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
LPC_I2C->MSTCTL = I2C_MSTCTL_MSTSTOP; // stop transaction
while(!(LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTPENDING));
if((LPC_I2C->STAT & I2C_STAT_MSTPENDING));
```

## 26.2.11 Master sending nack and repeated start on data. Interrupt mode

#### Table 348. I2C Code example

Master sending nack and repeated start on data. Address 0x23. No error checking. Interrupt mode

```
LPC_I2C->CFG = I2C_CFG_MSTEN;
LPC_I2C->INTENSET = I2C_STAT_MSTPENDING;
NVIC_EnableIRQ(I2c_IRQn);
while(LPC_I2C->INTENSET & I2C_STAT_MSTPENDING);
if((LPC_I2C->STAT & I2C_STAT_MSTSTATE) != I2C_STAT_MSTST_IDLE) abort();
NVIC_DisableIRQ(I2c_IRQn);
```

## 26.2.12 Slave read one byte from master

#### Table 349. I2C Code example

```
Slave read one byte from master. Address 0x23. Polling mode.
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_RX) abort();
data = LPC_I2C->SLVDAT; // read data
if(data != 0xdd) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack data
```

## 26.2.13 Slave write one byte to master

#### Table 350. I2C Code example

```
Slave write one byte to master. Address 0x23, Data 0xdd. Polling mode.
```

```
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVSTX) abort();
LPC_I2C->SLVDAT = 0xdd; // write data
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // continue transaction
```

## 26.2.14 Slave read one byte from master into subaddress

#### Table 351. I2C Code example

| Slave read one byte from master into subaddress. Address 0x23. Polling mode. |
|------------------------------------------------------------------------------|
|                                                                              |

```
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_RX) abort();
subaddress = LPC_I2C->SLVDAT; // read subaddress
if(subaddress != 0xaa) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack data
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack data
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_RX) abort();
data[subaddress] = LPC_I2C->SLVDAT; // read data into subaddress
if(data[subaddress] != 0xdd) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack data
```

## 26.2.15 Slave write one byte to master from subaddress

#### Table 352. I2C Code example

```
Slave write one byte to master from subaddress. Address 0x23. Polling mode.
```

```
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC I2C->STAT & I2C STAT SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_RX) abort();
subaddress = LPC I2C->SLVDAT; // read subaddress
if(subaddress != 0xaa) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // continue transaction
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVSTX) abort();
LPC_I2C->SLVDAT = data[subaddress]; // write data from subaddress
LPC I2C->SLVCTL = I2C SLVCTL SLVCONTINUE; // continue transaction
```

## 26.2.16 Slave nack matched address from master

### Table 353. I2C Code example

```
Slave nack matched address from master. Address 0x23. Polling mode.
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVNACK; // nack address
```

## 26.2.17 Slave nack data from master

#### Table 354. I2C Code example

```
Slave nack data from master. Address 0x23. Polling mode.
```

```
LPC_I2C->SLVADR0 = 0x23 << 1; // put address in address 0 register
LPC_I2C->CFG = I2C_CFG_SLVEN;
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_ADDR) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVCONTINUE; // ack address
while(!(LPC_I2C->STAT & I2C_STAT_SLVPENDING));
if((LPC_I2C->STAT & I2C_STAT_SLVSTATE) != I2C_STAT_SLVST_RX) abort();
data = LPC_I2C->SLVDAT; // read data
if(data != 0xdd) abort();
LPC_I2C->SLVCTL = I2C_SLVCTL_SLVNACK; // nack data
```

# 26.3 Code examples SPI

## 26.3.1 Definitions

#### Table 355. SPI Code example

```
SPI defines
#define SPI_CFG_ENABLE (0x1)
#define SPI_CFG_MASTER (0x4)
#define SPI_STAT_RXRDY (0x1)
#define SPI_STAT_TXRDY (0x2)
#define SPI_STAT_SSD (0x20)
#define SPI_TXDATCTL_SSEL_N(s) ((s) << 16)
#define SPI_TXDATCTL_EOT (1 << 20)
#define SPI_TXDATCTL_EOF (1 << 21)
#define SPI_TXDATCTL_RXIGNORE (1 << 22)
#define SPI_TXDATCTL_FLEN(1) ((1) << 24)</pre>
```

## 26.3.2 Interrupt handler

### Table 356. SPI Code example

```
Interrupt handler
void Spi_IRQHandler() {
     uint16_t data;
     uint32_t intstat = LPC_SPI->INTSTAT;
     if(intstat & SPI_STAT_TXRDY) {
           if(tx_state == 0) {
                LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(15)
     SPI_TXDATCTL_SSEL_N(0xe) | 0xdddd;
                tx_state++;
           }
          if(tx_state == 1) {
                LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_SSEL_N(0xe)
       0xdd;
                LPC_SPI->INTENCLR = SPI_STAT_TXRDY;
     if(intstat & SPI_STAT_RXRDY) {
           if(rx_state == 0) {
                data = LPC_SPI->RXDAT;
                if(data != 0xdddd) abort();
                rx_state++;
           if(rx_state == 1) {
                data = LPC SPI->RXDAT;
                if(data != 0xdd) abort();
                LPC_SPI->INTENCLR = SPI_STAT_RXRDY;
           }
     }
```

## 26.3.3 Transmit one byte to slave 0

#### Table 357. SPI Code example

```
Transmit one byte to slave 0.
```

```
LPC_SPI->CFG = SPI_CFG_MASTER | SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_RXIGNORE | SPI_TXDATCTL_EOT
| SPI_TXDATCTL_SSEL_N(0xe) | 0xdd;
while(~LPC_SPI->STAT & SPI_STAT_MSTIDLE);
```

## 26.3.4 Receive one byte from slave 0

## Table 358. SPI Code example

#### Receive one byte from slave 0.

```
LPC_SPI->CFG = SPI_CFG_MASTER | SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_EOT |
SPI_TXDATCTL_SSEL_N(0xe);
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdd) abort();
while(~LPC_SPI->STAT & SPI_STAT_MSTIDLE);
```

## 26.3.5 Transmit and receive a byte to/from slave 0

#### Table 359. SPI Code example

```
Transmit and receive a byte to/from slave 0.
```

```
LPC_SPI->CFG = SPI_CFG_MASTER | SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_EOT |
SPI_TXDATCTL_SSEL_N(0xe) | 0xdd;
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdd) abort();
while(~LPC_SPI->STAT & SPI_STAT_MSTIDLE);
```

## 26.3.6 Transmit and receive 24 bits to/from slave 0

#### Table 360. SPI Code example

#### Transmit and receive 24 bits to/from slave 0.

```
LPC_SPI->CFG = SPI_CFG_MASTER | SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(15) | SPI_TXDATCTL_SSEL_N(0xe) | 0xdddd;
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdddd) abort();
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_EOT |
SPI_TXDATCTL_SSEL_N(0xe) | 0xdd;
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdd) abort();
while(~LPC_SPI->STAT & SPI_STAT_MSTIDLE);
```

## 26.3.7 Transmit and receive 24 bits to/from slave 0, interrupt mode

## Table 361. SPI Code example

```
Transmit and receive 24 bits to/from slave 0, interrupt mode.
LPC_SPI->CFG = SPI_CFG_MASTER | SPI_CFG_ENABLE;
LPC_SPI->INTENSET = SPI_STAT_TXRDY | SPI_STAT_RXRDY;
while(LPC_SPI->INTENSET & (SPI_STAT_TXRDY | SPI_STAT_RXRDY));
NVIC_DisableIRQ(Spi_IRQn);
```

## 26.3.8 Transmit 8 bits to master

#### Table 362. SPI Code example

#### Transmit 8 bits to master.

```
LPC_SPI->CFG = SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | SPI_TXDATCTL_RXIGNORE | 0xdd;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->STAT = SPI_STAT_SSD;
while(~LPC_SPI->STAT & SPI_STAT_SSD);
LPC_SPI->STAT = SPI_STAT_SSD;
```

## 26.3.9 Receive 8 bits to master

#### Table 363. SPI Code example

#### Receive 8 bits to master.

```
LPC_SPI->CFG = SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7);
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdd) abort();
```

## 26.3.10 Transmit and receive 24 bits to master

#### Table 364. SPI Code example

#### Transmit and receive 24 bits to master.

```
LPC_SPI->CFG = SPI_CFG_ENABLE;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(15) | 0xdddd;
while(~LPC_SPI->STAT & SPI_STAT_TXRDY);
LPC_SPI->TXDATCTL = SPI_TXDATCTL_FLEN(7) | 0xdd;
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xdddd) abort();
while(~LPC_SPI->STAT & SPI_STAT_RXRDY);
data = LPC_SPI->RXDAT;
if(data != 0xddd) abort();
```

## 26.4 Code examples UART

## 26.4.1 Definitions

## Table 365. UART Code example

```
UART defines

#define UART_CFG_ENABLE (0x1 << 0)

#define UART_CFG_DATALEN(d) (((d) - 7) << 2)

#define UART_STAT_RXRDY (0x1 << 0)

#define UART_STAT_TXRDY (0x1 << 2)

#define UART_STAT_TXIDLE (0x1 << 3)
```

## 26.4.2 Interrupt handler

#### Table 366. UART Code example

```
Interrupt handler
void Usart_IRQHandler() {
    uint32_t intstat = LPC_USART->INTSTAT;
    if(intstat & UART_STAT_RXRDY) {
        if(!tx_rdy_flag) abort();
        tx_rdy_flag = 0;
        LPC_USART->TXDAT = LPC_USART->RXDAT;
        LPC_USART->INTENSET = UART_STAT_TXRDY;
        tx_counter++;
    }
    if(intstat & UART_STAT_TXRDY) {
        if(tx_rdy_flag) abort();
        tx_rdy_flag = 1;
        LPC_USART->INTENCLR = UART_STAT_TXRDY;
    }
}
```

## 26.4.3 Transmit one byte of data

### Table 367. UART Code example

```
Transmit one byte of data.
```

```
LPC_USART->CFG = UART_CFG_DATALEN(8) | UART_CFG_ENABLE;
while(~LPC_USART->STAT & UART_STAT_TXRDY);
LPC_USART->TXDAT = 0xdd;
while(~LPC_USART->STAT & UART_STAT_TXIDLE);
```

## 26.4.4 Receive one byte of data

Table 368. UART Code example

```
Receive one byte of data.
```

```
LPC_USART->CFG = UART_CFG_DATALEN(8) | UART_CFG_ENABLE;
while(~LPC_USART->STAT & UART_STAT_RXRDY);
data = LPC_USART->RXDAT;
if(data != 0xdd) abort();
```

## 26.4.5 Transmit and receive one byte of data

#### Table 369. UART Code example

#### Transmit and receive one byte of data.

```
LPC_USART->CFG = UART_CFG_DATALEN(8) | UART_CFG_ENABLE;
while(~LPC_USART->STAT & UART_STAT_TXRDY);
LPC_USART->TXDAT = 0xdd;
while(~LPC_USART->STAT & UART_STAT_RXRDY);
data = LPC_USART->RXDAT;
if(data != 0xdd) abort();
```

## 26.4.6 Loop back 10 bytes of data

#### Table 370. UART Code example

```
Loop back 10 bytes of data.
LPC_USART->CFG = UART_CFG_DATALEN(8) | UART_CFG_ENABLE;
for(i = 0; i < 10; i++) {
    while(~LPC_USART->STAT & (UART_STAT_TXRDY | UART_STAT_RXRDY));
    LPC_USART->TXDAT = LPC_USART->RXDAT;
}
while(~LPC_USART->STAT & UART_STAT_TXIDLE);
```

## 26.4.7 Loop back 10 bytes of data using interrupts

#### Table 371. UART Code example

```
Loop back 10 bytes of data using interrupts.

LPC_USART->CFG = UART_CFG_DATALEN(8) | UART_CFG_ENABLE;

LPC_USART->INTENSET = UART_STAT_TXRDY | UART_STAT_RXRDY;

while(tx_counter < 10);

LPC_USART->INTENCLR = UART_STAT_TXRDY | UART_STAT_RXRDY;

while(~LPC_USART->STAT & UART_STAT_TXIDLE);

NVIC_DisableIRQ(Usart_IRQn);
```

# **UM11021**

Chapter 27: Supplementary information Rev. 1.1 — 5 October 2016

**User manual** 

# **27.1 Abbreviations**

| Acronym | Description                                             |
|---------|---------------------------------------------------------|
| A/D     | Analog-to-Digital                                       |
| ADC     | Analog-to-Digital Converter                             |
| AHB     | Advanced High-performance Bus                           |
| APB     | Advanced Peripheral Bus                                 |
| BOD     | BrownOut Detection                                      |
| GPIO    | General Purpose Input/Output                            |
| JTAG    | Joint Test Action Group                                 |
| PLL     | Phase-Locked Loop                                       |
| RC      | Resistor-Capacitor                                      |
| SPI     | Serial Peripheral Interface                             |
| SSI     | Serial Synchronous Interface                            |
| SSP     | Synchronous Serial Port                                 |
| TAP     | Test Access Port                                        |
| UART    | Universal Asynchronous Receiver/Transmitter             |
| USART   | Universal Synchronous Asynchronous Receiver/Transmitter |

# **27.2 References**

- [1] LPC83x LPC83x Data sheet
- [2] ES\_LPC83x — LPC83x Errata sheet
- DDI0484B\_cortex\_m0p\_r0p0\_trm ARM Cortex-M0+ Technical Reference [3] Manual
- DDI0486A ARM technical reference manual [4]
- AN11538 AN11538 application note and code bundle (SCT cookbook) [5]
- ARMv6-M Architecture Reference Manual [6]

# 27.3 Legal information

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

## 27.3.2 Disclaimers

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

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

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

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

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

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

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product sole 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.

**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 competent authorities.

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

**User manual** 

## Chapter 27: Supplementary information

# 27.4 Tables

| Table 1.<br>Table 2.    | Ordering information                                |                           | (SYSPL<br>descrip |
|-------------------------|-----------------------------------------------------|---------------------------|-------------------|
| Table 3.                | Pin location in ISP mode                            | Table 30.                 | Main cl           |
| Table 4.                | Connection of interrupt sources to the NVIC16       |                           | address           |
| Table 5.                | Register overview: NVIC (base address 0xE000        | Table 31.                 |                   |
| Table 5.                | E000)                                               | Table 31.                 | (MAINC            |
| Table 6.                | Interrupt Set Enable Register 0 register (ISER0,    |                           | descrip           |
|                         | address 0xE000 E100) bit description20              | Table 32.                 | System            |
| Table 7.                | Interrupt clear enable register 0 (ICER0, address   | Table 32.                 | address           |
|                         | 0xE000 E180)                                        | Table 33.                 |                   |
| Table 8.                | Interrupt set pending register 0 register (ISPR0,   | Table 55.                 | (SYSAI            |
|                         | address 0xE000 E200) bit description22              |                           | descrip           |
| Table 9.                | Interrupt clear pending register 0 register (ICPR0, | Table 34.                 | USART             |
|                         | address 0xE000 E280) bit description23              |                           | address           |
| Table 10                | Interrupt Active Bit Register 0 (IABR0, address     | Table 35.                 | CLKOU             |
|                         | 0xE000 E300) bit description                        | Table 55.                 | (CLKO             |
| Table 11.               |                                                     |                           | descrip           |
|                         | 0xE000 E400) bit description                        | Table 36.                 | CLKOU             |
| Table 12                | Interrupt Priority Register 2 (IPR2, address        |                           | (CLKO             |
| 10010 12.               | 0xE000 E408) bit description                        |                           | descrip           |
| Table 13                | Interrupt Priority Register 3 (IPR3, address        | Table 37.                 |                   |
| 10010 10.               | 0xE000 E40C) bit description                        |                           | address           |
| Table 14                | Interrupt Priority Register 4 (IPR4, address        | Table 38.                 | USART             |
|                         | 0xE000 E410) bit description                        |                           | (UARTI            |
| Table 15.               | , .                                                 |                           | descrip           |
|                         | 0xE000 E414) bit description                        | Table 39.                 | USART             |
| Table 16.               | Interrupt Priority Register 6 (IPR6, address        |                           | register          |
|                         | 0xE000 E418) bit description27                      |                           | bit desc          |
| Table 17.               | Interrupt Priority Register 7 (IPR7, address        | Table 40.                 |                   |
|                         | 0xE000 E41C) bit description                        |                           | (EXTTF            |
| Table 18.               | SYSCON pin description                              |                           | descrip           |
| Table 19.               |                                                     | Table 41.                 | POR ca            |
|                         | address 0x4004 8000)                                |                           | (PIOPC            |
| Table 20.               | System memory remap register                        |                           | descrip           |
|                         | (SYSMEMREMAP, address 0x4004 8000) bit              | Table 42.                 | IOCON             |
|                         | description                                         |                           | (IOCON            |
| Table 21.               | <b>0</b> (                                          |                           | (IOCON            |
|                         | address 0x4004 8004) bit description34              |                           | (IOCON            |
| Table 22.               | System PLL control register (SYSPLLCTRL,            | Table 43.                 | BOD co            |
|                         | address 0x4004 8008) bit description36              |                           | 8150) b           |
| Table 23.               | System PLL status register (SYSPLLSTAT,             | Table 44.                 | System            |
|                         | address 0x4004 800C) bit description36              |                           | (SYST             |
| Table 24.               | 5                                                   |                           | descrip           |
|                         | address 0x4004 8020) bit description                | Table 45.                 | IRQ late          |
| Table 25.               | Watchdog oscillator control register                |                           | 0x4004            |
|                         | (WDTOSCCTRL, address 0x4004 8024) bit               | Table 46.                 |                   |
|                         | description                                         |                           | 0x4004            |
| Table 26.               | Internal resonant crystal control register          | Table 47.                 |                   |
|                         | (IRCCTRL, address 0x4004 8028) bit description      |                           | address           |
| <b>T</b> 1 1 0 <b>T</b> | 38                                                  | <b>T</b> 1 1 10           | 8194 (F           |
| Table 27.               | <b>5</b>                                            | Table 48.                 |                   |
| T-LL OC                 | address 0x4004 8030) bit description                |                           | (START            |
| Table 28.               | System PLL clock source select register             | Table 40                  | descrip           |
|                         | (SYSPLLCLKSEL, address 0x4004 8040) bit             | Table 49.                 | Start log         |
| Table 20                | description                                         |                           | (START            |
| 10010 29.               | Oystern I LL CIOCK Source update enable register    |                           | descrip           |
| UM11021                 | All information provided in this doc                | cument is subject to lega | al disclaimers.   |

|           | (SYSPLLCLKUEN, address 0x4004 8044) bit description                               |
|-----------|-----------------------------------------------------------------------------------|
| Table 30. | Main clock source select register (MAINCLKSEL,                                    |
| Table 04  | address 0x4004 8070) bit description 40                                           |
| Table 31. | 1 5                                                                               |
|           | (MAINCLKUEN, address 0x4004 8074) bit description                                 |
| Table 32. | -                                                                                 |
|           | address 0x4004 8078) bit description 41                                           |
| Table 33. |                                                                                   |
|           | (SYSAHBCLKCTRL, address 0x4004 8080) bit                                          |
| Table 04  | description                                                                       |
| Table 34. | USART clock divider register (UARTCLKDIV, address 0x4004 8094) bit description 43 |
| Table 35. | <i>,</i> .                                                                        |
|           | (CLKOUTSEL, address 0x4004 80E0) bit                                              |
|           | description                                                                       |
| Table 36. | -                                                                                 |
|           | (CLKOUTUEN, address 0x4004 80E4) bit                                              |
|           | description                                                                       |
| Table 37. | CLKOUT clock divider registers (CLKOUTDIV,                                        |
|           | address 0x4004 80E8) bit description 44                                           |
| Table 38. |                                                                                   |
|           | (UARTFRGDIV, address 0x4004 80F0) bit                                             |
|           | description                                                                       |
| Table 39. |                                                                                   |
|           | register (UARTFRGMULT, address 0x4004 80F4)                                       |
| Table 10  | bit description                                                                   |
|           | (EXTTRACECMD, address 0x4004 80FC) bit                                            |
|           | description                                                                       |
| Table 41  | POR captured PIO status register 0                                                |
|           | (PIOPORCAP0, address 0x4004 8100) bit                                             |
|           | description                                                                       |
| Table 42. |                                                                                   |
|           | (IOCONCLKDIV[6:0], address 0x4004 8134                                            |
|           | (IOCONCLKDIV6) to 0x004 814C                                                      |
|           | (IOCONFILTCLKDIV0)) bit description46                                             |
| Table 43. | 5 (                                                                               |
|           | 8150) bit description                                                             |
| Table 44. |                                                                                   |
|           | (SYSTCKCAL, address 0x4004 8154) bit                                              |
| Table 15  | description                                                                       |
| Table 45. | IRQ latency register (IRQLATENCY, address 0x4004 8170) bit description            |
| Table 46  | NMI source selection register (NMISRC, address                                    |
|           | 0x4004 8174) bit description                                                      |
| Table 47. | Pin interrupt select registers (PINTSEL[0:7],                                     |
|           | address 0x4004 8178 (PINTSEL0) to 0x4004                                          |
|           | 8194 (PINTSEL7)) bit description                                                  |
| Table 48. |                                                                                   |
|           | (STARTERP0, address 0x4004 8204) bit                                              |
|           | description                                                                       |
| Table 49. | Start logic 1 interrupt wake-up enable register                                   |
|           | (STARTERP1, address 0x4004 8214) bit                                              |
|           | description                                                                       |

## Chapter 27: Supplementary information

| Table 50. | Deep-sleep configuration register<br>(PDSLEEPCFG, address 0x4004 8230) bit                |
|-----------|-------------------------------------------------------------------------------------------|
|           | description                                                                               |
| Table 51. | Wake-up configuration register (PDAWAKECFG, address 0x4004 8234) bit description51        |
| Table 52. | Power configuration register (PDRUNCFG, address 0x4004 8238) bit description52            |
| Table 53. | Device ID register (DEVICE_ID, address 0x4004<br>83F8) bit description                    |
| Table 54. | PLL frequency parameters                                                                  |
| Table 55. | PLL configuration examples                                                                |
| Table 56. | System control register (SCR, address 0xE000 ED10) bit description60                      |
| Table 57. | Wake-up sources for reduced power modes63                                                 |
| Table 58. | Register overview:         PMU (base address 0x4002           0000)                       |
| Table 59. | Power control register (PCON, address 0x4002<br>0000) bit description                     |
| Table 60. | General purpose registers 0 to 3 (GPREG[0:3], address 0x4002 0004 (GPREG0) to 0x4002 0010 |
|           | (GPREG3)) bit description                                                                 |
| Table 61. | Deep power down control register (DPDCTRL, address 0x4002 0014) bit description65         |
| Table 62. | Peripheral configuration in reduced power modes 66                                        |
| Table 63. | Movable functions (assign to pins PIO0_0 to PIO0_28 through switch matrix)77              |
| Table 64. | Register overview: Switch matrix (base address 0x4000 C000)                               |
| Table 65. | Pin assign register 0 (PINASSIGN0, address<br>0x4000 C000) bit description                |
| Table 66. | Pin assign register 1 (PINASSIGN1, address 0x4000 C004) bit description80                 |
| Table 67. | Pin assign register 3 (PINASSIGN3, address 0x4000 C00C) bit description                   |
| Table 68. | Pin assign register 4 (PINASSIGN4, address 0x4000 C010) bit description                   |
| Table 69. | Pin assign register 5 (PINASSIGN5, address<br>0x4000 C014) bit description                |
| Table 70. | Pin assign register 6 (PINASSIGN6, address<br>0x4000 C018) bit description                |
| Table 71. | Pin assign register 7 (PINASSIGN7, address<br>0x4000 C01C) bit description                |
| Table 72. |                                                                                           |
| Table 73. |                                                                                           |
| Table 74. |                                                                                           |
| Table 75. | Pin assign register 11 (PINASSIGN11, address<br>0x4000 C02C) bit description              |
| Table 76. | Pin enable register 0 (PINENABLE0, address<br>0x4000 C1C0) bit description                |
| Table 77  | Pinout summary                                                                            |
|           | Register overview: I/O configuration (base address 0x4004 4000)                           |
| Table 79. |                                                                                           |

| Table 80. | PIO0_17 register (PIO0_17, address 0x4004<br>4000) bit description90  |
|-----------|-----------------------------------------------------------------------|
| Table 81. | PIO0_13 register (PIO0_13, address 0x4004<br>4004) bit description    |
| Table 82. | PIO0_12 register (PIO0_12, address 0x4004<br>4008) bit description    |
| Table 83. | PIO0_5 register (PIO0_5, address 0x4004 400C)<br>bit description      |
| Table 84. | PIO0_4 register (PIO0_4, address 0x4004 4010)<br>bit description      |
| Table 85. | PIO0_3 register (PIO0_3, address 0x4004 4014)<br>bit description95    |
| Table 86. | PIO0_2 register (PIO0_2, address 0x4004 4018) bit description97       |
| Table 87. | PIO0_11 register (PIO0_11, address 0x4004<br>401C) bit description    |
|           | PIO0_10 register (PIO0_10, address 0x4004<br>4020) bit description    |
|           | PIO0_16 register (PIO0_16, address 0x4004<br>4024) bit description100 |
|           | PIO0_15 register (PIO0_15, address 0x4004<br>4028) bit description101 |
|           | PIO0_1 register (PIO0_1, address 0x4004 402C)<br>bit description      |
|           | PIO0_9 register (PIO0_9, address 0x4004 4034)<br>bit description      |
|           | PIO0_8 register (PIO0_8, address 0x4004 4038)<br>bit description      |
|           | PIO0_7 register (PIO0_7, address 0x4004 403C)<br>bit description      |
| Table 95. | bit description                                                       |
| Table 96. | bit description                                                       |
|           | 4048) bit description                                                 |
|           | 4050) bit description                                                 |
|           | 4054) bit description                                                 |
|           | 4058) bit description                                                 |
|           | 405C) bit description                                                 |
|           | 4060) bit description                                                 |
| Table 104 | 4064) bit description                                                 |
| Table 105 | 4068) bit description                                                 |
| Table 106 | 406C) bit description                                                 |
| Table 107 | 4070) bit description                                                 |
| Table 108 | 4074) bit description                                                 |
|           |                                                                       |

|                                                                      |                                                                                                                                                        | GPIO pins available                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Table                                                                | 110.                                                                                                                                                   | Register overview: GPIO port (base address                                                                                                                                                                                                                         |
|                                                                      |                                                                                                                                                        | 0xA000 0000)                                                                                                                                                                                                                                                       |
| Table                                                                | 111.                                                                                                                                                   | GPIO port byte pin registers (B[0:28], addresses                                                                                                                                                                                                                   |
|                                                                      |                                                                                                                                                        | 0xA000 0000 (B0) to 0xA000 001C (B28)) bit                                                                                                                                                                                                                         |
|                                                                      |                                                                                                                                                        | description                                                                                                                                                                                                                                                        |
| Table                                                                | 112.                                                                                                                                                   | GPIO port word pin registers (W[0:28], addresses                                                                                                                                                                                                                   |
|                                                                      |                                                                                                                                                        | 0xA000 1000 (W0) to 0xA000 1074 (W28)) bit                                                                                                                                                                                                                         |
|                                                                      |                                                                                                                                                        | description                                                                                                                                                                                                                                                        |
| Table                                                                | 113.                                                                                                                                                   | GPIO direction port register (DIR0, address                                                                                                                                                                                                                        |
| Table                                                                |                                                                                                                                                        | 0xA000 2000) bit description                                                                                                                                                                                                                                       |
| Table                                                                | 114                                                                                                                                                    | GPIO mask port register (MASK0, address                                                                                                                                                                                                                            |
| Table                                                                |                                                                                                                                                        | 0xA000 2080) bit description                                                                                                                                                                                                                                       |
| Table                                                                | 115                                                                                                                                                    | GPIO port pin register (PIN0, address 0xA000                                                                                                                                                                                                                       |
| Table                                                                | 110.                                                                                                                                                   | 2100) bit description                                                                                                                                                                                                                                              |
| Tahla                                                                | 116                                                                                                                                                    | GPIO masked port pin register (MPIN0, address                                                                                                                                                                                                                      |
| Table                                                                | 110.                                                                                                                                                   | 0xA000 2180) bit description                                                                                                                                                                                                                                       |
| Tabla                                                                | 117                                                                                                                                                    | GPIO port set register (SET0, address 0xA000                                                                                                                                                                                                                       |
| Table                                                                | 117.                                                                                                                                                   | 2200) bit description                                                                                                                                                                                                                                              |
| Toblo                                                                | 110                                                                                                                                                    | GPIO port clear register (CLR0, address 0xA000                                                                                                                                                                                                                     |
| Table                                                                | 110.                                                                                                                                                   |                                                                                                                                                                                                                                                                    |
| Tabla                                                                | 440                                                                                                                                                    | 2280) bit description                                                                                                                                                                                                                                              |
| Table                                                                | 119.                                                                                                                                                   | GPIO port toggle register (NOT0, address                                                                                                                                                                                                                           |
| <b>-</b>                                                             | 400                                                                                                                                                    | 0xA000 2300) bit description                                                                                                                                                                                                                                       |
| Table                                                                | 120.                                                                                                                                                   | GPIO port direction set register (DIRSET0,                                                                                                                                                                                                                         |
| <b>T</b> -1-1-                                                       | 404                                                                                                                                                    | address 0xA000 2380) bit description124                                                                                                                                                                                                                            |
| Table                                                                | 121.                                                                                                                                                   | GPIO port direction clear register (DIRCLR0,                                                                                                                                                                                                                       |
| <b>T</b> -1-1-                                                       | 400                                                                                                                                                    | 0xA000 2400) bit description                                                                                                                                                                                                                                       |
| Table                                                                | 122.                                                                                                                                                   | GPIO port direction toggle register (DIRNOTO,                                                                                                                                                                                                                      |
|                                                                      |                                                                                                                                                        | address 0xA000 2480) bit description125                                                                                                                                                                                                                            |
| <b>T</b> - 1-1 -                                                     | 400                                                                                                                                                    |                                                                                                                                                                                                                                                                    |
| Table                                                                | 123                                                                                                                                                    | Pin interrupt/pattern match engine pin description                                                                                                                                                                                                                 |
|                                                                      |                                                                                                                                                        | Pin interrupt/pattern match engine pin description 128                                                                                                                                                                                                             |
|                                                                      |                                                                                                                                                        | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern                                                                                                                                                         |
| Table                                                                | 124.                                                                                                                                                   | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133                                                                                                        |
| Table                                                                | 124.                                                                                                                                                   | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address                                                          |
| Table<br>Table                                                       | 124.<br>125.                                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table                                                       | 124.<br>125.                                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table                                                       | 124.<br>125.                                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table                                              | 124.<br>125.<br>126.                                                                                                                                   | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table                                              | 124.<br>125.<br>126.                                                                                                                                   | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table                                              | 124.<br>125.<br>126.                                                                                                                                   | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table<br>Table                                     | 124.<br>125.<br>126.<br>127.                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table<br>Table                                     | 124.<br>125.<br>126.<br>127.                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table<br>Table                                     | 124.<br>125.<br>126.<br>127.                                                                                                                           | Pin interrupt/pattern match engine pin description<br>128<br>Register overview: Pin interrupts and pattern<br>match engine (base address: 0xA000 4000) .133<br>Pin interrupt mode register (ISEL, address<br>0xA000 4000) bit description                          |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table                            | 124.<br>125.<br>126.<br>127.<br>128.                                                                                                                   | Pin interrupt/pattern match engine pin description         128         Register overview: Pin interrupts and pattern         match engine (base address: 0xA000 4000) .133         Pin interrupt mode register (ISEL, address         0xA000 4000) bit description |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table                   | 124.<br>125.<br>126.<br>127.<br>128.<br>129.                                                                                                           | Pin interrupt/pattern match engine pin description         128         Register overview: Pin interrupts and pattern         match engine (base address: 0xA000 4000) .133         Pin interrupt mode register (ISEL, address         0xA000 4000) bit description |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table                   | 124.<br>125.<br>126.<br>127.<br>128.<br>129.                                                                                                           | Pin interrupt/pattern match engine pin description         128         Register overview: Pin interrupts and pattern         match engine (base address: 0xA000 4000) .133         Pin interrupt mode register (ISEL, address         0xA000 4000) bit description |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table                   | 124.<br>125.<br>126.<br>127.<br>128.<br>129.                                                                                                           | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table                   | 124.<br>125.<br>126.<br>127.<br>128.<br>129.<br>130.                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table                   | 124.<br>125.<br>126.<br>127.<br>128.<br>129.<br>130.                                                                                                   | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table<br>Table          | 124.<br>125.<br>126.<br>127.<br>128.<br>129.<br>130.<br>131.                                                                                           | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table<br>Table          | 124.<br>125.<br>126.<br>127.<br>128.<br>129.<br>130.<br>131.                                                                                           | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |
| Table<br>Table<br>Table<br>Table<br>Table<br>Table<br>Table<br>Table | <ol> <li>124.</li> <li>125.</li> <li>126.</li> <li>127.</li> <li>128.</li> <li>129.</li> <li>130.</li> <li>131.</li> <li>132.</li> <li>133.</li> </ol> | Pin interrupt/pattern match engine pin description128Register overview: Pin interrupts and patternmatch engine (base address: 0xA000 4000) .133Pin interrupt mode register (ISEL, address0xA000 4000) bit description                                              |

| Table | 135  | 4024) bit description                                                                                                                                                     |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      | bit description                                                                                                                                                           |
| Table | 137. | Pattern match bit slice configuration register<br>(PMCFG, address 0xA000 4030) bit description<br>143                                                                     |
| Table | 138  | Pin interrupt registers for edge- and level-sensitive pins                                                                                                                |
| Table | 139  | INPUT MUX pin description                                                                                                                                                 |
|       |      | Register overview: Input multiplexing (base address 0x4002 8000)                                                                                                          |
| Table | 141. | Register overview: Input multiplexing (base address 0x4002 C000)                                                                                                          |
| Table | 142. | DMA input trigger Input mux registers 0 to 17<br>(DMA_ITRIG_INMUX[0:17], address<br>0x4002 80E0 (DMA_ITRIG_INMUX0) to 0x4002<br>8124 (DMA_ITRIG_INMUX17)) bit description |
| Table | 143. | 155<br>DMA input trigger input mux input registers 0 to 1<br>(DMA_INMUX_INMUX[0:1], address                                                                               |
| Table | 144  | 0x4002 C000 (DMA_INMUX_INMUX0) to 0x4002<br>C004 (DMA_INMUX_INMUX1)) bit description<br>155<br>. SCT input mux registers 0 to 3                                           |
| Table |      | (SCT0_INMUX[0:3], address 0x4002 C020<br>(SCT0_INMUX0) to 0x4002 C02C<br>(SCT0_INMUX3)) bit description                                                                   |
| Table | 145  | DMA requests                                                                                                                                                              |
|       |      | Channel descriptor                                                                                                                                                        |
|       |      | Reload descriptors                                                                                                                                                        |
|       |      | Channel descriptor for a single transfer 161                                                                                                                              |
|       |      | Example descriptors for ping-pong operation:<br>peripheral to buffer                                                                                                      |
| Table | 150  | Register overview: DMA controller (base address<br>0x5000 8000)                                                                                                           |
| Table | 151  | Control register (CTRL, address 0x5000 8000) bit description                                                                                                              |
| Table | 152  | Interrupt Status register (INTSTAT, address<br>0x5000 8004) bit description                                                                                               |
| Table | 153  | SRAM Base address register (SRAMBASE, address 0x5000 8008) bit description 167                                                                                            |
| Table | 154  | Channel descriptor map 168                                                                                                                                                |
|       |      | Enable read and Set register 0 (ENABLESET0, address 0x5000 8020) bit description 168                                                                                      |
| Table | 156  | Enable Clear register 0 (ENABLECLR0, address 0x5000 8028) bit description                                                                                                 |
| Table | 157  | Active status register 0 (ACTIVE0, address<br>0x5000 8030) bit description                                                                                                |
|       |      | Busy status register 0 (BUSY0, address 0x5000 8038) bit description                                                                                                       |
| Table | 159. | Error Interrupt register 0 (ERRINT0, address 0x5000 8040) bit description                                                                                                 |
| Table | 160  | Interrupt Enable read and Set register 0<br>(INTENSET0, address 0x5000 8048) bit<br>description                                                                           |

User manual

| Table 1 | 161. | Interrupt Enable Clear register 0 (INTENCLR0, address 0x5000 8050) bit description170                                                             |
|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 1 | 162. | Interrupt A register 0 (INTA0, address 0x5000<br>8058) bit description                                                                            |
| Table 1 |      | Interrupt B register 0 (INTB0, address 0x5000<br>8060) bit description                                                                            |
|         | 164. | Set Valid 0 register (SETVALID0, address 0x5000 8068) bit description                                                                             |
|         |      | Set Trigger 0 register (SETTRIG0, address 0x5000 8070) bit description172                                                                         |
|         |      | Abort 0 register (ABORT0, address 0x5000 8078)<br>bit description                                                                                 |
| lable 1 | 167. | Configuration registers for channel 0 to 17<br>(CFG[0:17], addresses 0x5000 8400 (CFG0) to<br>address 0x5000 8510 (CFG17)) bit description<br>173 |
| Table 1 | 168. | Trigger setting summary                                                                                                                           |
| Table 1 | 169. | Control and Status registers for channel 0 to 17<br>(CTLSTAT[0:17], 0x5000 8404 (CTLSTAT0) to<br>address 0x5000 8514 (CTLSTAT17)) bit             |
|         |      | description175                                                                                                                                    |
| Table 1 | 170. | Transfer Configuration registers for channel 0 to                                                                                                 |
|         |      | 17 (XFERCFG[0:17], addresses 0x5000 8408                                                                                                          |
|         |      | (XFERCFG0) to 0x5000 8518 (XFERCFG17)) bit                                                                                                        |
|         |      | description                                                                                                                                       |
| Table 1 | 171. | USART pin description                                                                                                                             |
| Table 1 | 172. | Register overview: USART (base address                                                                                                            |
|         |      | 0x4006 4000 (USART0)                                                                                                                              |
| Table 1 |      | USART Configuration register (CFG, address                                                                                                        |
|         |      | 0x4006 4000 (USART0) bit description186                                                                                                           |
| Toble 1 |      | USART Control register (CTL, address 0x4006                                                                                                       |
| Table I |      |                                                                                                                                                   |
| Table 1 |      | 4004 (USART0) bit description                                                                                                                     |
|         |      | 4008 (USART0) bit description                                                                                                                     |
| Table 1 |      | USART Interrupt Enable read and set register                                                                                                      |
|         |      | (INTENSET, address 0x4006 400C (USART0)) bit                                                                                                      |
|         |      | description                                                                                                                                       |
| Table 1 |      |                                                                                                                                                   |
| Table I | 177. | USART Interrupt Enable clear register                                                                                                             |
|         |      | (INTENCLR, address 0x4006 4010 (USART0)) bit                                                                                                      |
|         |      | description                                                                                                                                       |
| Table 1 |      | USART Receiver Data register (RXDAT, address                                                                                                      |
|         |      | 0x4006 4014 (USART0) bit description194                                                                                                           |
| Table 1 | 179. | USART Receiver Data with Status register                                                                                                          |
|         |      | (RXDATSTAT, address 0x4006 4018 (USART0))                                                                                                         |
|         |      | bit description                                                                                                                                   |
| Table 1 | 180. | USART Transmitter Data Register (TXDAT,                                                                                                           |
|         |      | address 0x4006 401C (USART0)) bit description.                                                                                                    |
|         |      | 195                                                                                                                                               |
| Table 1 | 181  | USART Baud Rate Generator register (BRG,                                                                                                          |
|         | .01. | address 0x4006 4020 (USART0)) bit description .                                                                                                   |
|         |      | 195                                                                                                                                               |
| Table 1 | 182  | USART Interrupt Status register (INTSTAT,                                                                                                         |
|         | 02.  | address 0x4006 4024 (USART0)) bit description .                                                                                                   |
|         |      | · //                                                                                                                                              |
| Takla 4 | 100  | 196                                                                                                                                               |
| Table 1 |      | USART Oversample selection register (OSR,                                                                                                         |
|         |      | address 0x4006 4028 (USART0)) bit description .                                                                                                   |
|         |      | 197                                                                                                                                               |
| Table 1 | 184. | USART Address register (ADDR, address                                                                                                             |
|         |      |                                                                                                                                                   |

|               |      | 0x4006 402C (USART0)) bit description 197                    |
|---------------|------|--------------------------------------------------------------|
|               |      | SPI Pin Description                                          |
| Table         | 186. | Register overview: SPI (base address 0x4005                  |
|               |      | 8000 (SPI0) and 0x4005 C000 (SPI1)) 205                      |
| Table         | 187. | SPI Configuration register (CFG, addresses                   |
|               |      | 0x4005 8000 (SPI0), 0x4005 C000 (SPI1)) bit                  |
|               |      | description                                                  |
| Table         | 188. | SPI Delay register (DLY, addresses 0x4005 8004               |
|               |      | (SPI0), 0x4005 C004 (SPI1)) bit description . 208            |
| Table         | 189. | SPI Status register (STAT, addresses 0x4005                  |
|               |      | 8008 (SPI0), 0x4005 C008 (SPI1)) bit description             |
|               |      | 209                                                          |
| Table         | 190. | SPI Interrupt Enable read and Set register                   |
|               |      | (INTENSET, addresses 0x4005 800C (SPI0),                     |
|               |      | 0x4005 C00C (SPI1)) bit description 210                      |
| Table         | 191  | SPI Interrupt Enable clear register (INTENCLR,               |
| rabio         | 1011 | addresses 0x4005 8010 (SPI0), 0x4005 C010                    |
|               |      | (SPI1)) bit description                                      |
| Tahla         | 102  | SPI Receiver Data register (RXDAT, addresses                 |
| Table         | 132. | 0x4005 8014 (SPI0), 0x4005 C014 (SPI1)) bit                  |
|               |      | description                                                  |
| Tabla         | 100  | SPI Transmitter Data and Control register                    |
| Table         | 193. |                                                              |
|               |      | (TXDATCTL, addresses 0x4005 8018 (SPI0),                     |
| <b>-</b>      | 404  | 0x4005 C018 (SPI1)) bit description 213                      |
| Table         | 194. | SPI Transmitter Data Register (TXDAT,                        |
|               |      | addresses 0x4005 801C (SPI0), 0x4005 C01C                    |
|               |      | (SPI1)) bit description                                      |
| Table         | 195. | SPI Transmitter Control register (TXCTL,                     |
|               |      | addresses 0x4005 8020 (SPI0), 0x4005 C020                    |
|               |      | (SPI1)) bit description                                      |
| Table         | 196. | SPI Divider register (DIV, addresses 0x4005 8024             |
|               |      | (SPI0), 0x4005 C024 (SPI1)) bit description . 216            |
| Table         | 197. | SPI Interrupt Status register (INTSTAT, addresses            |
|               |      | 0x4005 8028 (SPI0), 0x4005 C028 (SPI1)) bit                  |
|               |      | description                                                  |
| Table         | 198. | SPI mode summary                                             |
|               |      | I2C-bus pin description                                      |
|               |      | Register overview: I2C (base address 0x4005                  |
|               |      | 0000 (I2C0))                                                 |
| Table         | 201. | I2C Configuration register (CFG, address 0x4005              |
|               | -    | 0000 (I2C0)) bit description 231                             |
| Table         | 202  | I <sup>2</sup> C Status register (STAT, address 0x4005 0004  |
| Table         |      | (I2C0)) bit description                                      |
| Tahle         | 203  | Master function state codes (MSTSTATE) 236                   |
|               |      | Slave function state codes (SLVSTATE) 237                    |
|               |      | Interrupt Enable Set and read register                       |
| Table         | 205. |                                                              |
|               |      | (INTENSET, address 0x4005 0008 (I2C0)) bit                   |
| Tabla         | 200  | description                                                  |
| Table         | 200. | Interrupt Enable Clear register (INTENCLR,                   |
| <b>T</b> -1 1 | 007  | address 0x4005 000C (I2C0)) bit description 239              |
| lable         | 207. | Time-out value register (TIMEOUT, address                    |
| <b>-</b>      |      | 0x4005 0010 (I2C0)) bit description240                       |
| lable         | 208. | I <sup>2</sup> C Clock Divider register (CLKDIV, address     |
|               |      | 0x4005 0014 (I2C0)) bit description240                       |
| Table         | 209. | I <sup>2</sup> C Interrupt Status register (INTSTAT, address |
|               |      | 0x4005 0018 (I2C0)) bit description241                       |
| Table         | 210. | Master Control register (MSTCTL, address                     |
|               |      | 0x4005 0020 (I2C0)) bit description                          |

| Table          | 211.         | Master Time register (MSTTIME, address 0x4005                                                                                             |
|----------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|                |              | 0024 (I2C0)) bit description                                                                                                              |
| Table          | 212.         | Master Data register (MSTDAT, address 0x4005                                                                                              |
|                |              | 0028 (I2C0)) bit description                                                                                                              |
| Table          | 213.         | Slave Control register (SLVCTL, address 0x4005                                                                                            |
|                |              | 0040 (I2C0)) bit description                                                                                                              |
| Table          | 214          | Slave Data register (SLVDAT, address 0x4005                                                                                               |
| Table          | 217.         | 0044 (I2C0)) bit description                                                                                                              |
| Tabla          | 215          | Slave Address registers (SLVADR[0:3], address                                                                                             |
| Table          | 210.         | 0x4005 0048 (SLVADR0) to 0x4005 0054                                                                                                      |
|                |              | · · · · · · · · · · · · · · · · · · ·                                                                                                     |
| <b>T</b> -1-1- | 040          | (SLVADR3) (I2C0)) bit description                                                                                                         |
| lable          | 216.         | Slave address Qualifier 0 register (SLVQUAL0,                                                                                             |
|                | - · -        | address 0x4005 0058 (I2C0)) bit description .246                                                                                          |
| lable          | 217.         | Monitor data register (MONRXDAT, address                                                                                                  |
|                |              | 0x4005 0080 (I2C0)) bit description                                                                                                       |
|                |              | SCT pin description                                                                                                                       |
| Table          | 219.         | Register overview: State Configurable Timer                                                                                               |
|                |              | SCT/PWM (base address 0x5000 4000)255                                                                                                     |
| Table          | 220.         | SCT configuration register (CONFIG, address                                                                                               |
|                |              | 0x5000 4000) bit description                                                                                                              |
| Table          | 221.         | SCT control register (CTRL, address 0x5000                                                                                                |
|                |              | 4004) bit description                                                                                                                     |
| Table          | 222.         | SCT limit event select register (LIMIT, address                                                                                           |
|                |              | 0x5000 4008) bit description                                                                                                              |
| Table          | 223          | SCT halt event select register (HALT, address                                                                                             |
| Table          | 220.         | 0x5000 400C) bit description                                                                                                              |
| Tabla          | 224          | SCT stop event select register (STOP, address                                                                                             |
| Table          | 224.         | 0x5000 4010) bit description                                                                                                              |
| Tabla          | 225          | SCT start event select register (START address                                                                                            |
| Table          | 223.         | SCT start event select register (START, address                                                                                           |
| <b>T</b> -1-1- | 000          | 0x5000 4014) bit description                                                                                                              |
| Table          | 226.         | SCT counter register (COUNT, address 0x5000                                                                                               |
| <b>-</b>       | 007          | 4040) bit description                                                                                                                     |
| Table          | 227.         | SCT state register (STATE, address 0x5000                                                                                                 |
| <b>-</b>       | ~~~          | 4044) bit description                                                                                                                     |
| lable          | 228.         | SCT input register (INPUT, address 0x5000                                                                                                 |
|                |              | 4048) bit description                                                                                                                     |
| Table          | 229.         | SCT match/capture mode register (REGMODE,                                                                                                 |
|                |              | address 0x5000 404C) bit description269                                                                                                   |
| Table          | 230.         | SCT output register (OUTPUT, address 0x5000                                                                                               |
|                |              | 4050) bit description                                                                                                                     |
| Table          | 231.         | SCT bidirectional output control register                                                                                                 |
|                |              | (OUTPUTDIRCTRL, address 0x5000 4054) bit                                                                                                  |
|                |              | description                                                                                                                               |
| Table          | 232.         | SCT conflict resolution register (RES, address                                                                                            |
|                |              | 0x5000 4058) bit description                                                                                                              |
| Table          | 233.         | SCT DMA 0 request register (DMAREQ0,                                                                                                      |
|                |              | address 0x5000 405C) bit description272                                                                                                   |
| Tahle          | 234          | SCT DMA 1 request register (DMAREQ1,                                                                                                      |
| Tuble          | 201.         | address 0x5000 C060) bit description272                                                                                                   |
| Tahla          | 235          | SCT event interrupt enable register (EVEN,                                                                                                |
| Table          | 200.         | address 0x5000 40F0) bit description272                                                                                                   |
|                | <b>7</b> 26  |                                                                                                                                           |
| Table          |              | SCT event flag register (EVFLAG, address                                                                                                  |
| Table          | 200.         | OVEDOD 40E4) bit description                                                                                                              |
|                |              | 0x5000 40F4) bit description                                                                                                              |
|                |              | SCT conflict interrupt enable register (CONEN,                                                                                            |
| Table          | 237.         | SCT conflict interrupt enable register (CONEN, address 0x5000 40F8) bit description273                                                    |
| Table          | 237.         | SCT conflict interrupt enable register (CONEN,<br>address 0x5000 40F8) bit description273<br>SCT conflict flag register (CONFLAG, address |
| Table<br>Table | 237.<br>238. | SCT conflict interrupt enable register (CONEN, address 0x5000 40F8) bit description273                                                    |

|           | 0x5000 4100 (MATCH0) to 0x5000 411C<br>(MATCH7)) bit description (REGMODEn bit = 0).<br>274                                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 240 | . SCT capture registers 0 to 7 (CAP[0:7], address<br>0x5000 4100 (CAP0) to 0x5000 411C (CAP7)) bit                                                                                                                |
| Table 241 | description (REGMODEn bit = 1)274<br>. SCT match reload registers 0 to 7<br>(MATCHREL[0:7], address 0x5000 4200<br>(MATCHREL0) to 0x5000 421C (MATCHREL7))                                                        |
| Table 242 | bit description (REGMODEn bit = 0) 275<br>. SCT capture control registers 0 to 7<br>(CAPCTRL[0:7], address 0x5000 4200                                                                                            |
| Table 243 | (CAPCTRL0) to 0x5000 421C (CAPCTRL7)) bit<br>description (REGMODEn bit = 1)275<br>. SCT event state mask registers 0 to 7<br>(EV[0:7]_STATE, addresses 0x5000 4300<br>(EV0_STATE) to 0x5000 4338 (EV7_STATE)) bit |
| Table 244 | description                                                                                                                                                                                                       |
| Table 245 | 433C (EV7_CTRL)) bit description                                                                                                                                                                                  |
| Table 246 | (OUT5_SET) bit description                                                                                                                                                                                        |
|           | . Event conditions                                                                                                                                                                                                |
|           | . SCT configuration example                                                                                                                                                                                       |
| Table 249 | . Register overview: Watchdog timer (base address 0x4000 0000)                                                                                                                                                    |
| Table 250 | . Watchdog mode register (MOD, 0x4000 0000) bit description                                                                                                                                                       |
| Table 251 | . Watchdog operating modes selection 296                                                                                                                                                                          |
|           | . Watchdog Timer Constant register (TC, 0x4000                                                                                                                                                                    |
| Table 253 | 0004) bit description. 296<br>Watchdog Feed register (FEED, 0x4000 0008) bit                                                                                                                                      |
| Table 254 | description                                                                                                                                                                                                       |
| Table 255 | 000C) bit description                                                                                                                                                                                             |
| Table 256 | (WARNINT, 0x4000 0014) bit description 297<br>. Watchdog Timer Window register (WINDOW,                                                                                                                           |
| Table 257 | 0x4000 0018) bit description                                                                                                                                                                                      |
| Table 258 | . Control register (CTRL, address 0x4000 8000) bit                                                                                                                                                                |
| Table 259 | description                                                                                                                                                                                                       |
| Table 260 | bit description                                                                                                                                                                                                   |
| Table 261 | 4000)                                                                                                                                                                                                             |
|           | 0x4000 4000 (INTVAL0) to 0x4000 4030<br>(INTVAL3)) bit description                                                                                                                                                |
| Table 262 | . Timer register (TIMER[0:3], address 0x4000 4004<br>(TIMER0) to 0x4000 4034 (TIMER3)) bit<br>description                                                                                                         |

# UM11021

| Table | 263. | Control register (CTRL[0:3], address 0x4000<br>4008 (CTRL0) to 0x4000 4038 (CTRL3)) bit           |
|-------|------|---------------------------------------------------------------------------------------------------|
| Table | 264. | description                                                                                       |
| Table | 265. | 308         Idle channel register (IDLE_CH, address 0x4000         40F4) bit description          |
| Table | 266. | Global interrupt flag register (IRQ_FLAG, address<br>0x4000 40F8) bit description                 |
| Table | 267. | Register overview: SysTick timer (base address 0xE000 E000)                                       |
|       |      | . SysTick Timer Control and status register<br>(SYST_CSR, 0xE000 E010) bit description312         |
| Table | 269. | System Timer Reload value register<br>(SYST_RVR, 0xE000 E014) bit description312                  |
|       |      | . System Timer Current value register<br>(SYST_CVR, 0xE000 E018) bit description312               |
|       |      | System Timer Calibration value register<br>(SYST_CALIB, 0xE000 E01C) bit description 313          |
|       |      | Pinout summary                                                                                    |
| Table | 273. | ADC hardware trigger inputs                                                                       |
|       |      | ADC supply and reference voltage pins 318                                                         |
|       |      | ADC pin description                                                                               |
|       |      | Register overview : ADC (base address 0x4001<br>C000 )                                            |
| Table | 277. | A/D Control Register (CTRL, addresses 0x4001<br>C000) bit description                             |
| Table | 278. | A/D Conversion Sequence A Control Register<br>(SEQA_CTRL, address 0x4001 C008) bit<br>description |
| Table | 279. | A/D Conversion Sequence A Control Register<br>(SEQA_CTRL, address 0x4001 C008) bit                |
|       |      | description                                                                                       |
| Table | 280. | A/D Sequence A Global Data Register                                                               |
|       |      | (SEQA_GDAT, address 0x4001 C010) bit                                                              |
|       |      | description                                                                                       |
| Table | 281. | A/D Sequence B Global Data Register<br>(SEQB_GDAT, address 0x4001 C014) bit                       |
|       |      | description                                                                                       |
| Table | 282. | A/D Data Registers (DAT[0:11], address 0x4001<br>C020 (DAT0) to 0x4001 C04C (DAT11)) bit          |
|       |      | description                                                                                       |
| Table | 283. | A/D Compare Low Threshold register 0<br>(THR0_LOW, address 0x4001 C050) bit                       |
| Table | 284. | description                                                                                       |
|       |      |                                                                                                   |
| Table | 285. | description                                                                                       |
|       |      | address 0x4001 C058) bit description334                                                           |
| Table | 286  | Compare High Threshold register 1<br>(THR1_HIGH, address 0x4001 C05C) bit                         |
|       |      | description                                                                                       |
| Table | 207  |                                                                                                   |
| Iable | 201  | A/D Channel Threshold Select register                                                             |
|       |      | (CHAN_THRSEL, addresses 0x4001 C060) bit                                                          |
|       | _    | description                                                                                       |
| Table | 288. | A/D Interrupt Enable register (INTEN, address                                                     |

| 0x4001 C064 ) bit description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 227                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| Table 289. A/D Flags register (FLAGS, add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |
| C068) bit description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |
| Table 290. A/D Flags register (TRM, addres<br>C06C) bit description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |
| Table 291. Register overview: CRC engine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |
| 0x5000 0000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                      |
| Table 292. CRC mode register (MODE, add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                      |
| 0000) bit description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| Table 293. CRC seed register (SEED, addr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |
| 0004) bit description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| Table 294. CRC checksum register (SUM, a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |
| 0008) bit description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |
| Table 295. CRC data register (WR_DATA, a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |
| 0008) bit description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |
| Table 296. Register overview: FMC (base a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |
| 0000)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |
| Table 297. Flash configuration register (FLA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                      |
| address 0x4004 0010) bit descri                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |
| Table 298. Flash Module Signature Start reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |
| (FMSSTART, 0x4004 0020) bit d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                      |
| Table 299. Flash Module Signature Stop reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                      |
| (FMSSTOP, 0x4004 0024) bit de                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                      |
| Table 300. FMSW0 register bit description (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                      |
| address: 0x4004 002C)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |
| Table 301. LPC83x flash configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 356                  |
| Table 302. Code Read Protection options .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |
| Table 303. Code Read Protection hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | /software            |
| interaction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 050                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                      |
| Table 304. ISP commands allowed for differ<br>359                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                      |
| Table 304. ISP commands allowed for differ 359                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rent CRP levels.     |
| Table 304. ISP commands allowed for differ359Table 305. UART ISP command summary .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rent CRP levels.     |
| Table 304. ISP commands allowed for differ<br>359<br>Table 305. UART ISP command summary .<br>Table 306. UART ISP Unlock command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359<br>Table 305. UART ISP command summary .<br>Table 306. UART ISP Unlock command<br>Table 307. UART ISP Set Baud Rate comm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate comm<br>Table 308. UART ISP Echo command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate comm<br>Table 308. UART ISP Echo commandTable 309. UART ISP Write to RAM command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate comm<br>Table 308. UART ISP Echo commandTable 309. UART ISP Write to RAM commany<br>Table 310. UART ISP Read Memory comm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate commTable 308. UART ISP Echo commandTable 309. UART ISP Write to RAM commandTable 301. UART ISP Write to RAM commandTable 310. UART ISP Read Memory commTable 311. UART ISP Prepare sector(s) for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate commTable 308. UART ISP Echo commandTable 309. UART ISP Write to RAM commaTable 310. UART ISP Read Memory commTable 311. UART ISP Prepare sector(s) for<br>command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary .Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate commTable 308. UART ISP Echo commandTable 309. UART ISP Write to RAM commandTable 310. UART ISP Read Memory commTable 311. UART ISP Prepare sector(s) for<br>command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary.<br>Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate comm<br>Table 308. UART ISP Echo command<br>Table 309. UART ISP Write to RAM comma<br>Table 310. UART ISP Read Memory comm<br>Table 311. UART ISP Prepare sector(s) for<br>commandTable 312. UART ISP Copy RAM to flash comma<br>Table 313. UART ISP Go command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ<br>359Table 305. UART ISP command summary<br>Table 306. UART ISP Unlock commandTable 307. UART ISP Set Baud Rate comm<br>Table 308. UART ISP Echo commandTable 309. UART ISP Echo commandTable 309. UART ISP Write to RAM comma<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rent CRP levels.<br> |
| Table 304. ISP commands allowed for differ         359         Table 305. UART ISP command summary.         Table 306. UART ISP Unlock command         Table 307. UART ISP Set Baud Rate comm         Table 308. UART ISP Echo command         Table 309. UART ISP Echo command         Table 309. UART ISP Echo command         Table 309. UART ISP Read Memory comm         Table 310. UART ISP Read Memory comm         Table 311. UART ISP Prepare sector(s) for         command         Table 312. UART ISP Copy RAM to flash command         Table 313. UART ISP Go command         Table 314. UART ISP Erase sector command         Table 315. UART ISP Blank check sector command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate command and a set of the set of th</li></ul> | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender Table 308. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commender Table 310. UART ISP Read Memory commender Table 311. UART ISP Read Memory commend</li> <li>Table 312. UART ISP Copy RAM to flash command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Erase sector command.</li> <li>Table 315. UART ISP Blank check sector command.</li> <li>Table 316. UART ISP Read Part Identificati</li> <li>Table 317. Part identification numbers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender Table 308. UART ISP Set Baud Rate commender Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commender Table 310. UART ISP Read Memory commender Table 311. UART ISP Read Memory commender Table 312. UART ISP Copy RAM to flash command</li> <li>Table 312. UART ISP Go command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Erase sector command Table 315. UART ISP Blank check sector command Table 316. UART ISP Read Part Identificati</li> <li>Table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code version</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender 309. UART ISP Set Baud Rate commender 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commender 310. UART ISP Read Memory commender 311. UART ISP Read Memory commender 312. UART ISP Prepare sector(s) for command</li> <li>Table 312. UART ISP Copy RAM to flash commender 313. UART ISP Go command</li> <li>Table 313. UART ISP Erase sector commender 314. UART ISP Erase sector commender 315. UART ISP Blank check sector commender 316. UART ISP Read Part Identification 1000 and 10000 and 1000 and 1000 and 1000 and 1000 and 1000</li></ul>                 | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender Table 308. UART ISP Set Baud Rate commender Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 310. UART ISP Read Memory commender Table 311. UART ISP Read Memory commender Table 312. UART ISP Prepare sector(s) for command</li> <li>Table 312. UART ISP Copy RAM to flash command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Erase sector command table 315. UART ISP Blank check sector command.</li> <li>Table 316. UART ISP Read Part Identificati</li> <li>Table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code verse command</li> <li>Table 319. UART ISP Compare command.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commere Table 308. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commere Table 310. UART ISP Read Memory commere Table 311. UART ISP Read Memory commere Table 312. UART ISP Copy RAM to flash command</li> <li>Table 312. UART ISP Go command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Blank check sector command</li> <li>Table 315. UART ISP Read Part Identification Table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code verse command</li> <li>Table 319. UART ISP Compare command.</li> <li>Table 319. UART ISP Compare command.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commere Table 308. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commere Table 310. UART ISP Read Memory commere Table 311. UART ISP Read Memory commere Table 312. UART ISP Copy RAM to flash command</li> <li>Table 312. UART ISP Go command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Erase sector command table 315. UART ISP Blank check sector command.</li> <li>Table 316. UART ISP Read Part Identification table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code verse command.</li> <li>Table 319. UART ISP Compare command.</li> <li>Table 319. UART ISP ReadUID command.</li> <li>Table 320. UART ISP Read CRC checksum</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commere Table 308. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commere Table 310. UART ISP Read Memory commere Table 311. UART ISP Read Memory commere Table 312. UART ISP Copy RAM to flash command</li> <li>Table 312. UART ISP Go command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Erase sector command table 315. UART ISP Blank check sector command.</li> <li>Table 316. UART ISP Read Part Identification table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code verse command.</li> <li>Table 319. UART ISP Compare command.</li> <li>Table 320. UART ISP Read CRC checksum</li> <li>Table 321. UART ISP Read CRC checksum</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commere Table 308. UART ISP Echo command</li> <li>Table 309. UART ISP Echo command</li> <li>Table 309. UART ISP Write to RAM commere Table 310. UART ISP Read Memory commere Table 311. UART ISP Read Memory commere Table 312. UART ISP Copy RAM to flash command</li> <li>Table 312. UART ISP Go command</li> <li>Table 313. UART ISP Go command</li> <li>Table 314. UART ISP Blank check sector command.</li> <li>Table 315. UART ISP Blank check sector command.</li> <li>Table 316. UART ISP Read Part Identification table 317. Part identification numbers</li> <li>Table 318. UART ISP Read Boot Code vers command.</li> <li>Table 319. UART ISP Read CRC checksum</li> <li>Table 320. UART ISP Read CRC checksum</li> <li>Table 322. UART ISP Return Codes Summer</li> <li>Table 323. IAP Command Summary</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender and the set of the set o</li></ul> | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender and the set of the set o</li></ul> | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender and the set of the set o</li></ul> | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender and the set of the set o</li></ul> | rent CRP levels.<br> |
| <ul> <li>Table 304. ISP commands allowed for difference 359</li> <li>Table 305. UART ISP command summary.</li> <li>Table 306. UART ISP Unlock command</li> <li>Table 307. UART ISP Set Baud Rate commender and the set of the set o</li></ul> | rent CRP levels.<br> |

| Table 329. IAP Read Boot Code version number comm 372 | nand. |
|-------------------------------------------------------|-------|
| Table 330. IAP Compare command.                       |       |
| Table 331. IAP Reinvoke ISP                           |       |
| Table 332. IAP ReadUID command                        |       |
| Table 333. IAP Erase page command                     |       |
| Table 334. IAP Status codes Summary                   |       |
| Table 335. Memory mapping in debug mode               |       |
| Table 336. SWD pin description                        |       |
| Table 337. JTAG boundary scan pin description         |       |
| Table 338. I2C Code example                           |       |
| Table 339. I2C Code example                           |       |
| Table 340. I2C Code example                           |       |
| Table 341. I2C Code example                           |       |
| Table 342. I2C Code example                           |       |
| Table 343. I2C Code example                           |       |
| Table 344. I2C Code example                           |       |
| Table 345. I2C Code example                           |       |
| Table 346. I2C Code example                           |       |
| Table 347. I2C Code example                           |       |
| Table 348. I2C Code example                           |       |
| Table 349. I2C Code example                           |       |
| Table 350. I2C Code example                           |       |
| Table 351. I2C Code example                           |       |
| Table 352. I2C Code example                           |       |
| Table 353. I2C Code example                           |       |
| Table 354. I2C Code example                           | 387   |
| Table 355. SPI Code example                           |       |
| Table 356. SPI Code example                           |       |
| Table 357. SPI Code example                           | 389   |
| Table 358. SPI Code example                           | 389   |
| Table 359. SPI Code example                           | 389   |
| Table 360. SPI Code example                           |       |
| Table 361. SPI Code example                           | 390   |
| Table 362. SPI Code example                           | 390   |
| Table 363. SPI Code example                           | 390   |
| Table 364. SPI Code example                           | 391   |
| Table 365. UART Code example                          | 391   |
| Table 366. UART Code example                          | 391   |
| Table 367. UART Code example                          | 392   |
| Table 368. UART Code example                          |       |
| Table 369. UART Code example                          |       |
| Table 370. UART Code example                          | 392   |
| Table 371. UART Code example                          | 392   |
| Table 372. Abbreviations                              | 393   |
|                                                       |       |

## 27.5 Figures

| Fig 1.   | LPC83x block diagram                               |
|----------|----------------------------------------------------|
| Fig 2.   | LPC83x Memory mapping                              |
| Fig 3.   | Boot process flowchart15                           |
| Fig 4.   | Clock generation                                   |
| Fig 5.   | Start-up timing                                    |
| Fig 6.   | System PLL block diagram55                         |
| Fig 7.   | Example: Connect function U0_RXD and U0_TXD        |
|          | to pins 4 and 14                                   |
| Fig 8.   | Functional diagram of the switch matrix            |
| Fig 9.   | Pin configuration                                  |
| Fig 10.  | Pin interrupt connections                          |
| Fig 11.  | Pattern match engine connections                   |
| Fig 12.  | Pattern match bit slice with detect logic131       |
| Fig 13.  | Pattern match engine examples: sticky edge detect  |
|          | 150                                                |
| Fig 14.  | Pattern match engine examples: Windowed            |
|          | non-sticky edge detect evaluates as true151        |
| Fig 15.  | Pattern match engine examples: Windowed            |
| 1 ig 10. | non-sticky edge detect evaluates as false 151      |
| Fig 16.  | SCT input multiplexing                             |
| Fig 17.  | DMA trigger multiplexing                           |
| Fig 18.  | DMA tingger multiplexing                           |
| •        | USART clocking                                     |
| Fig 19.  |                                                    |
| Fig 20.  | USART block diagram                                |
| Fig 21.  | <b>v</b>                                           |
| Fig 22.  | SPI clocking                                       |
| Fig 23.  | SPI block diagram                                  |
| Fig 24.  | Basic SPI operating modes                          |
| Fig 25.  | Pre_delay and Post_delay218                        |
| Fig 26.  | Frame_delay                                        |
| Fig 27.  | Transfer_delay                                     |
| Fig 28.  | Examples of data stalls                            |
| Fig 29.  | I2C clocking                                       |
| Fig 30.  | I2C block diagram                                  |
| Fig 31.  | SCT clocking                                       |
| Fig 32.  | SCT connections                                    |
| Fig 33.  | SCTimer/PWM block diagram                          |
| Fig 34.  | SCTimer/PWM counter and select logic254            |
| Fig 35.  | SCT event configuration and selection registers258 |
| Fig 36.  | Match logic                                        |
| Fig 37.  | Capture logic                                      |
| Fig 38.  | Event selection                                    |
| Fig 39.  | Output slice i                                     |
| Fig 40.  | SCT interrupt generation                           |
| Fig 41.  | SCT configuration example                          |
| Fig 42.  | WWDT clocking                                      |
| Fig 43.  | Windowed Watchdog timer block diagram291           |
| Fig 44.  | Early watchdog feed with windowed mode enabled     |
| U        | 298                                                |
| Fig 45.  | Correct watchdog feed with windowed mode           |
| 3.51     | enabled                                            |
| Fig 46.  | Watchdog warning interrupt                         |
| Fig 47.  | WKT clocking                                       |
| Fig 48.  | MRT clocking                                       |
| Fig 49.  | MRT block diagram                                  |
| Fig 50.  | System tick timer block diagram                    |
| -        |                                                    |
| UM11021  | All information provided in this doo               |

| Fig 51. | ADC clocking                              |
|---------|-------------------------------------------|
| Fig 52. | ADC block diagram                         |
| Fig 53. | CRC block diagram                         |
| Fig 54. | IAP parameter passing                     |
| Fig 55. | Connecting the SWD pins to a standard SWD |
|         | connector                                 |

#### **Chapter 27: Supplementary information**

## **27.6 Contents**

3.5

| Cha | Chapter 1: LPC83x Introductory information |       |                                   |    |  |
|-----|--------------------------------------------|-------|-----------------------------------|----|--|
| 1.1 | Introduction 3                             | 1.4   | General description               | 8  |  |
| 1.2 | Features 3                                 | 1.4.1 | ARM Cortex-M0+ core configuration | 8  |  |
| 1.3 | Ordering options 7                         | 1.5   | Block diagram                     |    |  |
| Cha | pter 2: LPC83x memory mapping              |       |                                   |    |  |
| 2.1 | How to read this chapter                   | 2.2.1 | Memory mapping                    | 11 |  |
| 2.2 | General description                        |       | Micro Trace Buffer (MTB)          | 11 |  |
| Cha | pter 3: LPC83x Boot ROM                    |       |                                   |    |  |
| 3.1 | How to read this chapter                   | 3.5.1 | Bootloader                        | 12 |  |
| 3.2 | Features 12                                | 3.6   | Functional description            | 13 |  |
| 3.3 | Basic configuration 12                     | 3.6.1 | Memory map after any reset        |    |  |
| 3.4 | Pin description 12                         | 3.6.2 | Boot process                      | 13 |  |

## Chapter 4: LPC83x Nested Vectored Interrupt Controller (NVIC)

General description ..... 12

| <ul> <li>4.1</li> <li>4.2</li> <li>4.3</li> <li>4.3.2</li> <li>4.3.3</li> <li>4.4</li> <li>4.4.1</li> <li>4.4.2</li> <li>4.4.3</li> </ul> | How to read this chapter16Features16General description16Interrupt sources16Non-Maskable Interrupt (NMI)18Vector table offset18Register description19Interrupt Set Enable Register 0 register 20Interrupt clear enable register 021Interrupt Set Pending Register 0 register 22 | 4.4.4<br>4.4.5<br>4.4.6<br>4.4.7<br>4.4.8<br>4.4.9<br>4.4.10<br>4.4.11<br>4.4.12 | Interrupt Clear Pending Register 0 register23Interrupt Active Bit Register 024Interrupt Priority Register 025Interrupt Priority Register 225Interrupt Priority Register 326Interrupt Priority Register 426Interrupt Priority Register 526Interrupt Priority Register 527Interrupt Priority Register 727 |
|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

3.6.3

## Chapter 5: LPC83x System configuration (SYSCON)

| <b>5.1</b><br><b>5.2</b><br><b>5.3</b><br>5.3.1<br>5.3.2<br>5.3.3              | How to read this chapter28Features28Basic configuration28Set up the PLL28Configure the main clock and system clock29Set up the system oscillator using XTALIN and<br>XTALOUT29                                                        | 5.6.7<br>5.6.8<br>5.6.9<br>5.6.10<br>5.6.11<br>5.6.12<br>5.6.13<br>5.6.14    | Internal resonant crystal control register<br>System reset status register<br>System PLL clock source select register<br>Main clock source select register<br>Main clock source update enable register<br>System clock divider register<br>System clock control register                                                                              | 39<br>39<br>40<br>40<br>40<br>41 |
|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 5.4                                                                            | Pin description 30                                                                                                                                                                                                                    |                                                                              |                                                                                                                                                                                                                                                                                                                                                       |                                  |
| <b>5.5</b><br>5.5.1<br>5.5.2<br>5.5.3<br>5.5.4<br><b>5.6</b><br>5.6.1<br>5.6.2 | General description30Clock generation30Power control of analog components31Configuration of reduced power-modes32Reset and interrupt control32Register description32System memory remap register34Peripheral reset control register34 | 5.6.15<br>5.6.16<br>5.6.17<br>5.6.18<br>5.6.19<br>5.6.20<br>5.6.21<br>5.6.22 | USART clock divider register<br>CLKOUT clock source select register<br>CLKOUT clock source update enable register<br>CLKOUT clock divider register<br>USART fractional generator divider value<br>register<br>USART fractional generator multiplier value<br>register<br>External trace buffer command register<br>POR captured PIO status register 0 | 43<br>44<br>44<br>44<br>45<br>45 |
| 5.6.3<br>5.6.4<br>5.6.5<br>5.6.6                                               | System PLL control register       36         System PLL status register       36         System oscillator control register       36         Watchdog oscillator control register       37                                            | 5.6.23<br>5.6.24                                                             | IOCON glitch filter clock divider registers 6<br>to 0                                                                                                                                                                                                                                                                                                 | 46                               |

## **Chapter 27: Supplementary information**

| 5.6.25 | System tick counter calibration register        | 47 | 5.7.2     | Start-up behavior                 | 54 |
|--------|-------------------------------------------------|----|-----------|-----------------------------------|----|
| 5.6.26 | IRQ latency register                            | 47 | 5.7.3     | Brown-out detection               | 55 |
| 5.6.27 | NMI source selection register                   | 48 | 5.7.4     | System PLL functional description | 55 |
| 5.6.28 | Pin interrupt select registers                  | 48 | 5.7.4.1   | Lock detector                     | 56 |
| 5.6.29 | Start logic 0 pin wake-up enable register       | 49 | 5.7.4.2   | Power-down control                | 56 |
| 5.6.30 | Start logic 1 interrupt wake-up enable register | 50 | 5.7.4.3   | Divider ratio programming         | 56 |
| 5.6.31 | Deep-sleep mode configuration register          | 50 | 5.7.4.3.1 | Post divider                      | 56 |
| 5.6.32 | Wake-up configuration register                  | 51 | 5.7.4.3.2 | Feedback divider                  | 56 |
| 5.6.33 | Power configuration register                    | 52 | 5.7.4.3.3 | Changing the divider values       | 56 |
| 5.6.34 | Device ID register                              | 53 |           | Frequency selection               |    |
| 5.7    | Functional description                          | 53 | 5.7.4.4.1 | Normal mode                       | 57 |
| 5.7.1  | Reset                                           | 53 | 5.7.4.4.2 | PLL Power-down mode               | 58 |

## Chapter 6: LPC83x Reduced power modes and power management

| 6.1     | How to read this chapter 59           |
|---------|---------------------------------------|
| 6.2     | Features 59                           |
| 6.3     | Basic configuration 59                |
| 6.3.1   | Low power modes in the ARM Cortex-M0+ |
|         | core 59                               |
| 6.3.1.1 | System control register 59            |
| 6.4     | Pin description 60                    |
| 6.5     | General description 61                |
| 6.5.1   | Wake-up process 62                    |
| 6.6     | Register description 63               |
| 6.6.1   | Power control register                |
| 6.6.2   | General purpose registers 0 to 3 64   |
| 6.6.3   | Deep power-down control register 65   |
| 6.7     | Functional description                |
| 6.7.1   | Power management 66                   |
| 6.7.2   | Reduced power modes and WWDT lock     |
|         | features 67                           |
| 6.7.3   | Active mode 67                        |
| 6.7.3.1 | Power configuration in Active mode 67 |
| 6.7.4   | Sleep mode 67                         |
| 6.7.4.1 | Power configuration in Sleep mode 68  |

## Chapter 7: LPC83x Switch matrix (SWM)

| 7.1   | How to read this chapter                       |
|-------|------------------------------------------------|
| 7.2   | Features 73                                    |
| 7.3   | Basic configuration 73                         |
| 7.3.1 | Connect an internal signal to a package pin 74 |
| 7.3.2 | Enable an analog input or other special        |
|       | function                                       |
| 7.3.3 | Changing the pin function assignment 75        |
| 7.4   | General description                            |
| 7.4.1 | Movable functions                              |
| 7.4.2 | Switch matrix register interface 78            |

| 6.7.4.2 | Programming Sleep mode                      |
|---------|---------------------------------------------|
| 6.7.4.3 | Wake-up from Sleep mode 68                  |
| 6.7.5   | Deep-sleep mode 68                          |
| 6.7.5.1 | Power configuration in Deep-sleep mode 68   |
| 6.7.5.2 | Programming Deep-sleep mode                 |
| 6.7.5.3 | Wake-up from Deep-sleep mode 69             |
| 6.7.6   | Power-down mode 69                          |
| 6.7.6.1 | Power configuration in Power-down mode 70   |
| 6.7.6.2 | Programming Power-down mode                 |
| 6.7.6.3 | Wake-up from Power-down mode                |
| 6.7.7   | Deep power-down mode 71                     |
| 6.7.7.1 | Power configuration in Deep power-down      |
|         | mode                                        |
| 6.7.7.2 | Programming Deep power-down mode using the  |
|         | WAKEUP pin: 71                              |
| 6.7.7.3 | Wake-up from Deep power-down mode using the |
|         | WAKEUP pin:                                 |
| 6.7.7.4 | Programming Deep power-down mode using the  |
|         | self-wake-up timer:                         |
| 6.7.7.5 | Wake-up from Deep power-down mode using the |
|         | self-wake-up timer:72                       |
|         |                                             |

| 7.5    | Register description   | 78 |
|--------|------------------------|----|
| 7.5.1  | Pin assign register 0  | 79 |
| 7.5.2  | Pin assign register 1  | 80 |
| 7.5.3  | Pin assign register 3  | 80 |
| 7.5.4  | Pin assign register 4  | 80 |
| 7.5.5  | Pin assign register 5  | 81 |
| 7.5.6  | Pin assign register 6  | 81 |
| 7.5.7  | Pin assign register 7  | 81 |
| 7.5.8  | Pin assign register 8  | 82 |
| 7.5.9  | Pin assign register 9  | 82 |
| 7.5.10 | Pin assign register 10 |    |

| 7.5.11         | Pin assign register 11 83               | 7.5.12 | PINENABLE 0          |
|----------------|-----------------------------------------|--------|----------------------|
| Chap           | ter 8: LPC83x I/O configuration (IOCON) |        |                      |
| 8.1            | How to read this chapter                | 8.5.9  | PIO0_10 register     |
| 8.2            | Features                                | 8.5.10 | PIO0_16 register 100 |
| 8.3            | Basic configuration                     | 8.5.11 | PIO0_15 register 101 |
| 8.4            | General description                     | 8.5.12 | PIO0_1 register 102  |
| -              | -                                       | 8.5.13 | PIO0_9 register 103  |
| 8.4.1<br>8.4.2 | Pin configuration                       | 8.5.14 | PIO0_8 register 104  |
| 8.4.2<br>8.4.3 | Pin function                            | 8.5.15 | PIO0_7 register 105  |
|                | Pin mode                                | 8.5.16 | PIO0_6 register 106  |
| 8.4.4          | Open-drain mode                         | 8.5.17 | PIO0_0 register 107  |
| 8.4.5          | Analog mode                             | 8.5.18 | PIO0_14 register 108 |
| 8.4.6          | I <sup>2</sup> C-bus mode               | 8.5.19 | PIO0_28 register 109 |
| 8.4.7          | Programmable digital filter 87          | 8.5.20 | PIO0_27 register 110 |
| 8.5            | Register description 88                 | 8.5.21 | PIO0_26 register 111 |
| 8.5.1          | PIO0_17 register 90                     | 8.5.22 | PIO0_25 register 112 |
| 8.5.2          | PIO0_13 register 91                     | 8.5.23 | PIO0_24 register 113 |
| 8.5.3          | PIO0_12 register 92                     | 8.5.24 | PIO0_23 register 114 |
| 8.5.4          | PIO0_5 register                         | 8.5.25 | PIO0_22 register     |
| 8.5.5          | PIO0_4 register                         | 8.5.26 | PIO0_21 register     |
| 8.5.6          | PIO0_3 register                         | 8.5.27 | PIO0_20 register     |
| 8.5.7          | PIO0_2 register                         | 8.5.28 | PIO0_19 register     |
| 8.5.8          | PIO0_11 register 98                     | 8.5.29 | PIO0_18 register     |

9.5.8

9.5.9

9.5.10 9.5.11

9.5.12

9.6

9.6.1

9.6.2 9.6.3

9.6.4

9.6.5

## Chapter 9: LPC83x General Purpose I/O (GPIO)

| 9.1   | How to read this chapter 120       |
|-------|------------------------------------|
| 9.2   | Basic configuration 120            |
| 9.3   | Features 120                       |
| 9.4   | General description 120            |
| 9.5   | Register description 120           |
| 9.5.1 | GPIO port byte pin registers 121   |
| 9.5.2 | GPIO port word pin registers 121   |
| 9.5.3 | GPIO port direction registers 122  |
| 9.5.4 | GPIO port mask registers           |
| 9.5.5 | GPIO port pin registers 122        |
| 9.5.6 | GPIO masked port pin registers 123 |
| 9.5.7 | GPIO port set registers 123        |

## Chapter 10: LPC83x Pin interrupts/pattern match engine

| 10.1   | How to read this chapter 127                                                  |
|--------|-------------------------------------------------------------------------------|
| 10.2   | Features 127                                                                  |
| 10.3   | Basic configuration 127                                                       |
| 10.3.1 | Configure pins as pin interrupts or as inputs to the pattern match engine 128 |
| 10.4   | Pin description 128                                                           |
| 10.5   | General description 128                                                       |

| 10.5.1   | Pin interrupts                          | 129 |
|----------|-----------------------------------------|-----|
| 10.5.2   | Pattern match engine                    | 129 |
| 10.5.2.1 | Inputs and outputs of the pattern match |     |
|          | engine                                  | 131 |
| 10.5.2.2 | Boolean expressions                     | 132 |
| 10.6 F   | Register description                    | 133 |
| 10.6.1   | Pin interrupt mode register             | 133 |

GPIO port clear registers ..... 123

GPIO port direction clear registers. . . . . . 124

GPIO port direction toggle registers. . . . . 124

GPIO output..... 125

GPIO direction ..... 126

Recommended practices ..... 126

Functional description125Reading pin state125

| 10.6.2 | Pin interrupt level or rising edge interrupt enable register |
|--------|--------------------------------------------------------------|
| 10.6.3 | Pin interrupt level or rising edge interrupt set register    |
| 10.6.4 | Pin interrupt level or rising edge interrupt clear           |
| 10.6.5 | register                                                     |
| 10.0.5 | enable register                                              |
| 10.6.6 | Pin interrupt active level or falling edge interrupt         |
| 10.6.7 | set register                                                 |
|        | clear register                                               |
| 10.6.8 | Pin interrupt rising edge register                           |
|        |                                                              |

| 10.6.9  | Pin interrupt falling edge register 137         |
|---------|-------------------------------------------------|
| 10.6.10 | Pin interrupt status register 137               |
| 10.6.11 | Pattern Match Interrupt Control Register 137    |
| 10.6.12 | Pattern Match Interrupt Bit-Slice Source        |
|         | register 138                                    |
| 10.6.13 | Pattern Match Interrupt Bit Slice Configuration |
|         | register 142                                    |
| 10.7    | Functional description 148                      |
| 10.7.1  | Pin interrupts 148                              |
| 10.7.2  | Pattern Match engine example 149                |
| 10.7.3  | Pattern match engine edge detect examples 150   |

## Chapter 11: LPC83x Input multiplexing and DMA trigger multiplexing (INPUT MUX, DMA TRIGMUX)

| 11.1 | How to read this chapter 152 | 11.5.1 | SCT input multiplexing 153                        |
|------|------------------------------|--------|---------------------------------------------------|
| 11.2 | Features 152                 | 11.5.2 | DMA trigger input multiplexing 153                |
| 11.3 | Basic configuration 152      | 11.6   | Register description 154                          |
| 11.4 | Pin description 152          | 11.6.1 | DMA input trigger input mux registers 0 to 17 154 |
| 11.5 | General description 152      | 1162   | DMA trigger input mux input registers 0 to 1 155  |
| 11.5 |                              | 11.6.3 | SCT input mux registers 0 to 3 155                |

## Chapter 12: LPC83x DMA controller

| 12.1   | How to read this chapter 157             |
|--------|------------------------------------------|
| 12.2   | Features 157                             |
| 12.3   | Basic configuration 157                  |
| 12.3.1 | Hardware triggers 157                    |
| 12.3.2 | Trigger outputs 158                      |
| 12.3.3 | DMA requests 158                         |
| 12.3.4 | DMA in sleep mode 159                    |
| 12.4   | Pin description 159                      |
| 12.5   | General description 159                  |
| 12.5.1 | DMA requests and triggers                |
| 12.5.2 | DMA Modes 160                            |
| 12.5.3 | Single buffer 161                        |
| 12.5.4 | Ping-Pong 161                            |
| 12.5.5 | Linked transfers (linked list)           |
| 12.5.6 | Address alignment for data transfers 162 |
| 12.5.7 | Channel chaining 162                     |
| 12.6   | Register description 163                 |
| 12.6.1 | Control register 167                     |

## Chapter 13: LPC83x USART0

| 13.1 | How to read this chapter | 179 |
|------|--------------------------|-----|
| 13.2 | Features                 | 179 |
| 13.3 | Basic configuration      | 179 |

| 12.6.2  | Interrupt Status register                | 167 |
|---------|------------------------------------------|-----|
| 12.6.3  | SRAM Base address register               | 167 |
| 12.6.4  | Enable read and Set registers            | 168 |
| 12.6.5  | Enable Clear register                    | 169 |
| 12.6.6  | Active status register                   | 169 |
| 12.6.7  | Busy status register                     | 169 |
| 12.6.8  | Error Interrupt register                 | 170 |
| 12.6.9  | Interrupt Enable read and Set register   | 170 |
| 12.6.10 | Interrupt Enable Clear register          | 170 |
| 12.6.11 | Interrupt A register                     | 171 |
| 12.6.12 | Interrupt B register                     | 171 |
| 12.6.13 | Set Valid register                       | 171 |
| 12.6.14 | Set Trigger register                     | 172 |
| 12.6.15 | Abort registers                          | 172 |
| 12.6.16 | Channel configuration registers          | 173 |
| 12.6.17 | Channel control and status registers     | 175 |
| 12.6.18 | Channel transfer configuration registers | 176 |
| 12.7    | Functional description                   | 177 |
| 12.7.1  | Trigger operation                        | 177 |
|         |                                          |     |

<sup>13.3.1</sup> Configure the USART clock and baud rate . 180 13.3.2 Configure the USART for wake-up ..... 181 13.3.2.1 Wake-up from Sleep mode ..... 181

| 13.3.2.2 | Wake-up from Deep-sleep or Power-down mode.<br>182 |
|----------|----------------------------------------------------|
| 13.4     | Pin description 182                                |
| 13.5     | General description 183                            |
| 13.6     | Register description 185                           |
| 13.6.1   | USART Configuration register 186                   |
| 13.6.2   | USART Control register 188                         |
| 13.6.3   | USART Status register 190                          |
| 13.6.4   | USART Interrupt Enable read and set                |
|          | register 191                                       |
| 13.6.5   | USART Interrupt Enable Clear register 192          |
| 13.6.6   | USART Receiver Data register 193                   |
| 13.6.7   | USART Receiver Data with Status register . 194     |
| 13.6.8   | USART Transmitter Data Register 194                |
| 13.6.9   | USART Baud Rate Generator register 195             |
| 13.6.10  | USART Interrupt Status register 196                |

## Chapter 14: LPC83x SPI0/1

| 14.1                       | How to read this chapter 202                                                                    |
|----------------------------|-------------------------------------------------------------------------------------------------|
| 14.2                       | Features 202                                                                                    |
| 14.3                       | Basic configuration 202                                                                         |
| 14.3.1                     | Configure the SPI for wake-up 203                                                               |
| 14.3.1.1                   | Wake-up from Sleep mode 203                                                                     |
| 14.3.1.2                   | Wake-up from Deep-sleep or Power-down                                                           |
|                            | mode 203                                                                                        |
| 14.4                       | Pin description 203                                                                             |
| 14.5                       | General description                                                                             |
|                            |                                                                                                 |
| 14.6                       | Register description   205                                                                      |
| <b>14.6</b><br>14.6.1      | •                                                                                               |
|                            | Register description 205                                                                        |
| 14.6.1                     | Register description205SPI Configuration register206                                            |
| 14.6.1<br>14.6.2           | Register description205SPI Configuration register206SPI Delay register207                       |
| 14.6.1<br>14.6.2<br>14.6.3 | Register description205SPI Configuration register206SPI Delay register207SPI Status register209 |

## Chapter 15: LPC83x I2C0

| 15.1     | How to read this chapter 224            |
|----------|-----------------------------------------|
| 15.2     | Features 224                            |
| 15.3     | Basic configuration 224                 |
| 15.3.1   | I2C transmit/receive in master mode 225 |
| 15.3.1.1 | Master write to slave 226               |
| 15.3.1.2 | Master read from slave 226              |
| 15.3.2   | I2C receive/transmit in slave mode 226  |
| 15.3.2.1 | Slave read from master 227              |
| 15.3.2.2 | Slave write to master 228               |
| 15.3.3   | Configure the I2C for wake-up 228       |
| 15.3.3.1 | Wake-up from Sleep mode                 |

| 13.6.11<br>13.6.12 | USART Oversample selection register | 197<br>197 |
|--------------------|-------------------------------------|------------|
| 13.7 F             | Functional description              | 197        |
| 13.7.1             | Clocking and baud rates             | 197        |
| 13.7.1.1           | Fractional Rate Generator (FRG)     | 198        |
| 13.7.1.2           | Baud Rate Generator (BRG)           | 198        |
| 13.7.1.3           | Baud rate calculations              | 198        |
| 13.7.2             | DMA                                 | 198        |
| 13.7.3             | Synchronous mode                    | 199        |
| 13.7.4             | Flow control                        | 199        |
| 13.7.4.1           | Hardware flow control               | 199        |
| 13.7.4.2           | Software flow control               | 199        |
| 13.7.5             | Autobaud function                   | 199        |
| 13.7.6             | RS-485 support                      | 200        |
| 13.7.7             | Oversampling                        | 200        |

| 14.6.7   | SPI Transmitter Data and Control register 213  |
|----------|------------------------------------------------|
| 14.6.8   | SPI Transmitter Data Register 214              |
| 14.6.9   | SPI Transmitter Control register               |
| 14.6.10  | SPI Divider register 215                       |
| 14.6.11  | SPI Interrupt Status register                  |
| 14.7 F   | Functional description 217                     |
| 14.7.1   | Operating modes: clock and phase selection 217 |
| 14.7.2   | Frame delays                                   |
| 14.7.2.1 | Pre_delay and Post_delay 218                   |
| 14.7.2.2 | Frame_delay 219                                |
| 14.7.2.3 | Transfer_delay 220                             |
| 14.7.3   | Clocking and data rates 221                    |
| 14.7.3.1 | Data rate calculations 221                     |
| 14.7.4   | Slave select                                   |
| 14.7.5   | DMA operation                                  |
| 14.7.6   | Data lengths greater than 16 bits 222          |
| 14.7.7   | Data stalls 222                                |
|          |                                                |

| 15.3.3.2 | Wake-up from Deep-sleep and Power-down |     |
|----------|----------------------------------------|-----|
|          | modes                                  | 228 |
| 15.4     | Pin description                        | 229 |
| 15.5     | General description                    | 229 |
| 15.6     | Register description                   | 230 |
| 15.6.1   | I2C Configuration register             | 231 |
| 15.6.2   | I2C Status register                    | 233 |
| 15.6.3   | Interrupt Enable Set and read register | 237 |
| 15.6.4   | Interrupt Enable Clear register        | 238 |
| 15.6.5   | Time-out value register                | 239 |
| 15.6.6   | Clock Divider register                 | 240 |
|          |                                        |     |

**UM11021** 

| 15.6.7  | Interrupt Status register 241          |
|---------|----------------------------------------|
| 15.6.8  | Master Control register 241            |
| 15.6.9  | Master Time 242                        |
| 15.6.10 | Master Data register 244               |
| 15.6.11 | Slave Control register 244             |
| 15.6.12 | Slave Data register 245                |
| 15.6.13 | Slave Address registers 245            |
| 15.6.14 | Slave address Qualifier 0 register 246 |
| 15.6.15 | Monitor data register 247              |

## Chapter 16: LPC83x SCTimer/PWM

| 16.1     | How to read this chapter 250                       |
|----------|----------------------------------------------------|
| 16.2     | Features                                           |
| 16.3     | Basic configuration 251                            |
| 16.4     | Pin description                                    |
| 16.5     | General description                                |
| 16.6     | Register description 254                           |
| 16.6.1   | Register functional grouping                       |
| 16.6.1.1 | Counter configuration and control registers . 259  |
| 16.6.1.2 | Event configuration registers 259                  |
| 16.6.1.3 |                                                    |
| 16.6.1.4 | Event select registers for the counter             |
|          | operations                                         |
| 16.6.1.5 | Event select registers for setting or clearing the |
|          | outputs 260                                        |
| 16.6.1.6 | Event select registers for capturing a counter     |
|          | value 260                                          |
| 16.6.1.7 |                                                    |
|          | transfers 260                                      |
| 16.6.1.8 |                                                    |
| 16.6.1.9 | ······································             |
|          | by software 260                                    |
| 16.6.2   | SCT configuration register 261                     |
| 16.6.3   | SCT control register 262                           |
| 16.6.4   | SCT limit event select register 264                |
| 16.6.5   | SCT halt event select register 265                 |
| 16.6.6   | SCT stop event select register 265                 |
| 16.6.7   | SCT start event select register 266                |
| 16.6.8   | SCT counter register 266                           |
| 16.6.9   | SCT state register                                 |
| 16.6.10  | SCT input register                                 |
| 16.6.11  | SCT match/capture mode register 268                |
| 16.6.12  | SCT output register 269                            |
| 16.6.13  | SCT bi-directional output control register 270     |
| 16.6.14  | SCT conflict resolution register 270               |
| 16.6.15  | SCT DMA request 0 and 1 registers 272              |
| 16.6.16  | SCT event interrupt enable register 272            |
| 16.6.17  | SCT event flag register                            |
| 16.6.18  | SCT conflict interrupt enable register 273         |
|          |                                                    |

| 15.7     | Functional description              | 247 |
|----------|-------------------------------------|-----|
| 15.7.1   | Bus rates and timing considerations | 247 |
| 15.7.1.1 | Rate calculations                   | 248 |
| 15.7.2   | Time-out                            | 248 |
| 15.7.3   | Ten-bit addressing                  | 248 |
| 15.7.4   | Clocking and power considerations   | 249 |
| 15.7.5   | Interrupt handling                  | 249 |
| 15.7.6   | DMA                                 | 249 |
|          |                                     |     |

| 16.6.19              | SCT conflict flag register 273                                                 |
|----------------------|--------------------------------------------------------------------------------|
| 16.6.20              | SCT match registers 0 to 7                                                     |
|                      | (REGMODEn bit = 0)                                                             |
| 16.6.21              | SCT capture registers 0 to 7                                                   |
|                      | (REGMODEn bit = 1)                                                             |
| 16.6.22              | SCT match reload registers 0 to 7 (REGMODEn                                    |
| 40.0.00              | bit = 0) 274                                                                   |
| 16.6.23              | SCT capture control registers 0 to 7 (REGMODEn bit = 1)                        |
| 16.6.24              | bit = 1)                                                                       |
| 16.6.25              | SCT event control registers 0 to 7 276                                         |
| 16.6.26              | SCT output set registers 0 to 5 277                                            |
| 16.6.27              | SCT output clear registers 0 to 5                                              |
|                      | unctional description                                                          |
| 16.7.1               | Match logic                                                                    |
| 16.7.2               | Capture logic                                                                  |
| 16.7.3               | Event selection                                                                |
| 16.7.4               | Output generation                                                              |
| 16.7.5               | State logic 280                                                                |
| 16.7.6               | Interrupt generation                                                           |
| 16.7.7               | Clearing the prescaler 281                                                     |
| 16.7.8               | Match vs. I/O events 281                                                       |
| 16.7.9               | SCT operation 283                                                              |
| 16.7.10              | Configure the SCT 283                                                          |
| 16.7.10.1            | Configure the counter 283                                                      |
|                      | Configure the match and capture registers . 283                                |
|                      | Configure events and event responses 284                                       |
|                      | Configure multiple states 285                                                  |
| 16.7.10.5<br>16.7.11 |                                                                                |
| 16.7.11              | Run the SCT       285         Configure the SCT without using states       286 |
| 16.7.12              | SCT PWM Example                                                                |
| 10.7.13              |                                                                                |

UM11021

## Chapter 17: LPC83x Windowed Watchdog Timer (WWDT)

| 17.1<br>17.2<br>17.3<br>17.4<br>17.5<br>17.5.1<br>17.5.2<br>17.5.3 | How to read this chapter.         Features         Basic configuration         Pin description.         General description         Block diagram.         Clocking and power control         Using the WWDT lock features. | <ul> <li>289</li> <li>289</li> <li>290</li> <li>291</li> <li>291</li> <li>293</li> </ul> | <b>17.6</b><br>17.6.1<br>17.6.2<br>17.6.3<br>17.6.4<br>17.6.5<br>17.6.6 | Changing the WWDT reload value<br>Register description | 294<br>296<br>296<br>297<br>297<br>297 |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------|
| 17.5.3.                                                            | •                                                                                                                                                                                                                           |                                                                                          | 17.7                                                                    | Functional description                                 | 298                                    |

#### Chapter 18: LPC83x Self-wake-up timer (WKT)

| 18.1 | How to read this chapter 299 |
|------|------------------------------|
| 18.2 | Features                     |
| 18.3 | Basic configuration          |
| 18.4 | Pin description 300          |

#### Chapter 19: LPC83x Multi-Rate Timer (MRT)

| 19.1   | How to read this chapter 303 |  |
|--------|------------------------------|--|
| 19.2   | Features 303                 |  |
| 19.3   | Basic configuration 303      |  |
| 19.4   | Pin description 303          |  |
| 19.5   | General description 303      |  |
| 19.5.1 | Repeat interrupt mode 304    |  |
| 19.5.2 | One-shot interrupt mode      |  |
| 19.5.3 | One-shot bus stall mode      |  |

#### Chapter 20: LPC83x System tick timer (SysTick)

| 20.1 | How to read this chapter 310 | 20.6.1 |
|------|------------------------------|--------|
| 20.2 | Features 310                 | 20.6.2 |
| 20.3 | Basic configuration          | 20.6.3 |
|      | 5                            | 20.6.4 |
| 20.4 | Pin description 310          |        |
| 20.5 | General description          | 20.7   |
|      | -                            | 20.7.1 |
| 20.6 | Register description 311     |        |

| Chapter 21: 12-bit Analog-to-Digital Converter (ADC) | C) |
|------------------------------------------------------|----|
|------------------------------------------------------|----|

| 21.1                  | How to read this chapter                                                                                 | 21.3.2                | 1 55 ,                                        |
|-----------------------|----------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------------------------|
| 21.2                  | Features 314                                                                                             |                       | an external pin 316                           |
| <b>21.3</b><br>21.3.1 | Basic configuration       314         Perform a single ADC conversion using a software trigger       315 | 21.3.3<br>21.3.4      | ADC hardware trigger inputs                   |
|                       |                                                                                                          | <b>21.4</b><br>21.4.1 | Pin description317ADC vs. digital receiver318 |

#### continued >>

| 19.6   | Register description           | 305 |
|--------|--------------------------------|-----|
| 19.6.1 | Time interval register         | 306 |
| 19.6.2 | Timer register                 | 307 |
| 19.6.3 | Control register               | 307 |
| 19.6.4 | Status register                | 308 |
| 19.6.5 | Idle channel register          | 308 |
| 19.6.6 | Global interrupt flag register | 309 |
|        |                                |     |

System Timer Control and status register ... 311

System Timer Reload value register ..... 312

System Timer Current value register ..... 312 System Timer Calibration value register ... 313

Functional description ..... 313

Example timer calculation ..... 313

18.5 General description ..... 300 18.5.1 WKT clock sources ..... 300 Register description ...... 301 18.6 18.6.1 Control register ..... 301 18.6.2 

339

#### **Chapter 27: Supplementary information**

A/D Interrupt Enable Register ..... 336

Hardware-triggered conversion ..... 342

Avoiding spurious hardware triggers ..... 342

Threshold-Compare Out-of-Range Interrupt 344

Optional operating modes ..... 344

Hardware Trigger Source Selection ...... 345

Conversion-Complete or Sequence-Complete interrupts ..... 343

Functional description ..... 341 Conversion Sequences ..... 341

A/D Flag register .....

| 21.5   | General description 319                              |
|--------|------------------------------------------------------|
| 21.6   | Register description 319                             |
| 21.6.1 | ADC Control Register 321                             |
| 21.6.2 | A/D Conversion Sequence A Control Register           |
|        |                                                      |
| 21.6.3 | A/D Conversion Sequence B Control Register           |
|        |                                                      |
| 21.6.4 | A/D Global Data Register A and B                     |
|        |                                                      |
| 21.6.5 | A/D Channel Data Registers 0 to 11                   |
|        |                                                      |
| 21.6.6 | A/D Compare Low Threshold Registers 0 and 1 .<br>333 |
| 21.6.7 | A/D Compare High Threshold Registers 0 and 1         |
|        |                                                      |
| 21.6.8 | A/D Channel Threshold Select register 335            |

## Chapter 22: LPC83x CRC engine

| 22.1<br>22.2<br>22.3<br>22.4<br>22.5<br>22.6 | How to read this chapter3Features3Basic configuration3Pin description3General description3Register description3 | 346<br>346<br>346<br>346 | 22.6.3<br>22.6.4<br><b>22.7</b><br>22.7.1<br>22.7.2 | CRC checksum register<br>CRC data register<br>Functional description<br>CRC-CCITT set-up<br>CRC-16 set-up | 348<br>349<br><b>349</b><br>349<br>349 |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------|
| <b>22.6</b><br>22.6.1                        | Register description       3         CRC mode register       3                                                  | 348                      | 22.7.2<br>22.7.3                                    | CRC-16 set-up<br>CRC-32 set-up                                                                            |                                        |

21.6.9

21.6.10

21.6.11

21.7

21.7.1 21.7.2

21.7.2.1

21.7.3

21.7.4

21.7.4.1

21.7.4.2

21.7.4.3

21.7.5

21.7.6

21.7.7

#### Chapter 23: LPC83x Flash controller

| 23.1   | How to read this chapter                  |    |          |                            |     |
|--------|-------------------------------------------|----|----------|----------------------------|-----|
| 23.2   | Features 35                               | 51 | 23.5     | Functional description     | 352 |
| 23.3   | General description 35                    | 51 | 23.5.1   | Flash signature generation | 352 |
| 23.4   | Register description 35                   | 51 | 23.5.1.1 |                            |     |
| 23.4.1 | Flash configuration register              | 51 |          | registers                  | 353 |
| 23.4.2 | Flash signature start address register 35 |    | 23.5.1.2 | Signature generation       | 353 |
| -      |                                           |    | 23.5.1.3 | Content verification       | 353 |
| 23.4.3 | Flash signature stop address register 35  | 52 |          |                            |     |

## Chapter 24: LPC83x Flash In-System and In-Application Programming (ISP and IAP)

| 24.1     | How to read this chapter               |
|----------|----------------------------------------|
| 24.2     | Features 355                           |
| 24.3     | Basic configuration 355                |
| 24.4     | Pin description 355                    |
| 24.5     | General description 355                |
| 24.5.1   | Flash configuration                    |
| 24.5.2   | Flash content protection mechanism 356 |
| 24.5.3   | Code Read Protection (CRP)             |
| 24.5.3.1 | I ISP entry protection 359             |
| 24.6     | API description 359                    |

| 24.6.1   | UART ISP commands 359                                                    |
|----------|--------------------------------------------------------------------------|
| 24.6.1.1 | Unlock <unlock code=""> 360</unlock>                                     |
| 24.6.1.2 | Set Baud Rate < Baud Rate > < stop bit > 360                             |
| 24.6.1.3 | Echo <setting> 361</setting>                                             |
| 24.6.1.4 | Write to RAM <start address=""> <number bytes="" of=""></number></start> |
|          | 361                                                                      |
| 24.6.1.5 | Read Memory <address> <number bytes="" of=""></number></address>         |
|          | 361                                                                      |
| 24.6.1.6 | Prepare sector(s) for write operation <start sector<="" td=""></start>   |
|          | number> <end number="" sector=""></end>                                  |

| 24.6.1.7  | Copy RAM to flash <flash address=""> <ram<br>address&gt; <no bytes="" of=""></no></ram<br></flash> | 362 |
|-----------|----------------------------------------------------------------------------------------------------|-----|
| 24.6.1.8  | Go <address> <mode></mode></address>                                                               | 363 |
| 24.6.1.9  | Erase sector(s) <start number="" sector=""> <end< td=""><td></td></end<></start>                   |     |
|           | sector number>                                                                                     | 364 |
| 24.6.1.10 | Blank check sector(s) <sector number=""> <end< td=""><td></td></end<></sector>                     |     |
|           | sector number>                                                                                     | 364 |
| 24.6.1.11 | Read Part Identification number                                                                    | 365 |
| 24.6.1.12 | Read Boot code version number                                                                      | 365 |
| 24.6.1.13 | Compare <address1> <address2></address2></address1>                                                |     |
|           | <no bytes="" of=""></no>                                                                           | 365 |
| 24.6.1.14 | ReadUID                                                                                            | 366 |
| 24.6.1.15 | Read CRC checksum <address></address>                                                              |     |
|           | <no bytes="" of=""></no>                                                                           | 366 |
| 24.6.1.16 | UART ISP Return Codes                                                                              | 367 |
| 24.6.2    | IAP commands                                                                                       | 367 |
| 24.6.2.1  | Prepare sector(s) for write operation (IAP)                                                        | 369 |
| 24.6.2.2  | Copy RAM to flash (IAP)                                                                            | 370 |
| 24.6.2.3  | Erase Sector(s) (IAP)                                                                              | 371 |
| 24.6.2.4  | Blank check sector(s) (IAP)                                                                        | 371 |
| 24.6.2.5  | Read Part Identification number (IAP)                                                              | 371 |
| 24.6.2.6  | Read Boot code version number (IAP)                                                                | 372 |

## Chapter 25: LPC83x Serial Wire Debug (SWD)

| 25.1 | How to read this chapter |  |
|------|--------------------------|--|
| 25.2 | Features 376             |  |
| 25.3 | General description      |  |
| 25.4 | Pin description 376      |  |

## Chapter 26: LPC83x Code examples

| 26.1    | How to read this chapter 380                    |
|---------|-------------------------------------------------|
| 26.2    | Code examples I2C 380                           |
| 26.2.1  | Definitions                                     |
| 26.2.2  | Interrupt handler                               |
| 26.2.3  | Master write one byte to slave                  |
| 26.2.4  | Master read one byte from slave                 |
| 26.2.5  | Master write one byte to subaddress on          |
|         | slave                                           |
| 26.2.6  | Master read one byte from subaddress on         |
|         | slave                                           |
| 26.2.7  | Master receiving nack on address                |
| 26.2.8  | Master receiving nack on data                   |
| 26.2.9  | Master sending nack and stop on data 384        |
| 26.2.10 | Master sending nack and repeated start on       |
|         | data                                            |
| 26.2.11 | Master sending nack and repeated start on data. |
|         | Interrupt mode 385                              |
| 26.2.12 | Slave read one byte from master                 |

## Chapter 27: Supplementary information

**UM11021** 

| 24.6.2.7  | Compare <address1> <address2> <no by<="" of="" th=""><th>tes&gt;</th></no></address2></address1> | tes> |
|-----------|--------------------------------------------------------------------------------------------------|------|
|           | (IAP)                                                                                            | 372  |
| 24.6.2.8  | Reinvoke ISP (IAP)                                                                               | 373  |
| 24.6.2.9  | ReadUID (IAP)                                                                                    | 373  |
| 24.6.2.10 | Erase page                                                                                       | 373  |
| 24.6.2.11 | IAP Status codes                                                                                 | 374  |
| 24.7 F    | Functional description                                                                           | 374  |
| 24.7.1    | UART Communication protocol                                                                      | 374  |
| 24.7.1.1  | UART ISP command format.                                                                         | 374  |
| 24.7.1.2  | UART ISP response format                                                                         | 374  |
| 24.7.1.3  | UART ISP data format                                                                             | 374  |
| 24.7.2    | Memory and interrupt use for ISP and IAP .                                                       | 375  |
| 24.7.2.1  | Interrupts during UART ISP                                                                       | 375  |
| 24.7.2.2  | Interrupts during IAP                                                                            | 375  |
| 24.7.2.3  | RAM used by ISP command handler                                                                  | 375  |
| 24.7.2.4  | RAM used by IAP command handler                                                                  | 375  |
| 24.7.3    | Debugging                                                                                        | 375  |
| 24.7.3.1  | Comparing flash images                                                                           | 375  |
| 24.7.3.2  | Serial Wire Debug (SWD) flash programming                                                        | ļ    |
|           | interface                                                                                        | 375  |

| 25.5   | Functional description    | 377 |
|--------|---------------------------|-----|
| 25.5.1 | Debug limitations         | 377 |
| 25.5.2 | Debug connections for SWD | 377 |
| 25.5.3 | Boundary scan             | 378 |
| 25.5.4 | Micro Trace Buffer (MTB)  | 378 |

| 26.2.13 | Slave write one byte to master                | 386 |
|---------|-----------------------------------------------|-----|
| 26.2.14 | Slave read one byte from master into          |     |
|         | subaddress                                    | 386 |
| 26.2.15 | Slave write one byte to master from           |     |
|         | subaddress                                    | 387 |
| 26.2.16 | Slave nack matched address from master        | 387 |
| 26.2.17 | Slave nack data from master                   | 387 |
| 26.3    | Code examples SPI                             | 388 |
| 26.3.1  | Definitions                                   | 388 |
| 26.3.2  | Interrupt handler                             | 388 |
| 26.3.3  | Transmit one byte to slave 0                  | 389 |
| 26.3.4  | Receive one byte from slave 0                 | 389 |
| 26.3.5  | Transmit and receive a byte to/from slave 0   | 389 |
| 26.3.6  | Transmit and receive 24 bits to/from slave 0  | 390 |
| 26.3.7  | Transmit and receive 24 bits to/from slave 0, |     |
|         | interrupt mode                                | 390 |
| 26.3.8  | Transmit 8 bits to master                     | 390 |
| 26.3.9  | Receive 8 bits to master                      | 390 |
|         |                                               |     |

# UM11021

## **Chapter 27: Supplementary information**

| 26.3.10<br>26.4<br>26.4.1<br>26.4.2<br>26.4.3<br>Chapt | Transmit and receive 24 bits to master<br>Code examples UART<br>Definitions<br>Interrupt handler<br>Transmit one byte of data<br>ter 27: Supplementary information | <b>391</b><br>391<br>391 | 26.4.4<br>26.4.5<br>26.4.6<br>26.4.7 | Receive one byte of data<br>Transmit and receive one byte of data<br>Loop back 10 bytes of data<br>Loop back 10 bytes of data using interrupts | 392<br>392 |
|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 27.1                                                   | Abbreviations                                                                                                                                                      | 393                      | 27.3.3                               | Trademarks                                                                                                                                     | 394        |
| 27.2                                                   | References                                                                                                                                                         | 393                      | 27.4                                 | Tables                                                                                                                                         | 395        |
| 27.3                                                   | Legal information                                                                                                                                                  | 394                      | 27.5                                 | Figures                                                                                                                                        | 402        |
| 27.3.1                                                 | Definitions                                                                                                                                                        | 394                      | 27.6                                 | Contents                                                                                                                                       | 403        |
| 27.3.2                                                 | Disclaimers                                                                                                                                                        | 394                      |                                      |                                                                                                                                                |            |

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

#### © NXP Semiconductors N.V. 2016.

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: 5 October 2016 Document identifier: UM11021