# nRF5340

**Product Specification** 

v1.3



# nRF5340 features

#### Features:

- 1.7 V to 5.5 V supply voltage range
- Package variants
  - aQFN94<sup>™</sup> package, 7 x 7 mm
  - WLCSP95 package, 4.4 x 4.0 mm

#### Application core

- Arm Cortex -M33 with TrustZone technology
  - 128 MHz or 64 MHz operation
  - 514 EEMBC CoreMark score running from flash, 4.0 CoreMark per MHz
  - Single-precision floating-point unit (FPU)
  - Digital signal processing (DSP) instructions
  - Data watchpoint and trace (DWT), embedded trace macrocell (ETM), instrumentation trace macrocell (ITM), and cross trigger interface (CTI)
  - Serial wire debug (SWD)
  - Trace port interface unit (TPIU)
    - 4-bit parallel trace of ITM and ETM trace data
    - Serial wire output (SWO) trace of ITM data
- 1 MB flash and 512 kB low leakage RAM
- Arm TrustZone CryptoCell <sup>™</sup>-312 security subsystem
  - NIST 800-90B, AIS-31, and FIPS 140-2 compliant random number generator
  - AES-128 and 256: ECB, CBC, CMAC/CBC-MAC, CTR, CCM/CCM\*, GCM
  - SHA-1. SHA-2 up to 256 bits
  - Keyed-hash message authentication code (HMAC)
  - RSA public key cryptography with max key size 3072 bits
  - ECC support for most used curves
  - Application key management using derived key model
- Two-way set associative cache towards flash and QSPI XIP code regions
- QSPI peripheral for communicating with an external flash memory device
  - Execute in place with optional on-the-fly encryption and decryption
- Near field communication (NFC-A) tag with wake-on field and touch-to-pair
- Up to 5x SPI master/slave with EasyDMA
- Up to 4x I<sup>2</sup>C compatible two-wire master/slave with EasyDMA
- Up to 4x UART (CTS/RTS) with EasyDMA
- Audio peripherals I<sup>2</sup>S compatible, digital microphone interface (PDM)
- Four pulse width modulator (PWM) units with EasyDMA
- 12-bit, 200 ksps ADC with EasyDMA eight configurable channels with programmable gain
- Three 32-bit timers with counter mode
- Two 24-bit real-time counters (RTC)
- Two Quadrature decoders (QDEC)
- Distributed programmable peripheral interconnect (DPPI)
- Inter-processor communication (IPC)
- Mutually exclusive peripheral (MUTEX)
- USB 2.0 full speed (12 Mbps) controller

- Single 32 MHz crystal operation
- 1.8 V to 3.3 V regulated supply for external components
- Operating temperature from -40°C to 105°C
- 48 general purpose I/O pins

#### Network core

- Arm Cortex-M33
  - 64 MHz operation
  - 244 EEMBC CoreMark score running from flash memory, 101
     CoreMark per mA
  - Cross trigger interface (CTI)
  - Serial wire debug (SWD)
  - SWO trace port
- 256 kB flash and 64 kB low leakage RAM
- Bluetooth 5.2, IEEE 802.15.4-2006, 2.4 GHz enabled transceiver
  - -98 dBm sensitivity in 1 Mbps Bluetooth Low Energy mode
  - -104 dBm sensitivity in 125 kbps Bluetooth Low Energy mode (long range)
  - -101 dBm sensitivity in IEEE 802.15.4
  - -40 dBm to +3 dBm configurable TX power
  - On-air compatible with nRF52, nRF51, nRF24L, and nRF24AP series devices
  - Supported data rates:
    - Bluetooth 5.2 2 Mbps, 1 Mbps, 500 kbps, and 125 kbps
    - IEEE 802.15.4-2006 250 kbps
    - Proprietary 2.4 GHz 2 Mbps, 1 Mbps
  - Angle of Arrival (AoA) and Angle of Departure (AoD) direction finding using *Bluetooth* Low Energy
  - Single-ended antenna output (on-chip balun)
  - 128-bit AES/ECB/CCM/AAR co-processor (on-the-fly packet encryption)
  - 3.2 mA run current in TX (0 dBm)
  - 2.6 mA run current in RX
  - RSSI (1 dB resolution)
- SPI master/slave with EasyDMA
- I<sup>2</sup>C compatible two-wire master/slave with EasyDMA
- UART (CTS/RTS) with EasyDMA
- Three 32-bit timers with counter mode
- Two real-time counters (RTC)
- Temperature sensor
- Distributed programmable peripheral interconnect (DPPI)
- Inter-processor communication (IPC)
- Mutually exclusive peripheral (MUTEX)



4406\_640 v1.3 ii

#### Applications:

- Advanced computer peripherals and I/O devices
  - Multi-touch trackpad
- Advanced wearables
  - Health/fitness sensor and monitor devices
  - Wireless payment enabled devices
- Wireless audio devices
  - Bluetooth Low Energy Audio
  - True wireless earbuds
  - Headphones, microphones, and speakers

- Internet of things (IoT)
  - Smart home sensors and controllers
  - Industrial IoT sensors and controllers
- Interactive entertainment devices
  - Remote controls
  - Gaming controllers
- Professional lighting
  - Wireless connected luminaire



4406\_640 v1.3 iii

# Contents

|    | nRF5340 features                       | . ii         |
|----|----------------------------------------|--------------|
| 1  | Revision history                       | 13           |
| 2  | About this document.                   | 15           |
|    | 2.1 Document status                    | 15           |
|    | 2.2 Peripheral chapters                | 15           |
|    | 2.3 Register tables                    | 15           |
|    | 2.3.1 Fields and values                | 16           |
|    | 2.3.2 Permissions                      |              |
|    | 2.4 Registers                          |              |
|    | 2.4.1 DUMMY                            |              |
| 3  | Product overview.                      | 18           |
|    | 3.1 Block diagram                      | 18           |
|    | 3.2 Memory                             |              |
|    | 3.2.1 RAM — Random access memory       |              |
|    | 3.2.2 Flash — Non-volatile memory      |              |
|    | 3.2.3 XIP — Execute in place           |              |
|    | 3.2.4 Access latency                   | 22           |
| 4  | Power and clock management.            | 23           |
| Т. |                                        |              |
|    | 4.1 System ON mode                     |              |
|    | 4.1.1 Power submodes                   | 24           |
|    | 4.2 System OFF mode                    |              |
|    | 4.2.1 Emulated System OFF mode         |              |
|    | 4.3 Force-OFF mode                     | 25           |
|    | 4.3.1 Emulated Force-OFF mode          | 25           |
|    | 4.4 Current consumption                | 25           |
|    | 4.4.1 Electrical specification         | 28           |
|    | 4.5 Power supply modes and regulators  | 41           |
|    | 4.5.1 Normal voltage mode              | 42           |
|    | 4.5.2 High voltage mode                | 43           |
|    | 4.5.3 Power supply supervisor          | . 43<br>. 46 |
|    | 4.6 POWER — Power control              |              |
|    | 4.6.1 Registers                        | 51           |
|    | 4.7.1 Normal voltage mode              | 51           |
|    | 4.7.2 High voltage mode                | 52           |
|    | 4.7.3 GPIO levels                      | 53           |
|    |                                        | 54           |
|    | 4.7.4 Registers                        | 56           |
|    | 4.7.5 Electrical specification         | 58           |
|    | 4.8 USBREG — USB regulator control     |              |
|    | 4.8.1 Registers                        |              |
|    | 4.8.2 Electrical specification         | 63<br>63     |
|    | 4.9 VREQCTRL — Voltage request control |              |
|    | 4.9.1 Registers                        |              |
|    | 4.9.2 Electrical specification         | 65<br>65     |



4406\_640 v1.3 iv

|   | 4.10.1 Power-on reset                                       | . 66  |
|---|-------------------------------------------------------------|-------|
|   | 4.10.2 Pin reset                                            | . 66  |
|   | 4.10.3 Brownout reset                                       |       |
|   | 4.10.4 Wakeup from System OFF mode reset                    |       |
|   | 4.10.5 Soft reset                                           | 66    |
|   | 4.10.6 Watchdog timer reset                                 |       |
|   | 4.10.7 Network Force-OFF                                    | 67    |
|   | 4.10.8 Retained registers                                   | . 67  |
|   | 4.10.9 Application core reset behavior                      | 67    |
|   | 4.10.10 Network core reset behavior                         | . 68  |
|   | 4.10.11 Registers                                           |       |
|   | 4.10.12 Electrical specification                            |       |
|   | 4.11 CLOCK — Clock control                                  |       |
|   | 4.11.1 HFCLK controller                                     |       |
|   | 4.11.2 LFCLK controller                                     |       |
|   | 4.11.3 Registers                                            |       |
|   | 4.11.4 Electrical specification                             |       |
|   | 4.12 OSCILLATORS — Oscillator control                       |       |
|   |                                                             |       |
|   | 4.12.1 High-frequency (32 MHz) crystal oscillator (HFXO)    |       |
|   | 4.12.2 Low-frequency (32.768 kHz) crystal oscillator (LFXO) |       |
|   | 4.12.3 Low-frequency (32.768 kHz) external source           |       |
|   | 4.12.4 Registers                                            |       |
|   | 4.12.5 Electrical specification                             | . 102 |
|   |                                                             |       |
| 5 | Application core                                            | 105   |
|   | 5.1 Block diagram                                           | . 105 |
|   | 5.2 CPU                                                     |       |
|   | 5.2.1 Floating point interrupt                              |       |
|   | 5.2.2 Electrical specification                              |       |
|   | 5.2.3 CPU and support module configuration                  |       |
|   | 5.3 Memory                                                  |       |
|   | 5.3.1 Peripheral instantiation                              |       |
|   | 5.4 Core components                                         |       |
|   |                                                             |       |
|   | 5.4.1 CACHE — Instruction/data cache                        | 122   |
|   | 5.4.2 FICR — Factory information configuration registers    |       |
|   | 5.4.3 UICR — User information configuration registers       |       |
|   | 5.4.4 AHB multilayer                                        | . 134 |
|   |                                                             |       |
| 6 | Network core                                                | . 136 |
|   | 6.1 Block diagram                                           | . 136 |
|   | 6.2 CPU                                                     |       |
|   | 6.2.1 Electrical specification                              |       |
|   | 6.2.2 CPU and support module configuration                  |       |
|   | 6.3 Memory                                                  |       |
|   | 6.3.1 Peripheral instantiation                              |       |
|   | ·                                                           |       |
|   | 6.4 Core components                                         |       |
|   | 6.4.1 FICR — Factory information configuration registers    |       |
|   | 6.4.2 UICR — User information configuration registers       |       |
|   | 6.4.3 AHB multilayer                                        | . 149 |
|   |                                                             |       |
| 7 | Peripherals                                                 | 150   |
|   | 7.1 Peripheral interface                                    | 150   |
|   | 7.1.1 Peripheral ID                                         |       |
|   |                                                             | 101   |



4406\_640 v1.3 V

| 7.1.2 Peripherals with shared ID                                                         | 152 |
|------------------------------------------------------------------------------------------|-----|
| 7.1.3 Peripheral registers                                                               | 152 |
| 7.1.4 Bit set and clear                                                                  | 152 |
| 7.1.5 Tasks                                                                              | 153 |
| 7.1.6 Events                                                                             | 153 |
| 7.1.7 Publish and subscribe                                                              | 153 |
| 7.1.8 Shortcuts                                                                          | 153 |
| 7.1.9 Interrupts                                                                         | 153 |
| 7.1.10 Secure/non-secure peripherals                                                     | 154 |
| 7.2 EasyDMA                                                                              | 154 |
| 7.2.1 EasyDMA error handling                                                             | 156 |
| 7.2.2 EasyDMA array list                                                                 | 156 |
| 7.3 ACL — Access control lists                                                           | 157 |
| 7.3.1 Registers                                                                          | 158 |
| 7.4 AAR — Accelerated address resolver                                                   | 159 |
| 7.4.1 Shared resources                                                                   | 160 |
| 7.4.2 EasyDMA                                                                            | 160 |
| 7.4.3 Resolving a resolvable address                                                     | 160 |
| 7.4.4 Example                                                                            | 161 |
| 7.4.5 IRK data structure                                                                 | 161 |
| 7.4.6 Registers                                                                          | 161 |
| 7.4.7 Electrical specification                                                           | 167 |
| 7.5 CCM — AES CCM mode encryption                                                        | 167 |
| 7.5.1 Shared resources                                                                   | 168 |
| 7.5.2 Keystream generation                                                               | 168 |
| 7.5.3 Encryption                                                                         | 168 |
| 7.5.4 Decryption                                                                         | 169 |
| 7.5.5 AES CCM and RADIO concurrent operation                                             | 170 |
| 7.5.6 Encrypting packets on-the-fly in radio transmit mode                               | 170 |
| 7.5.7 Decrypting packets on the fly in RADIO receive mode                                | 171 |
| 7.5.8 CCM data structure                                                                 | 172 |
| 7.5.9 EasyDMA and ERROR event                                                            | 173 |
| 7.5.10 Registers                                                                         | 173 |
| 7.5.11 Electrical specification                                                          | 182 |
| 7.6 COMP — Comparator                                                                    | 182 |
| 7.6.1 Shared resources                                                                   | 184 |
| 7.6.2 Differential mode                                                                  | 185 |
| 7.6.3 Single-ended mode                                                                  | 186 |
| 7.6.4 Registers                                                                          | 187 |
| 7.6.5 Electrical specification                                                           | 197 |
| 7.7 CRYPTOCELL — Arm TrustZone CryptoCell 312                                            | 197 |
| 7.7.1 Usage                                                                              | 199 |
| 7.7.2 Direct memory access (DMA)                                                         | 199 |
| 7.7.2 Sheet memory decess (DMA)                                                          | 199 |
| 7.7.4 Registers                                                                          | 200 |
| 7.8 DCNF — Domain configuration                                                          | 200 |
| 7.8.1 Protection                                                                         | 201 |
| 7.8.2 Registers                                                                          | 201 |
| 7.8.2 Registers                                                                          | 202 |
| 7.9 DPP1 — Distributed programmable peripheral interconnect                              | 203 |
| 7.9.2 DPPI controller (DPPIC)                                                            | 204 |
| 7.9.3 Connection examples                                                                | 206 |
| 7.9.4 Special considerations for a system implementing TrustZone for Cortex-M processors | 200 |
| 7.9.4 Special considerations for a system implementing trustzone for Cortex-M processors | 207 |
| / .J NEGISIES                                                                            | ∠U8 |



| 7.10 ECB — AES electronic codebook mode encryption              | 211 |
|-----------------------------------------------------------------|-----|
| 7.10.1 Shared resources                                         | 211 |
| 7.10.2 EasyDMA                                                  | 212 |
| 7.10.3 ECB data structure                                       | 212 |
| 7.10.4 Registers                                                | 212 |
| 7.10.5 Electrical specification                                 | 216 |
| 7.11 EGU — Event generator unit                                 | 216 |
| 7.11.1 Registers                                                | 217 |
| 7.11.2 Electrical specification                                 | 219 |
| 7.12 FPU — Floating point unit (FPU) exceptions                 | 219 |
| 7.12.1 Registers                                                | 220 |
| 7.13 GPIO — General purpose input/output                        | 224 |
| 7.13.1 Assigning pins between cores, peripherals, or subsystems | 225 |
| 7.13.2 Pin configuration                                        | 226 |
| 7.13.3 Pin sense mechanism                                      | 227 |
| 7.13.4 GPIO security                                            | 228 |
| 7.13.5 Registers                                                | 230 |
| 7.13.6 Electrical specification                                 | 234 |
| 7.14 GPIOTE — GPIO tasks and events                             | 235 |
| 7.14.1 Pin events and tasks                                     | 236 |
| 7.14.2 Port event                                               | 237 |
| 7.14.3 Tasks and events pin configuration                       | 237 |
| 7.14.4 Low power                                                | 237 |
| 7.14.5 Registers                                                | 238 |
| 7.14.6 Electrical specification                                 | 243 |
| 7.14.0 Electrical specification 2                               | 243 |
| 7.15.1 Mode                                                     | 244 |
| 7.15.1 Mode: 7.15.1 Mode: 7.15.2 Transmitting and receiving     | 244 |
|                                                                 | 244 |
| 7.15.3 Left right clock (LRCK)                                  | 243 |
| 7.15.4 Serial clock (SCK)                                       |     |
| 7.15.5 Master clock (MCK)                                       | 246 |
| 7.15.6 Width, alignment and format                              | 248 |
| 7.15.7 EasyDMA                                                  | 250 |
| 7.15.8 Module operation                                         | 253 |
| 7.15.9 Pin configuration                                        | 255 |
| 7.15.10 Registers                                               | 255 |
| 7.15.11 Electrical specification                                | 269 |
| 7.16 IPC — Interprocessor communication                         | 269 |
| 7.16.1 IPC and PPI connections                                  | 271 |
| 7.16.2 Registers                                                | 272 |
| 7.16.3 Electrical specification                                 | 275 |
| 7.17 KMU — Key management unit                                  | 275 |
| 7.17.1 Functional view                                          | 276 |
| 7.17.2 Access control                                           | 276 |
| 7.17.3 Protecting the UICR content                              | 277 |
| 7.17.4 Usage                                                    | 277 |
| 7.17.5 Registers                                                | 281 |
| 7.18 LPCOMP — Low-power comparator                              | 285 |
| 7.18.1 Shared resources                                         | 286 |
| 7.18.2 Pin configuration                                        | 287 |
| 7.18.3 Registers                                                | 287 |
| 7.18.4 Electrical specification                                 | 295 |
| 7.19 MUTEX — Mutual exclusive peripheral                        | 295 |
| 7.19.1 Registers                                                | 297 |





| 7.20 NFCT — Near field communication tag | 297 |
|------------------------------------------|-----|
| 7.20.1 Overview                          | 298 |
| 7.20.2 Operating states                  | 300 |
| 7.20.3 Pin configuration                 | 301 |
| 7.20.4 EasyDMA                           | 301 |
|                                          | 302 |
|                                          | 303 |
|                                          | 304 |
|                                          | 305 |
|                                          | 306 |
|                                          | 306 |
|                                          | 307 |
|                                          | 307 |
|                                          | 308 |
|                                          | 308 |
|                                          | 334 |
|                                          | 334 |
|                                          | 334 |
|                                          |     |
|                                          | 335 |
|                                          | 335 |
|                                          | 335 |
|                                          | 335 |
|                                          | 336 |
|                                          | 337 |
| 9                                        | 337 |
| =                                        | 341 |
| '                                        | 341 |
|                                          | 342 |
| 8                                        | 342 |
| !                                        | 343 |
|                                          | 343 |
| ,                                        | 344 |
| 7.22.6 Hardware example                  | 345 |
| 7.22.7 Pin configuration                 | 345 |
| 7.22.8 Registers                         | 346 |
| 7.22.9 Electrical specification          | 355 |
| 7.23 PWM — Pulse width modulation        | 355 |
| 7.23.1 Wave counter                      | 356 |
| 7.23.2 Decoder with EasyDMA              | 359 |
| 7.23.3 Limitations                       | 367 |
| 7.23.4 Pin configuration                 | 367 |
| 7.23.5 Registers                         | 367 |
| 7.24 QDEC — Quadrature decoder           | 378 |
|                                          | 379 |
|                                          | 380 |
|                                          | 380 |
|                                          | 381 |
|                                          | 381 |
| 1 / 1 1                                  | 381 |
|                                          | 382 |
|                                          | 397 |
|                                          | 397 |
|                                          | 398 |
|                                          | 399 |
| 1.23.2 WITHE OPERATION                   | ンフフ |



| 7.25.3 Read operation                                             | 399 |
|-------------------------------------------------------------------|-----|
| 7.25.4 Erase operation                                            | 399 |
| 7.25.5 Execute in place                                           | 399 |
| 7.25.6 Encryption                                                 | 400 |
| 7.25.7 Sending custom instructions                                | 401 |
| 7.25.8 Deep power-down mode                                       | 402 |
| 7.25.9 Instruction set                                            | 402 |
| 7.25.10 Interface description                                     | 403 |
| 7.25.11 Registers                                                 | 409 |
| 7.25.12 Electrical specification                                  | 428 |
| 7.26 RADIO — 2.4 GHz radio                                        | 428 |
| 7.26.1 Packet configuration                                       | 429 |
| 7.26.2 Address configuration                                      | 430 |
| 7.26.3 Data whitening                                             | 431 |
| 7.26.4 CRC                                                        | 431 |
| 7.26.5 Radio states                                               | 432 |
| 7.26.6 Transmit sequence                                          | 432 |
| 7.26.7 Receive sequence                                           | 434 |
| 7.26.8 Received signal strength indicator (RSSI)                  | 435 |
| 7.26.9 Interframe spacing (IFS)                                   | 435 |
| 7.26.10 Device address match                                      | 436 |
| 7.26.11 Bit counter                                               | 437 |
| 7.26.12 Direction finding                                         | 437 |
| 7.26.13 IEEE 802.15.4 operation                                   | 442 |
| 7.26.14 EasyDMA                                                   | 451 |
|                                                                   | 451 |
| 7.26.15 Registers                                                 | 499 |
| 7.26.16 Electrical specification                                  | 505 |
| 7.27 RNG — Random number generator                                | 505 |
|                                                                   | 505 |
| 7.27.2 Speed                                                      |     |
| 7.27.3 Registers                                                  | 505 |
| 7.27.4 Electrical specification                                   | 509 |
| 7.28 RTC — Real-time counter                                      | 509 |
| 7.28.1 Clock source                                               | 509 |
| 7.28.2 Resolution versus overflow and the prescaler               | 509 |
| 7.28.3 Counter register                                           | 510 |
| 7.28.4 Overflow                                                   | 511 |
| 7.28.5 Tick event                                                 | 511 |
| 7.28.6 Event control                                              | 511 |
| 7.28.7 Capture                                                    | 512 |
| 7.28.8 Compare                                                    | 512 |
| 7.28.9 Task and event jitter/delay                                | 515 |
| 7.28.10 Registers                                                 | 517 |
| 7.28.11 Electrical specification                                  | 525 |
| 7.29 SAADC — Successive approximation analog-to-digital converter | 525 |
| 7.29.1 Shared resources                                           | 526 |
| 7.29.2 Overview                                                   | 526 |
| 7.29.3 Digital output                                             | 527 |
| 7.29.4 Analog inputs and channels                                 | 527 |
| 7.29.5 Operation modes                                            | 528 |
| 7.29.6 EasyDMA                                                    | 529 |
| 7.29.7 Resistor ladder                                            | 530 |
| 7.29.8 Reference                                                  | 531 |
| 7.29.9 Acquisition time                                           | 531 |



4406\_640 v1.3 ix

| 7.29.10 Limits event monitoring                                      | 532 |
|----------------------------------------------------------------------|-----|
| 7.29.11 Registers                                                    | 533 |
| 7.29.12 Electrical specification                                     | 550 |
| 7.29.13 Performance factors                                          | 551 |
| 7.30 SPIM — Serial peripheral interface master with EasyDMA          | 551 |
|                                                                      | 552 |
|                                                                      | 553 |
| 7.30.3 Pin configuration                                             | 554 |
| 7.30.4 Shared resources                                              | 555 |
| 7.30.5 EasyDMA                                                       | 555 |
| 7.30.6 Low power                                                     | 555 |
|                                                                      | 556 |
| 7.30.8 Electrical specification                                      | 570 |
|                                                                      | 571 |
| 7.31.1 Shared resources                                              | 572 |
| 7.31.2 EasyDMA                                                       | 572 |
| 7.31.3 SPI slave operation                                           | 573 |
| 7.31.4 Semaphore operation                                           | 574 |
| 7.31.5 Pin configuration                                             | 575 |
| 7.31.6 Registers                                                     | 576 |
| 7.31.7 Electrical specification                                      | 588 |
| 7.31.7 Electrical specification                                      | 590 |
| 7.32.1 General concepts                                              | 590 |
|                                                                      | 590 |
| 7.32.2 Flash access control                                          | 591 |
| 7.32.3 RAM access control                                            | 597 |
| ·                                                                    | 599 |
| 7.32.5 Pin access control                                            | 599 |
| 7.32.6 DPPI access control                                           |     |
| 7.32.7 External domain access control                                | 601 |
| 7.32.8 Arm TrustZone for Cortex-M ID allocation                      | 602 |
| 7.32.9 Registers                                                     | 603 |
| 7.33 SWI — Software interrupts                                       | 614 |
| 9                                                                    | 615 |
| ·                                                                    | 615 |
| <u>e</u>                                                             | 615 |
| 7.34.2 Electrical specification                                      | 622 |
| 7.35 TIMER — Timer/counter                                           | 623 |
| 7.35.1 Capture                                                       | 624 |
| 7.35.2 Compare                                                       | 624 |
| 7.35.3 Task delays                                                   | 624 |
| 7.35.4 Task priority                                                 | 624 |
| 7.35.5 Registers                                                     | 625 |
| 7.35.6 Electrical specification                                      | 632 |
| 7.36 TWIM — $I^2C$ compatible two-wire interface master with EasyDMA | 632 |
| 7.36.1 Shared resources                                              | 634 |
| 7.36.2 EasyDMA                                                       | 634 |
| 7.36.3 Master write sequence                                         | 634 |
| 7.36.4 Master read sequence                                          | 635 |
| 7.36.5 Master repeated start sequence                                | 636 |
| 7.36.6 Low power                                                     | 637 |
| 7.36.7 Master mode pin configuration                                 | 637 |
| 7.36.8 Registers                                                     | 638 |
| 7.36.9 Electrical specification                                      | 652 |
| 7.36.10 Pullup resistor                                              | 653 |



4406\_640 v1.3 X

| 7.37 TWIS — $I^2C$ compatible two-wire interface slave with EasyDMA   | 653        |
|-----------------------------------------------------------------------|------------|
| 7.37.1 Shared resources                                               | 656        |
| 7.37.2 EasyDMA                                                        | 656        |
| 7.37.3 TWIS responding to a read command                              | 656        |
| 7.37.4 TWIS responding to a write command                             | 657        |
| 7.37.5 Master repeated start sequence                                 | 658        |
| 7.37.6 Terminating an ongoing TWI transaction                         | 659        |
| 7.37.7 Low power                                                      | 659        |
| 7.37.8 Slave mode pin configuration                                   | 659        |
| 7.37.9 Registers                                                      | 660        |
| 7.37.10 Electrical specification                                      | 673        |
| 7.38 UARTE — Universal asynchronous receiver/transmitter with EasyDMA | 674        |
| 7.38.1 EasyDMA                                                        | 675        |
| 7.38.2 Transmission                                                   | 675        |
| 7.38.3 Reception                                                      | 676        |
| 7.38.4 Error conditions                                               | 677        |
| 7.38.5 Using the UARTE without flow control                           | 677        |
| 7.38.6 Parity and stop bit configuration                              | 677        |
|                                                                       |            |
| 7.38.7 Low power                                                      | 678        |
| 7.38.8 Pin configuration                                              | 678        |
| 7.38.9 Registers                                                      | 678        |
| 7.38.10 Electrical specification                                      | 696        |
| 7.39 USBD — Universal serial bus device                               | 696        |
| 7.39.1 USB device states                                              | 697        |
| 7.39.2 USB terminology                                                | 698        |
| 7.39.3 USB pins                                                       | 699        |
| 7.39.4 USBD power-up sequence                                         | 699        |
| 7.39.5 USB pull-up                                                    | 700        |
| 7.39.6 USB reset                                                      | 700        |
| 7.39.7 USB suspend and resume                                         | 701        |
| 7.39.8 EasyDMA                                                        | 702        |
| 7.39.9 Control transfers                                              | 703        |
| 7.39.10 Bulk and interrupt transactions                               | 706        |
| 7.39.11 Isochronous transactions                                      | 708        |
| 7.39.12 USB register access limitations                               | 711        |
| 7.39.13 Registers                                                     | 711        |
| 7.39.14 Electrical specification                                      | 740        |
| 7.40 VMC — Volatile memory controller                                 | 740        |
| 7.40.1 RAM power states                                               | 740        |
| 7.40.2 Registers                                                      | 741        |
| 7.41 WDT — Watchdog timer                                             | 743        |
| 7.41.1 Reload criteria                                                | 743        |
| 7.41.2 Temporarily pausing the watchdog                               | 743        |
| 7.41.3 Watchdog reset                                                 | 743        |
| 7.41.4 Stopping the watchdog                                          | 743        |
| 7.41.5 Registers                                                      | 744        |
| 7.41.6 Electrical specification                                       | 750        |
|                                                                       |            |
| Debug and trace.                                                      | 751        |
| 8.1 DAP — Debug access port                                           | 752        |
| 8.1.1 Registers                                                       | 752        |
| 8.1.2 Electrical specification                                        | 753        |
| 8.2 Access port protection                                            | 754        |
| 8.3 Debug Interface mode                                              | 754<br>756 |
| old bedag interface mode                                              | , 50       |



|    | 8.4 Real-time debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 757 |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|    | 8.5 ROM tables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 757 |
|    | 8.6 Cross-trigger network                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 760 |
|    | 8.7 Multidrop serial wire debug                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 762 |
|    | 8.8 Trace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 762 |
|    | 8.9 Enabling the trace port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 763 |
|    | 8.10 CTRL-AP - Control access port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 764 |
|    | 8.10.1 Reset request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 765 |
|    | 8.10.2 Erase all                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 765 |
|    | 8.10.3 Mailbox interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 765 |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
|    | 8.10.4 Disabling erase protection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 766 |
|    | 8.10.5 Disabling access port protection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 766 |
|    | 8.10.6 Debugger registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 767 |
|    | 8.10.7 Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 772 |
|    | 8.11 CTI - Cross Trigger Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 776 |
|    | 8.11.1 Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 776 |
|    | 8.12 TAD - Trace and debug control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 785 |
|    | 8.12.1 Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 785 |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 9  | Hardware and layout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 790 |
|    | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
|    | 9.1 Pin assignments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 790 |
|    | 9.1.1 aQFN94 pin assignments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 791 |
|    | 9.1.2 WLCSP pin assignments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 795 |
|    | 9.2 Mechanical specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 799 |
|    | 9.2.1 aQFN94 7 x 7 mm package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 799 |
|    | 9.2.2 WLCSP package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 800 |
|    | 9.3 Reference circuitry                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 801 |
|    | 9.3.1 Circuit configuration no. 1 for QKAA aQFN94                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 802 |
|    | 9.3.2 Circuit configuration no. 2 for QKAA aQFN94                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 804 |
|    | 9.3.3 Circuit configuration no. 3 for QKAA aQFN94                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 806 |
|    | 9.3.4 Circuit configuration no. 4 for QKAA aQFN94                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 808 |
|    | 9.3.5 Circuit configuration no. 1 for CLAA WLCSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 810 |
|    | 9.3.6 Circuit configuration no. 2 for CLAA WLCSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 812 |
|    | 9.3.7 Circuit configuration no. 3 for CLAA WLCSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 814 |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
|    | 9.3.8 Circuit configuration no. 4 for CLAA WLCSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
|    | 9.3.9 PCB layout example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|    | 9.4 Package thermal characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 820 |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 10 | Recommended operating conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 821 |
|    | 10.1 WLCSP light sensitivity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 821 |
|    | 1012 11 2001 11.6111 10.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11.1111 11 |     |
| 11 | Absolute maximum ratings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 822 |
| 11 | Absolute maximum ratings.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 022 |
| 12 | Ordering information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 824 |
| 12 | Ordering information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 024 |
|    | 12.1 Device marking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 824 |
|    | 12.2 Box labels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 824 |
|    | 12.3 Order code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 825 |
|    | 12.4 Code ranges and values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 826 |
|    | 12.5 Product options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 827 |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 13 | Legal notices                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 829 |



# 1 Revision history

| Date           | Version | Description                                                                                         |
|----------------|---------|-----------------------------------------------------------------------------------------------------|
| October 2022   | 1.3     | The following content has been added or updated:                                                    |
|                |         | OSCILLATORS - Added high-frequency (32 MHz) crystal oscillator (HFXO) equation                      |
|                |         | Mechanical specification - Updated L dimension according to Errata 154                              |
|                |         | <ul> <li>Current consumption on page 25 - Updated COMPOUND10 according<br/>to Errata 152</li> </ul> |
|                |         | QSPI - Updated IFCONFIG0 and DPMDUR register description                                            |
|                |         | RADIO - Updated ED_RSSISCALE                                                                        |
|                |         | GPIO - Added guidance on maximum combined GPIO sink/source current                                  |
|                |         | Editorial changes                                                                                   |
| September 2021 | 1.2     | The following content has been added or updated:                                                    |
|                |         | OSCILLATORS - Updated LFXO internal capacitors description                                          |
|                |         | CLOCK - Added PCLK1M                                                                                |
|                |         | Reference circuitry on page 801 - Updated config. 2 showing circuit enables DCDC                    |
|                |         | Absolute maximum ratings on page 822 - Added NFC antenna pin                                        |
|                |         | current and ANT pin RF input levels; added environmental specifications                             |
|                |         | for WLCSP package                                                                                   |
|                |         | WLCSP package on page 800 - Updated K and L dimensions                                              |
|                |         | SPIM - Updated description of CSNDUR behavior                                                       |
|                |         | Added Package thermal characteristics on page 820                                                   |
|                |         | Added electrical specifications for the following chapters:                                         |
|                |         | • COMP                                                                                              |
|                |         | • VREQCTRL                                                                                          |
|                |         | • USBREG                                                                                            |
|                |         | • RADIO                                                                                             |
| April 2021     | 1.1     | Editorial changes  The fellowing content has been added as undeted.                                 |
| April 2021     | 1.1     | The following content has been added or updated:                                                    |
|                |         | <ul> <li>Added WLCSP package variant information to the following chapters:</li> </ul>              |
|                |         | Pin assignments on page 790                                                                         |
|                |         | Mechanical specifications on page 799                                                               |
|                |         | Ordering information on page 824                                                                    |
|                |         | Reference circuitry on page 801 - nRF5340-QKAA Config. 1 updated;                                   |
|                |         | N/C capacitor footprint removed; component designators re-ordered;                                  |
|                |         | schematic drawing updates  Reference circuitry on page 801 - Added additional reference circuits    |
|                |         | for nRF5340-QKAA and nRF5340-CLAA                                                                   |
|                |         | DPPI - Corrected number of DPPI channels (32) for the network core                                  |
|                |         | RADIO - Added electrical parameters for TX only run current, P <sub>RF</sub> = +3                   |
|                |         | dBm; clarified use of EDSAMPLE register in combination with CCA                                     |
|                |         | Added electrical specifications for the following chapters:                                         |
|                |         | • SAADC                                                                                             |

QSPI



| Date          | Version | Description                                           |
|---------------|---------|-------------------------------------------------------|
|               |         | • RESET                                               |
|               |         | • CLOCK                                               |
|               |         | Product overview on page 18 - Added missing SAADC     |
|               |         | Ordering information on page 824 - Updated box labels |
|               |         | Editorial changes                                     |
|               |         | Fixed error in document ID                            |
| December 2020 | 1.0     | First release                                         |



# 2 About this document

This document is organized into chapters that are based on the modules and peripherals available in the IC

## 2.1 Document status

The document status reflects the level of maturity of the document.

| Document name                         | Description                                                                                                                                                                                                                                                |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Objective Product Specification (OPS) | Applies to document versions up to 1.0.  This document contains target specifications for product development.                                                                                                                                             |
| Product Specification (PS)            | Applies to document versions 1.0 and higher.  This document contains final product specifications. Nordic Semiconductor ASA reserves the right to make changes at any time without notice in order to improve design and supply the best possible product. |

Table 1: Defined document names

# 2.2 Peripheral chapters

Every peripheral has a unique capitalized name or an abbreviation of its name, e.g. TIMER, used for identification and reference. This name is used in chapter headings and references, and it will appear in the Arm Cortex Microcontroller Software Interface Standard (CMSIS) hardware abstraction layer to identify the peripheral.

The peripheral instance name, which is different from the peripheral name, is constructed using the peripheral name followed by a numbered postfix, starting with 0, for example, TIMERO. A postfix is normally only used if a peripheral can be instantiated more than once. The peripheral instance name is also used in the CMSIS to identify the peripheral instance.

The chapters describing peripherals may include the following information:

- A detailed functional description of the peripheral
- · Register configuration for the peripheral
- Electrical specification tables, containing performance data which apply for the operating conditions described in Recommended operating conditions on page 821.

## 2.3 Register tables

Individual registers are described using register tables. These tables are built up of two sections. The first three colored rows describe the position and size of the different fields in the register. The following rows describe the fields in more detail.

NORDIC SEMICONDUCTOR

#### 2.3.1 Fields and values

The **Id** (**Field Id**) row specifies the bits that belong to the different fields in the register. If a field has enumerated values, then every value will be identified with a unique value id in the **Value Id** column.

A blank space means that the field is reserved and read as undefined, and it also must be written as 0 to secure forward compatibility. If a register is divided into more than one field, a unique field name is specified for each field in the **Field** column. The **Value Id** may be omitted in the single-bit bit fields when values can be substituted with a Boolean type enumerator range, e.g. true/false, disable(d)/enable(d), on/off, and so on.

Values are usually provided as decimal or hexadecimal. Hexadecimal values have a 0x prefix, decimal values have no prefix.

The Value column can be populated in the following ways:

- Individual enumerated values, for example 1, 3, 9.
- Range of values, e.g. [0..4], indicating all values from and including 0 and 4.
- Implicit values. If no values are indicated in the **Value** column, all bit combinations are supported, or alternatively the field's translation and limitations are described in the text instead.

If two or more fields are closely related, the **Value Id**, **Value**, and **Description** may be omitted for all but the first field. Subsequent fields will indicate inheritance with '..'.

A feature marked **Deprecated** should not be used for new designs.

#### 2.3.2 Permissions

Different fields in a register might have different access permissions enforced by hardware.

The access permission for each register field is documented in the Access column in the following ways:

| Access | Description     | Hardware behavior                                                                                                      |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------|
| RO     | Read-only       | Field can only be read. A write will be ignored.                                                                       |
| WO     | Write-only      | Field can only be written. A read will return an undefined value.                                                      |
| RW     | Read-write      | Field can be read and written multiple times.                                                                          |
| W1     | Write-once      | Field can only be written once per reset. Any subsequent write will be ignored. A read will return an undefined value. |
| RW1    | Read-write-once | Field can be read multiple times, but only written once per reset. Any subsequent write will be ignored.               |

Table 2: Register field permission schemes

## 2.4 Registers

| Register | Offset | Security | Description                                       |
|----------|--------|----------|---------------------------------------------------|
| DUMMY    | 0x514  |          | Example of a register controlling a dummy feature |

Table 3: Register overview

#### 2.4.1 DUMMY

Address offset: 0x514

Example of a register controlling a dummy feature



| Bit r | umber    |         |              | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5     | 4 3 2 1 0  |  |  |
|-------|----------|---------|--------------|----------------------|------------------------------------------------------------|------------|--|--|
| ID    |          |         |              | D D D                | D C C C B                                                  | АА         |  |  |
| Res   | et 0x000 | 050002  |              | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0                    |            |  |  |
|       |          |         |              |                      |                                                            |            |  |  |
| Α     | RW       | FIELD_A |              |                      | Example of a read-write field with several enumerated      |            |  |  |
|       |          |         |              |                      | values                                                     |            |  |  |
|       |          |         | Disabled     | 0                    | The example feature is disabled                            |            |  |  |
|       |          |         | NormalMode   | 1                    | The example feature is enabled in normal mode              |            |  |  |
|       |          |         | ExtendedMode | 2                    | The example feature is enabled along with extra            |            |  |  |
|       |          |         |              |                      | functionality                                              |            |  |  |
| В     | RW       | FIELD_B |              |                      | Example of a deprecated read-write field                   | Deprecated |  |  |
|       |          |         | Disabled     | 0                    | The override feature is disabled                           |            |  |  |
|       |          |         | Enabled      | 1                    | The override feature is enabled                            |            |  |  |
| С     | RW       | FIELD_C |              |                      | Example of a read-write field with a valid range of values |            |  |  |
|       |          |         | ValidRange   | [27]                 | Example of allowed values for this field                   |            |  |  |
| D     | RW       | FIELD_D |              |                      | Example of a read-write field with no restriction on the   |            |  |  |
|       |          |         |              |                      | values                                                     |            |  |  |



# 3 Product overview

nRF5340 is a wireless, ultra-low power multicore System on Chip (SoC), integrating two fully programmable Arm Cortex-M33 processors, advanced security features, a range of peripherals, and a multiprotocol 2.4 GHz transceiver. The transceiver supports Bluetooth Low Energy,  $ANT^{\text{TM}}$ , and IEEE 802.15.4 for Thread and Zigbee protocols. It also allows the implementation of proprietary 2.4 GHz protocols.

The two Arm Cortex-M33 processors share the power, clock, and peripheral architecture with Nordic Semiconductor nRF51, nRF52, and nRF91 Series of SoCs, ensuring minimal porting efforts. The application core is a full-featured Arm Cortex-M33 processor including DSP instructions and FPU, running at up to 128 MHz with 1 MB of flash and 512 kB of RAM. The option to run the application processor at 64 MHz allows the CPU to increase energy efficiency. The network core is an Arm Cortex-M33 processor with a reduced feature set, designed for ultra-low power operation. It runs at a fixed 64 MHz frequency and contains 256 kB of flash and 64 kB of RAM.

The peripheral set offers a variety of analog and digital functionality enabling single-chip implementation of a wide range of applications. Arm TrustZone technology, Arm CryptoCell-312, and supporting blocks for system protection and key management are embedded for the advanced security needed for IoT applications.

# 3.1 Block diagram

The block diagram illustrates the overall system. More detailed diagrams of the two cores, including pins and EasyDMA connectivity, can be found in Block diagram on page 105 and Block diagram on page 136.





Figure 1: Simplified block diagram

# 3.2 Memory

The nRF5340 SoC contains two processor cores, each with flash memory and RAM that can be used for code and data storage.



| Core             | RAM                                                                                                                     | Flash                 |
|------------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------|
| Application core | <ul> <li>512 kB, arranged as follows:</li> <li>256 kB CPU single-cycle RAM</li> <li>256 kB of additional RAM</li> </ul> | 1024 kB in 4 kB pages |
| Network core     | 64 kB total                                                                                                             | 256 kB in 2 kB pages  |

Table 4: nRF5340 memory configuration

All memory and registers are found in the same address space, as shown in Memory map on page 21. This includes the two blocks of 256 kB RAM, which are accessible in the memory map as one contiguous 512 kB block of RAM. The first 256 kB block of RAM has single-cycle access time from the CPU, while up to four CPU cycles additional latency occurs when accessing the additional 256 kB block of RAM.

The application core memory is mapped to the network core memory map. This means that the network core CPU can access and use the application core memory for shared memory communication. The application core can restrict network core access through the domain configuration (DCNF) PROTECT registers, see DCNF — Domain configuration on page 201. Access to secure memory or peripherals as defined by the SPU — System protection unit on page 590 is also prevented when the network core is marked as non-secure in an application using TrustZone technology.

**Note:** The EasyDMA masters of the network core peripherals cannot access the application core RAM. The network core processor cannot execute code directly from the application core flash or access QSPI XIP memories.





Figure 2: Memory map

### 3.2.1 RAM — Random access memory

RAM can be read and written an unlimited number of times.

Each RAM AHB slave within a core is connected to one or more RAM sections that has separate power control for System ON and System OFF mode operation. For details, see VMC — Volatile memory controller on page 740.



## 3.2.2 Flash — Non-volatile memory

Flash memory can be read an unlimited number of times by the CPU, but is restricted in the number of times it can be written to or erased. Flash memory is also restricted in how it can be written.

Writing to flash memory is managed by the non-volatile memory controller (NVMC), see NVMC — Non-volatile memory controller on page 334.

Flash memory is divided in pages, as listed in nRF5340 memory configuration on page 20.

### 3.2.3 XIP — Execute in place

Execute in Place (XIP) allows the application core to execute program code directly from the external flash memory device using the Quad serial peripheral interface (QSPI). The external flash memory supports on-the-fly encryption and decryption.

For details, see QSPI — Quad serial peripheral interface on page 397.

### 3.2.4 Access latency

When accessing memories or peripherals across bus bridges, additional access latency will occur. An example of this is when the network core accesses the application core memory or peripherals.



# 4 Power and clock management

The power and clock management system in nRF5340 is optimized for ultra-low power applications to ensure maximum power efficiency.

The core of the power and clock management system is the power management unit (PMU) shown in the following figure.



Figure 3: Power management unit

The PMU automatically tracks the power and clock resources required by the different components in the system at any given time. To achieve the lowest power consumption possible, the PMU optimizes the system by evaluating power and clock requests, automatically starting and stopping clock sources, and choosing regulator operation modes.

The nRF5340 start-up sequence after reset is described in RESET — Reset control on page 65.

## 4.1 System ON mode

System ON is the default operation mode after power-on reset.

In System ON, all functional blocks, such as the CPU and peripherals, can be in an IDLE or RUN state depending on the configuration set by the software and the state of the executing application. The network core's CPU and peripherals can be in IDLE state, RUN state, or Force-OFF mode (see Force-OFF mode on page 25).

The PMU can switch the appropriate internal power sources on and off, depending on power requirements. A peripheral's power requirement is directly related to its activity level, which increases and decreases when specific tasks are triggered or events are generated.

#### Voltage and frequency scaling

nRF5340 automatically adjusts the internal voltages to optimize power efficiency.

Some configuration options request a higher internal voltage, which is seen as an increase in power consumption. These configurations are the following:

• Setting the frequency of the application core's clock to 128 MHz, see Application core frequency scaling on page 76. Increased power consumption in this mode is also observed when the CPU is sleeping, such as after executing the WFI (wait for interrupt) or WFE (wait for event) instructions.

Power consumption during System ON with CPU and peripherals in IDLE state sleep is reduced by configuring the application core's clock to 64 MHz before entering CPU sleep.

- Using QSPI with 96 MHz clock frequency
- · Using the USB peripheral
- · When debugging
- Requesting additional voltage on the VREGRADIO supply using VREQCTRL Voltage request control on page 63

#### 4.1.1 Power submodes

In System ON mode, when the CPU and all peripherals are in IDLE state, the system can reside in one of two power submodes.

The power submodes are:

- Constant latency
- Low-power

In Constant latency mode, the CPU wakeup latency and the PPI task response will be constant and kept at a minimum. This is secured by a set of resources that are always enabled. Compared to Low-power mode, the advantage of having a constant and predictable latency comes at a cost of increased power consumption. Constant latency mode is selected by triggering the CONSTLAT task.

In Low-power mode, the most power efficient supply option is chosen by the automatic power management system. Achieving the lowest power possible is at the expense of variations in CPU wakeup latency and PPI task response. Low-power mode is selected by triggering the LOWPWR task.

When the system enters System ON, it is by default in the Low-power submode.

## 4.2 System OFF mode

System OFF is the deepest power-saving mode the system can enter. In this mode, the system's core functionality is powered down and all ongoing tasks are terminated.

The device is put into System OFF mode using the register SYSTEMOFF on page 54 . The following initiate a wakeup from System OFF:

- The DETECT signal, generated by the GPIO peripheral
- The ANADETECT signal, generated by the LPCOMP peripheral
- The SENSE signal, generated by the NFCT peripheral to wake-on-field
- A valid USB voltage on the VBUS pin is detected
- A debug session is started
- A pin reset

When the device wakes up from System OFF, a system reset is performed. For more details, see Application core reset behavior on page 67.

One or more RAM sections can be retained in System OFF depending on the RAM retention settings in the peripheral VMC — Volatile memory controller on page 740.

Before entering System OFF, the EasyDMA enabled peripheral must not active when entering System OFF. It is also recommended that the network core is in IDLE state, meaning peripherals are stopped and the CPU is idle.

## 4.2.1 Emulated System OFF mode

When the device is in Debug Interface mode, System OFF is emulated to ensure that all resources required for debugging are available during System OFF.



Resources required for debugging include the following key components:

- Debug Interface mode on page 756
- CLOCK Clock control on page 73
- POWER Power control on page 46
- OSCILLATORS Oscillator control on page 98
- REGULATORS Regulator control on page 51
- RESET Reset control on page 65
- NVMC Non-volatile memory controller on page 334
- CPU
- · Flash memory
- RAM

Because the CPU is kept on in an emulated System OFF mode, it is recommended to add an infinite loop directly after entering System OFF. This prevents the CPU from executing code that normally should not be executed. For more information, see Debug and trace on page 751.

## 4.3 Force-OFF mode

Force-OFF mode is only applicable for the network core.

The register interface RESET — Reset control on page 65 is used by the application core to force the network core to Force-OFF mode. In this mode, the network core is stopped in order to achieve the lowest power consumption possible. When the network core is in Force-OFF mode, only the application core can release the mode, causing the network core to wake up and start the CPU again.

Before the application core sets the network core to Force-OFF mode, it is recommended that the network core is in IDLE state, as defined by the following:

- All peripherals are stopped
- Additional voltage on the VREGRADIO supply is canceled using VREQCTRL Voltage request control on page 63
- The CPU is in IDLE state, meaning it is running the WFI or WFE instruction

When the network core wakes up from Force-OFF mode, it is reset. For more details, see Network core reset behavior on page 68.

Several RAM sections can be retained in Force-OFF mode depending on the RAM retention settings in the peripheral VMC — Volatile memory controller on page 740.

#### 4.3.1 Emulated Force-OFF mode

If the device is in Debug Interface mode, Force-OFF mode will be emulated to secure the required resources needed for debugging.

When Force-OFF mode is emulated, the CPU and all peripherals are reset. The CPU is prevented from running during debug access to a core's resources, including writing to RAM, flash, and/or peripherals. See Debug and trace on page 751 for more information.

## 4.4 Current consumption

Because the Power Management Unit (PMU) is constantly adjusting the different power and clock sources, estimating an application's current consumption can be challenging when the measurements cannot be performed directly on the hardware. To facilitate the estimation process, a set of current consumption scenarios is provided to show the typical current drawn from the VDD or VDDH supply.



Each scenario specifies a set of operations and conditions applying to the given scenario. All scenarios are listed in Electrical specification on page 28. The following table shows a set of common conditions used in all scenarios, unless otherwise stated in the description of a given scenario.



| Condition               | Value                                               | Note                                                                                                                                                                                             |
|-------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Supply                  | 3 V on VDD/VDDH (normal voltage mode)               |                                                                                                                                                                                                  |
| Temperature             | 25ºC                                                |                                                                                                                                                                                                  |
| СРИ                     | WFI (wait for interrupt)/WFE (wait for event) sleep |                                                                                                                                                                                                  |
| Peripherals             | All idle                                            |                                                                                                                                                                                                  |
| Clock                   | HFCLK=HFINT running at 64 MHz                       |                                                                                                                                                                                                  |
|                         | LFCLK=Not running                                   |                                                                                                                                                                                                  |
| Regulator               | DC/DC on VREGMAIN, VREGRADIO, and VREGH (when used) |                                                                                                                                                                                                  |
| Application core RAM    | 8 kB                                                | In System ON, RAM value refers to<br>the amount of RAM that is switched<br>on. The remainder of RAM is non<br>retained. In System OFF, RAM value<br>refers to amount of RAM that is<br>retained. |
| Network core RAM        | 0 kB                                                |                                                                                                                                                                                                  |
| Cache enabled           | Yes                                                 | Only applies when the CPU is running from flash memory.                                                                                                                                          |
| Network core forced off | Yes                                                 |                                                                                                                                                                                                  |
| 32 MHz crystal          | SMD 2016                                            | Only applies when the high                                                                                                                                                                       |
|                         | 32 MHz                                              | frequency crystal oscillator (HFXO) is running. HFXO is used when the                                                                                                                            |
|                         | f <sub>tol</sub> = ±30 ppm                          | radio is running.                                                                                                                                                                                |
|                         | C <sub>L</sub> =8 pF                                |                                                                                                                                                                                                  |
|                         | R <sub>S</sub> ≤50 Ω                                |                                                                                                                                                                                                  |
|                         | D <sub>L</sub> ≤100 μW                              |                                                                                                                                                                                                  |
| 32 kHz crystal          | SMD 2012                                            | Only applies when the low frequency                                                                                                                                                              |
|                         | 32.768 kHz                                          | crystal oscillator (LFXO) is running.                                                                                                                                                            |
|                         | f <sub>tol</sub> = ±20 ppm                          |                                                                                                                                                                                                  |
|                         | C <sub>L</sub> =9 pF                                |                                                                                                                                                                                                  |
|                         | C <sub>0</sub> =1.3 pF                              |                                                                                                                                                                                                  |
|                         | R <sub>L</sub> =70 kΩ                               |                                                                                                                                                                                                  |
|                         | D <sub>L</sub> ≤1.0 μW                              |                                                                                                                                                                                                  |
| Inductors               | SMD 1608                                            |                                                                                                                                                                                                  |
|                         | L = 10 μH                                           |                                                                                                                                                                                                  |
|                         | Tol = 20%                                           |                                                                                                                                                                                                  |
|                         | I <sub>sat</sub> ≥ 90 mA                            |                                                                                                                                                                                                  |



| Condition        | Value                                                                                    | Note                                            |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------|-------------------------------------------------|--|--|--|--|
|                  | $R_{DC} \le 1.2 \Omega$                                                                  |                                                 |  |  |  |  |
| Compiler version | GCC version 7.3.1 20180622 (arm-none-eabi-gcc)                                           |                                                 |  |  |  |  |
| Compiler flags   | -mcpu=cortex-m33 -mthumb -mfpu=fpv5-sp-d16 -fno-delections-functions-falign-functions-03 | ete-null-pointer-checks<br>ll-loops -ffunction- |  |  |  |  |

Table 5: Current consumption scenarios, common conditions

# 4.4.1 Electrical specification

## 4.4.1.1 Sleep

| Symbol                       | Description                                                                                                      | Min. | Тур. | Max. | Units |  |
|------------------------------|------------------------------------------------------------------------------------------------------------------|------|------|------|-------|--|
| I <sub>ON_IDLE1</sub>        | System ON, 0 kB application RAM, wake on any event                                                               |      | 1.3  |      | uA    |  |
| I <sub>ON_IDLE1,LDO</sub>    | System ON, 0k application RAM, wake on any event, regulator = LDO                                                |      | 3.3  |      | uA    |  |
| I <sub>ON_IDLE2</sub>        | System ON, wake on any event                                                                                     |      | 1.3  |      | uA    |  |
| I <sub>ON_IDLE2,LDO</sub>    | System ON, wake on any event, regulator = LDO                                                                    |      | 3.4  |      | uA    |  |
| I <sub>ON_IDLE3</sub>        | System ON, wake on any event, power-fail comparator enabled                                                      |      | 1.3  |      | uA    |  |
| I <sub>ON_IDLE3,128MHz</sub> | System ON, wake on any event, power-fail comparator enabled, clock=HFINT128M                                     |      | 785  |      | uA    |  |
| I <sub>ON_IDLE4</sub>        | System ON, wake on GPIOTE input (event mode,  LATENCY=LowLatency)                                                |      | 48   |      | uA    |  |
| I <sub>ON_IDLE4_LP</sub>     | System ON, wake on GPIOTE input (event mode,  LATENCY=LowPower)                                                  |      | 1.3  |      | uA    |  |
| I <sub>ON_IDLE5</sub>        | System ON, wake on GPIOTE PORT event                                                                             |      | 1.3  |      | uA    |  |
| I <sub>ON_IDLE6</sub>        | System ON, 0 kB application RAM, wake on RTC (running from LFXO clock)                                           |      | 1.5  |      | uA    |  |
| I <sub>ON_IDLE7</sub>        | System ON, wake on RTC (running from LFXO clock)                                                                 |      | 1.5  |      | uA    |  |
| I <sub>ON_IDLE8</sub>        | System ON, 0 kB application RAM, wake on RTC (running from LFXO clock), 5 V supply on VDDH, VREGH output = 3.3 V |      | 1.7  |      | uA    |  |
| I <sub>ON_IDLE7</sub>        | System ON, 0 kB network RAM, wake on network RTC (running from LFXO clock)                                       |      | 1.5  |      | uA    |  |



| Symbol                 | Description                                                                                               | Min. | Тур. | Max. | Units |
|------------------------|-----------------------------------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>ON_IDLE8</sub>  | System ON, 64 kB network RAM, wake on network RTC (running from LFXO clock)                               |      | 1.7  |      | uA    |
| I <sub>ON_IDLE9</sub>  | System ON, 0 kB application RAM, wake on RTC (running from LFRC clock)                                    |      | 2.1  |      | uA    |
| I <sub>ON_IDLE10</sub> | Both cores in System ON, wake on any event.  VREQH=Disabled.                                              |      | 1.3  |      | uA    |
| ION_IDLE10_VREQH       | Both cores in System ON, wake on any event.  VREQH=Enabled.                                               |      | 1.4  |      | uA    |
| I <sub>OFF0</sub>      | System OFF, 0 kB application RAM, wake on reset                                                           |      | 1.0  |      | uA    |
| I <sub>OFF0,LDO</sub>  | System OFF, 0 kB application RAM, wake on reset; regulator = LDO                                          |      | 1.4  |      | uA    |
| I <sub>OFF1</sub>      | System OFF, 0 kB application RAM, wake on LPCOMP                                                          |      | 0.9  |      | uA    |
| I <sub>OFF2</sub>      | System OFF, wake on reset                                                                                 |      | 0.9  |      | uA    |
| I <sub>OFF3</sub>      | System OFF, 0 kB application RAM, wake on reset, 5 V supply on VDDH, VREGH output = 3.3V                  |      | 1.1  |      | uA    |
| I <sub>OFF3,LDO</sub>  | System OFF, 0 kB application RAM, wake on reset, 5 V supply on VDDH, VREGH output = 3.3V; regulator = LDO |      | 1.4  |      | uA    |
| I <sub>OFF4</sub>      | System OFF, 512 kB application RAM + 64 kB network RAM, wake on reset                                     |      | 2.4  |      | uA    |





Figure 4: System OFF, 0 kB application RAM, wake on reset (typical values)



Figure 5: System ON, wake on any event, power-fail comparator enabled (typical values)

## 4.4.1.2 Application CPU running

The application CPU running parameters are obtained using the following compiler version:

Compiler: Arm version 6.14 (armclang)



#### Compiler flags:

```
-std=c99 --target=arm-arm-none-eabi -mcpu=cortex-m33 -mfpu=fpv5-sp-d16 -mfloat-abi=hard - fno-rtti -flto -funsigned-char -mcmse -Omax -ffunction-sections
```

#### Linker flags:

```
-Omax
```

20 kB of RAM in application core switched on and retained in execute-from-flash cases, and 44 kB in execute-from-RAM cases.

| Symbol                | Description                                                         | Min. | Тур. | Max. | Units |
|-----------------------|---------------------------------------------------------------------|------|------|------|-------|
| I <sub>APPCPU0</sub>  | CPU running CoreMark from flash, regulator = LDO, clock = HFINT128M |      | 15.5 |      | mA    |
| I <sub>APPCPU2</sub>  | CPU running CoreMark from flash, clock = HFXO128M                   |      | 8.0  |      | mA    |
| I <sub>APPCPU3</sub>  | CPU running CoreMark from flash, clock = HFXO64M                    |      | 3.6  |      | mA    |
| I <sub>APPCPU4</sub>  | CPU running CoreMark from flash, clock = HFINT128M                  |      | 7.8  |      | mA    |
| I <sub>APPCPU5</sub>  | CPU running CoreMark from flash                                     |      | 3.3  |      | mA    |
| I <sub>APPCPU8</sub>  | CPU running CoreMark from RAM, clock = HFINT128M                    |      | 7.9  |      | mA    |
| I <sub>APPCPU9</sub>  | CPU running CoreMark from RAM                                       |      | 3.4  |      | mA    |
| I <sub>APPCPU10</sub> | CPU running CoreMark from RAM, clock = HFXO128M                     |      | 8.2  |      | mA    |
| I <sub>APPCPU11</sub> | CPU running CoreMark from RAM, clock = HFXO64M                      |      | 3.6  |      | mA    |

### 4.4.1.3 Network CPU running

The network CPU running parameters are obtained using the following compiler version:

Compiler: Arm version 6.14 (armclang)

```
Compiler flags: -std=c99 --target=arm-arm-none-eabi -mcpu=cortex-m33+nodsp -mfpu=none - mfloat-abi=soft -fno-rtti -flto -funsigned-char -Omax -ffunction-sections
```

#### Linker flags:

```
-Omax
```

20 kB of RAM in network core switched on and retained in execute-from-flash cases, and 40 kB in execute-from-RAM cases.

Clock and regulator settings only apply to network core. The settings in the application core are the same as the common conditions.

| Symbol               | Description                                      | Min. | Тур. | Max. | Units |
|----------------------|--------------------------------------------------|------|------|------|-------|
| I <sub>NETCPU0</sub> | CPU running CoreMark from flash, regulator = LDO |      | 5.1  |      | mA    |
| I <sub>NETCPU1</sub> | CPU running CoreMark from flash                  |      | 2.4  |      | mA    |
| I <sub>NETCPU2</sub> | CPU running CoreMark from flash, clock = HFXO64M |      | 2.6  |      | mA    |
| I <sub>NETCPU3</sub> | CPU running CoreMark from RAM, regulator = LDO   |      | 4.3  |      | mA    |
| I <sub>NETCPU4</sub> | CPU running CoreMark from RAM                    |      | 2.0  |      | mA    |
| I <sub>NETCPU5</sub> | CPU running CoreMark from RAM, clock = HFXO64M   |      | 2.2  |      | mA    |

## 4.4.1.4 COMP active

| Symbol                 | Description                   | Min. | Тур. | Max. | Units |
|------------------------|-------------------------------|------|------|------|-------|
| I <sub>COMP,LP</sub>   | COMP enabled, Low-power mode  |      | 60   |      | uA    |
|                        |                               |      |      |      |       |
| I <sub>COMP,NORM</sub> | COMP enabled, normal mode     |      | 62   |      | uA    |
|                        |                               |      |      |      |       |
| I <sub>COMP,HS</sub>   | COMP enabled, High-speed mode |      | 68   |      | uA    |

## 4.4.1.5 I2S active

| Symbol            | Description                                            | Min. | Тур. | Max. | Units |
|-------------------|--------------------------------------------------------|------|------|------|-------|
| I <sub>12S0</sub> | I2S transferring data @ 2 x 16 bit x 16 kHz            |      | 2000 |      | uA    |
|                   | (CONFIG.MCKFREQ = 32MDIV63, CONFIG.RATIO = 32X),       |      |      |      |       |
|                   | clock = HFXO64M                                        |      |      |      |       |
|                   |                                                        |      |      |      |       |
| I <sub>I2S1</sub> | I2S transferring data @ 2 x 16 bit x 16 kHz            |      | 2170 |      | uA    |
|                   | (CONFIG.MCKFREQ = 510000, CONFIG.RATIO = 32X), clock = |      |      |      |       |
|                   | HFXO ACLK @ 12.288 MHz                                 |      |      |      |       |
|                   |                                                        |      |      |      |       |
| I <sub>1252</sub> | I2S transferring data @ 2 x 16 bit x 48 kHz            |      | 2310 |      | uA    |
|                   | (CONFIG.MCKFREQ = 505286656, CONFIG.RATIO = 32X),      |      |      |      |       |
|                   | clock = HFXO ACLK @ 12.288 MHz                         |      |      |      |       |

## 4.4.1.6 LPCOMP active

| Symbol                 | Description    | Min. | Тур. | Max. | Units |
|------------------------|----------------|------|------|------|-------|
| I <sub>LPCOMP,EN</sub> | LPCOMP enabled |      | 45   |      | uA    |



## 4.4.1.7 NFCT active

| Symbol                 | Description                                                                       | Min. | Тур. | Max. | Units |
|------------------------|-----------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>SENSE</sub>     | System ON, current in SENSE STATE (this current does not apply when in NFC field) |      | 1.3  |      | uA    |
| I <sub>ACTIVATED</sub> | System ON, current in ACTIVATED STATE, clock = HFXO64M                            |      | 1080 |      | uA    |

### 4.4.1.8 PDM active

| Symbol                    | Description                                            | Min. | Тур. | Max. | Units |
|---------------------------|--------------------------------------------------------|------|------|------|-------|
| I <sub>PDM,RUN</sub>      | PDM receiving and processing data @ 1 MHz (RATIO =     |      | 655  |      | uA    |
|                           | 64, PDMCLKCTRL = 135274496), stereo mode, clock =      |      |      |      |       |
|                           | HFXO64M                                                |      |      |      |       |
|                           |                                                        |      |      |      |       |
| I <sub>PDM,RUN,ACLK</sub> | PDM receiving and processing data @ 1 MHz (RATIO = 64, |      | 1045 |      | uA    |
|                           | PDMCLKCTRL = 343597056), stereo mode, HFXO ACLK =      |      |      |      |       |
|                           | 12.288 MHz                                             |      |      |      |       |
|                           |                                                        |      |      |      |       |

## 4.4.1.9 PWM active

| Symbol                     | Description                                                   | Min. | Тур. | Max. | Units |
|----------------------------|---------------------------------------------------------------|------|------|------|-------|
| I <sub>PWM,RUNO</sub>      | PWM running at 125 kHz, top = 10, duty = 50%                  |      | 560  |      | uA    |
| I <sub>PWM,RUN1</sub>      | PWM running at 16 MHz, top = 10, duty = 50%                   |      | 560  |      | uA    |
| I <sub>PWM</sub> ,RUN1,LDO | PWM running at 16 MHz, top = 10, duty = 50%; regulator = LDO  |      | 1035 |      | uA    |
| I <sub>PWM,RUN2</sub>      | PWM running at 125 kHz, top = 10, duty = 50%, clock = HFXO64M |      | 750  |      | uA    |
| I <sub>PWM</sub> ,RUN3     | PWM running at 16 MHz, top = 10, duty = 50%, clock = HFXO64M  |      | 755  |      | uA    |

## 4.4.1.10 QDEC active

| Symbol                | Description  | Min. | Тур. | Max. | Units |
|-----------------------|--------------|------|------|------|-------|
| I <sub>ODEC RUN</sub> | QDEC running |      | 480  |      | uA    |



## 4.4.1.11 QSPI active

| Symbol                   | Description                                                  | Min. | Тур. | Max. | Units |
|--------------------------|--------------------------------------------------------------|------|------|------|-------|
| I <sub>QSPI,IDLE</sub>   | QSPI idle (enabled, but not activated)                       |      | 45   |      | uA    |
| I <sub>QSPI,ACTIVE</sub> | QSPI active (activated, but not transferring data)           |      | 1790 |      | uA    |
| I <sub>QSPI,DATA</sub>   | QSPI transferring data (activated, and transferring data to/ |      | 4430 |      | uA    |
|                          | from external flash memory), SCKFREQ = 96 MHz, quad          |      |      |      |       |
|                          | mode, clock = HFXO192M                                       |      |      |      |       |

## 4.4.1.12 RADIO transmitting/receiving

64 kB of network core RAM switched on and retained.

Clock and regulator settings only apply to network core. The settings in the application core are the same as the common conditions.

| Symbol                 | Description                                                                                                          | Min. | Тур. | Max. | Units |
|------------------------|----------------------------------------------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>RADIO_TX0</sub> | Radio transmitting @ +3 dBm output power, 1 Mbps Bluetooth low energy (BLE) mode, clock = HFXO64M                    |      | 5.3  |      | mA    |
| I <sub>RADIO_TX1</sub> | Radio transmitting @ 0 dBm output power, 1 Mbps  Bluetooth low energy (BLE) mode, clock = HFXO64M                    |      | 4.1  |      | mA    |
| I <sub>RADIO_TX2</sub> | Radio transmitting @ -40 dBm output power, 1 Mbps  Bluetooth low energy (BLE) mode, clock = HFXO64M                  |      | 2.6  |      | mA    |
| I <sub>RADIO_TX3</sub> | Radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth low energy (BLE) mode, clock = HFXO64M; regulator = LDO    |      | 9.7  |      | mA    |
| I <sub>RADIO_TX4</sub> | Radio transmitting @ -40 dBm output power, 1 Mbps Bluetooth low energy (BLE) mode, clock = HFXO64M; regulator = LDO  |      | 5.0  |      | mA    |
| I <sub>RADIO_TX5</sub> | Radio transmitting @ 0 dBm output power, 2 Mbps Bluetooth low energy (BLE) mode, clock = HFXO64M                     |      | 4.2  |      | mA    |
| I <sub>RADIO_TX6</sub> | Radio transmitting @ 0 dBm output power, 500 kbps Bluetooth low energy (BLE) long-range (LR) mode, clock = HFXO64M   |      | 4.1  |      | mA    |
| I <sub>RADIO_TX7</sub> | Radio transmitting @ 0 dBm output power, 125 kbps  Bluetooth low energy (BLE) long-range (LR) mode, clock =  HFXO64M |      | 4.1  |      | mA    |
| I <sub>RADIO_TX8</sub> | Radio transmitting @ 0 dBm output power, 250 kbps IEEE<br>802.15.4-2006 mode, clock = HFXO64M                        |      | 4.1  |      | mA    |
| I <sub>RADIO_RXO</sub> | Radio receiving @ 1 Mbps Bluetooth low energy (BLE) mode, clock = HFXO64M                                            |      | 3.7  |      | mA    |



| Symbol                 | Description                                               | Min. | Тур. | Max. | Units |
|------------------------|-----------------------------------------------------------|------|------|------|-------|
| I <sub>RADIO_RX1</sub> | Radio receiving @ 1 Mbps Bluetooth low energy (BLE)       |      | 8.0  |      | mA    |
|                        | mode, clock = HFXO64M; regulator = LDO                    |      |      |      |       |
| I <sub>RADIO_RX2</sub> | Radio receiving @ 2 Mbps Bluetooth low energy (BLE)       |      | 4.1  |      | mA    |
|                        | mode, clock = HFXO64M                                     |      |      |      |       |
| I <sub>RADIO_RX3</sub> | Radio receiving @ 500 kbps Bluetooth low energy (BLE)     |      | 3.6  |      | mA    |
|                        | long-range (LR) mode, clock = HFXO64M                     |      |      |      |       |
| I <sub>RADIO_RX4</sub> | Radio receiving @ 125 kbps Bluetooth low energy (BLE)     |      | 3.6  |      | mA    |
|                        | long-range (LR) mode, clock = HFXO64M                     |      |      |      |       |
| I <sub>RADIO_RX5</sub> | Radio receiving @ 250 kbps IEEE 802.15.4-2006 mode, clock |      | 3.9  |      | mA    |
|                        | = HFXO64M                                                 |      |      |      |       |



Figure 6: Radio transmitting at 3 dBm output power, 1 Mbps Bluetooth LE mode (typical values)





Figure 7: Radio transmitting at 0 dBm output power, 1 Mbps Bluetooth LE mode (typical values)

### 4.4.1.13 RNG active

| Symbol            | Description                    | Min. | Тур. | Max. | Units |
|-------------------|--------------------------------|------|------|------|-------|
| I <sub>RNG0</sub> | RNG running, 64 kB network RAM |      | 270  |      | uA    |

#### 4.4.1.14 SAADC active

| Symbol                  | Description                                               | Min. | Тур. | Max. | Units |
|-------------------------|-----------------------------------------------------------|------|------|------|-------|
| I <sub>SAADC,RUN</sub>  | SAADC sampling @ 16 ksps, acquisition time = 20 us, clock |      | 980  |      | uA    |
|                         | = HFXO64M                                                 |      |      |      |       |
|                         |                                                           |      |      |      |       |
| I <sub>SAADC,TASK</sub> | SAADC sampling @ 1 kHz from RTC in task mode,             |      | 160  |      | uA    |
|                         | acquisition time = 20 us, clock = HFINT64M and LFXO       |      |      |      |       |
|                         |                                                           |      |      |      |       |

### 4.4.1.15 TEMP active

| Symbol             | Description                     | Min. | Тур. | Max. | Units |
|--------------------|---------------------------------|------|------|------|-------|
| I <sub>TEMPO</sub> | TEMP started, 64 kB network RAM |      | 615  |      | uA    |

## 4.4.1.16 TIMER running

| Symbol              | Description               | Min. | Тур. | Max. | Units |  |
|---------------------|---------------------------|------|------|------|-------|--|
| I <sub>TIMERO</sub> | One TIMER running @ 1 MHz |      | 475  |      | uA    |  |





| Symbol                  | Description                                                | Min. | Тур. | Max. | Units |
|-------------------------|------------------------------------------------------------|------|------|------|-------|
| I <sub>TIMER1</sub>     | One TIMER running @ 1 MHz, clock = HFXO64M                 |      | 670  |      | uA    |
| I <sub>TIMER2</sub>     | One TIMER running @ 16 MHz                                 |      | 560  |      | uA    |
| I <sub>TIMER2,LDO</sub> | One TIMER running @ 16 MHz; regulator = LDO                |      | 1040 |      | uA    |
| I <sub>TIMER3</sub>     | One TIMER running @ 16 MHz, clock = HFXO64M                |      | 750  |      | uA    |
| I <sub>TIMER3,LDO</sub> | One TIMER running @ 16 MHz, clock = HFXO64M; regulator LDO |      | 1280 |      | uA    |
| I <sub>TIMER4</sub>     | One TIMER running @ 16 MHz, clock = HFINT128M              |      | 750  |      | uA    |
| I <sub>NET,TIMERO</sub> | One network TIMER running @ 1 MHz                          |      | 170  |      | uA    |
| I <sub>NET,TIMER1</sub> | One network TIMER running @ 1 MHz, clock = HFXO64M         |      | 400  |      | uA    |
| I <sub>NET,TIMER2</sub> | One network TIMER running @ 16 MHz                         |      | 220  |      | uA    |
| I <sub>NET,TIMER3</sub> | One network TIMER running @ 16 MHz, clock = HFXO64M        |      | 445  |      | uA    |

### 4.4.1.17 SPIM active

| Symbol             | Description                                       | Min. | Тур. | Max. | Units |
|--------------------|---------------------------------------------------|------|------|------|-------|
| I <sub>SPIMO</sub> | SPIM transferring data @ 2 Mbps                   |      | 935  |      | uA    |
| I <sub>SPIM1</sub> | SPIM transferring data @ 2 Mbps, clock = HFXO64M  |      | 1145 |      | uA    |
| I <sub>SPIM2</sub> | SPIM transferring data @ 8 Mbps                   |      | 1705 |      | uA    |
| I <sub>SPIM3</sub> | SPIM transferring data @ 8 Mbps, clock = HFXO64M  |      | 1930 |      | uA    |
| I <sub>SPIM4</sub> | SPIM transferring data @ 32 Mbps                  |      | 2115 |      | uA    |
| I <sub>SPIM5</sub> | SPIM transferring data @ 32 Mbps, clock = HFXO64M |      | 2345 |      | uA    |

### 4.4.1.18 SPIS active

| Symbol             | Description                                         | Min. | Тур. | Max. | Units |  |
|--------------------|-----------------------------------------------------|------|------|------|-------|--|
| I <sub>SPISO</sub> | SPIS configured and idle (enabled, no CSN activity) |      | 145  |      | uA    |  |
| I <sub>SPIS1</sub> | SPIS transferring data @ 2 Mbps                     |      | 713  |      | uA    |  |
| I <sub>SPIS2</sub> | SPIS transferring data @ 2 Mbps, clock = HFXO64M    |      | 913  |      | uA    |  |



### 4.4.1.19 TWIM active

| Symbol             | Description                                         | Min. | Тур. | Max. | Units |
|--------------------|-----------------------------------------------------|------|------|------|-------|
| I <sub>TWIM0</sub> | TWIM transferring data @ 100 kbps                   |      | 965  |      | uA    |
| I <sub>TWIM1</sub> | TWIM transferring data @ 100 kbps, clock = HFXO64M  |      | 1170 |      | uA    |
| I <sub>TWIM2</sub> | TWIM transferring data @ 400 kbps                   |      | 1000 |      | uA    |
| I <sub>TWIM3</sub> | TWIM transferring data @ 400 kbps, clock = HFXO64M  |      | 1205 |      | uA    |
| I <sub>TWIM4</sub> | TWIM transferring data @ 1000 kbps                  |      | 2050 |      | uA    |
| I <sub>TWIM5</sub> | TWIM transferring data @ 1000 kbps, clock = HFXO64M |      | 2295 |      | uA    |

### 4.4.1.20 TWIS active

| Symbol                 | Description                                        | Min. | Тур. | Max. | Units |
|------------------------|----------------------------------------------------|------|------|------|-------|
| I <sub>TWIS,IDLE</sub> | TWIS configured and enabled (IDLE state)           |      | 45   |      | uA    |
| I <sub>TWISO</sub>     | TWIS transferring data @ 100 kbps                  |      | 945  |      | uA    |
| I <sub>TWIS1</sub>     | TWIS transferring data @ 400 kbps                  |      | 985  |      | uA    |
| I <sub>TWIS2</sub>     | TWIS transferring data @ 100 kbps, clock = HFXO64M |      | 1150 |      | uA    |
| I <sub>TWIS3</sub>     | TWIS transferring data @ 400 kbps, clock = HFXO64M |      | 1185 |      | uA    |

### 4.4.1.21 UARTE active

| Symbol                   | Description                                                                  | Min. | Тур. | Max. | Units |
|--------------------------|------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>UARTE,IDLEO</sub> | UARTE RX idle (started, waiting for data, no data transfer)                  |      | 645  |      | uA    |
| I <sub>UARTE,IDLE1</sub> | UARTE RX idle (started, waiting for data, no data transfer), clock = HFXO64M |      | 840  |      | uA    |
| I <sub>UARTEO</sub>      | UARTE transferring data @ 1200 bps, clock = HFXO64M                          |      | 885  |      | uA    |
| I <sub>UARTE1</sub>      | UARTE transferring data @ 115200 bps, clock = HFXO64M                        |      | 890  |      | uA    |
| I <sub>UARTE2</sub>      | UARTE receiving data @ 115200 bps, clock = HFXO64M                           |      | 890  |      | uA    |
| I <sub>UARTE3</sub>      | UARTE transmitting and receiving data @ 115200 bps, clock = HFXO64M          |      | 895  |      | uA    |





#### 4.4.1.22 WDT active

| Symbol                   | Description                                  | Min. | Тур. | Max. | Units |  |
|--------------------------|----------------------------------------------|------|------|------|-------|--|
| I <sub>WDT,APP</sub>     | Application MCU WDT started                  |      | 2.0  |      | uA    |  |
|                          |                                              |      |      |      |       |  |
| I <sub>WDT,APP,LDO</sub> | Application MCU WDT started; regulator = LDO |      | 4.9  |      | uA    |  |
|                          |                                              |      |      |      |       |  |
| I <sub>WDT,NET</sub>     | Network MCU WDT started, 64 kB network RAM   |      | 3.2  |      | uA    |  |

# 4.4.1.23 Compounded

These are scenarios where both cores are active. 20 kB of RAM in the application core and 64 kB of RAM in the network core are switched on and retained.

In scenarios where both cores are active, the clock and regulator settings apply to both.

| Symbol          | Description                                                                                                                                                                       | Min. | Тур. | Max. | Units |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>50</sub> | Application CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M                                           |      | 7.3  |      | mA    |
| I <sub>51</sub> | Application CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M                                                                  |      | 6.9  |      | mA    |
| I <sub>52</sub> | Application CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M, regulator = LDO                          |      | 16.9 |      | mA    |
| I <sub>53</sub> | Application CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M; regulator = LDO                                                 |      | 15.6 |      | mA    |
| I <sub>S4</sub> | Application CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M, 5 V supply on VDDH, VREGH output = 3.3 V |      | 6.7  |      | mA    |
| I <sub>SS</sub> | Application CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M, 5 V supply on VDDH, VREGH output = 3.3 V                        |      | 6.4  |      | mA    |
| I <sub>56</sub> | Network CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth Low Energy mode, clock = HFXO64M                                               |      | 5.9  |      | mA    |
| I <sub>S7</sub> | Network CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode, clock = HFXO64M                                                                      |      | 5.4  |      | mA    |
| I <sub>S8</sub> | Application + Network CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps  Bluetooth Low Energy mode; clock = HFXO64M                                |      | 9.1  |      | mA    |



| Symbol           | Description                                                                                                                                                          | Min. | Тур. | Max. | Units |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------|
| l <sub>S9</sub>  | Application + Network CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M                                           |      | 8.6  |      | mA    |
| l <sub>S10</sub> | Application + Network CPU running CoreMark from flash, radio transmitting @ +3 dBm output power, 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M                   |      | 9.9  |      | mA    |
| I <sub>S11</sub> | Application + Network CPU running CoreMark from flash, radio transmitting @ +3 dBm output power, 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M; regulator = LDO  |      | 21.5 |      | mA    |
| I <sub>S12</sub> | Application + Network CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps  Bluetooth Low Energy mode; clock = HFXO64M; regulator =  LDO |      | 20.2 |      | mA    |
| l <sub>S13</sub> | Application + Network CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode; clock = HFXO64M; regulator = LDO                          |      | 21.5 |      | mA    |
| l <sub>S14</sub> | Network CPU running CoreMark from flash, radio transmitting @ 0 dBm output power, 1 Mbps Bluetooth Low Energy mode, clock = HFXO64M; regulator = LDO                 |      | 12.6 |      | mA    |
| l <sub>S15</sub> | Network CPU running CoreMark from flash, radio receiving @ 1 Mbps Bluetooth Low Energy mode, clock = HFXO64M; regulator = LDO                                        |      | 14.0 |      | mA    |



#### 4.4.1.24 USBD active

| Symbol                         | Description                                                                                                                          | Min. | Тур. | Max. | Units |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------|
| I <sub>USB,ACTIVE,VBUS</sub>   | Current from VBUS supply, USB active                                                                                                 |      | 1.2  |      | mA    |
| I <sub>USB</sub> ,SUSPEND,VBUS | Current from VBUS supply, USB suspended, CPU sleeping                                                                                |      | 180  |      | uA    |
| lusb,active,vdd                | Current from VDD supply (normal voltage mode), all RAM retained, CPU running, USB active                                             |      | 3.0  |      | mA    |
| lusb,suspend,vdd               | Current from VDD supply (normal voltage mode), all RAM retained, CPU sleeping, USB suspended                                         |      | 815  |      | uA    |
| lusb,suspend,vdd,ldo           | Current from VDD supply (normal voltage mode), all RAM retained, CPU sleeping, USB suspended, regulator = LDO                        |      | 135  |      | uA    |
| lusb,active,vddh               | Current from VDDH supply (high voltage mode), VDD=3 V (VREGH output), all RAM retained, CPU running, USB active                      |      | 3.2  |      | mA    |
| lusb,suspend,vddh              | Current from VDDH supply (high voltage mode), VDD=3 V (VREGH output), all RAM retained, CPU sleeping, USB suspended                  |      | 2340 |      | uA    |
| lusb,suspend,vddh,ldc          | Current from VDDH supply (high voltage mode), VDD=3 V (VREGH output), all RAM retained, CPU sleeping, USB suspended, regulator = LDO |      | 125  |      | uA    |
| I <sub>USB,DISABLED,VDD</sub>  | Current from VDD supply, USB disabled, VBUS supply connected, all RAM retained, CPU sleeping                                         |      | 3    |      | uA    |

# 4.5 Power supply modes and regulators

nRF5340 supports two power supply voltage ranges, each with a dedicated power supply pin. The PMU automatically activates the correct voltage regulator depending on which power supply pin is used.

The nRF5340 PMU controls three different regulators to support the following power supply modes:

- Normal voltage mode on page 42 Powers the device through the VDD pin
- High voltage mode on page 43 Powers the device through the VDDH pin

In addition, the nRF5340 has a dedicated regulator used only for USB, controlled and operated separately using USBREG — USB regulator control on page 58.

The following figure shows the regulators and how they are connected to the supply pins.





Figure 8: Regulators used in nRF5340

### 4.5.1 Normal voltage mode

When the device operates in normal voltage mode, only the main voltage regulator (VREGMAIN) and the radio voltage regulator (VREGRADIO) are used.



Figure 9: Regulator usage in normal voltage mode

The VDD and VDDH pins are connected together. The external power supply is connected to the both pins. In this case, the VREGH regulator is automatically deactivated.

In normal voltage mode, each regulator can operate in LDO or DC/DC mode. See Normal voltage mode on page 51 for details about configuration of the regulators in this mode.



## 4.5.2 High voltage mode

When the device operates in high voltage mode, the high voltage regulator (VREGH), the main voltage regulator (VREGMAIN), and the radio voltage regulator (VREGRADIO) are used.



Figure 10: Regulator usage in high voltage mode

The external power supply is connected to the VDDH pin. The VREGMAIN and VREGRADIO regulators power the internal circuitry from the VDD pin. The VREGH regulator supplies the VDD pin.

By default, the high voltage regulator is configured to source external components from the VDD pin. To save power this feature must be disabled. For details, see High voltage mode on page 52.

In high voltage mode, each of the three regulators can operate in LDO or DC/DC mode. See High voltage mode on page 52 for details about configuring the regulators in this mode.

## 4.5.3 Power supply supervisor

Several voltage monitoring devices, enabled through the power management unit (PMU), monitor the connected power supply.

The following figure illustrates the main components for power supply supervision.





Figure 11: Power supply supervision in nRF5340

The power supply mode detector determines which supply pin is used when the device is powered up. It selects the appropriate power supply mode, generates the enable signal that automatically enables VREGH, and generates a power-on reset (POR) initializing the device. For an overview of the supply modes, see Power supply modes and regulators on page 41.

The brownout detector monitors the VDD supply (input of the VREGMAIN regulator) to ensure safe operation. It generates a brownout reset (BOR) when the voltage is too low, holding the device in reset when the voltage is too low for safe operation. The brownout reset voltage is defined in parameters  $V_{BOR,OFF}$  and  $V_{BOR,ON}$ .

#### 4.5.3.1 Power-fail comparator

The power-fail comparator (POF) can provide the CPU with an early warning of an impending power supply failure.

The POF can be used to signal the application when the supply voltage drops below a configured threshold. The POF will not reset the system, but give the CPU time to prepare for an orderly power-down. The following figure shows the main elements of the POF.





Figure 12: Power-fail comparator

Using the POF is optional, and must be enabled and configured through the register POFCON (Retained) on page 55.

Depending on the supply mode (see Power supply modes and regulators on page 41), the thresholds  $V_{POF}$  and  $V_{POFH}$  must be configured to a suitable level through the POFCON register. When the supply voltage falls below the defined threshold, the POF generates the event POFWARN that is sent to the POWER module within both the application and network cores. Software running on both cores uses this signal to prepare for a power failure. This event is also generated when the supply voltage is below the threshold at the time the power-fail comparator is enabled, or if the threshold is reconfigured to a level above the supply voltage.

If the POF is enabled and the supply voltage is below the threshold, the POF prevents the NVMC from performing write operations to the NVM.

To save power, the power-fail comparator is not active in System OFF or in System ON when HFCLK is not running.

The POF features a hysteresis of V<sub>POFHYST</sub>, as illustrated in the following figure.





Figure 13: POF hysteresis and POFWARN event (BOR = brownout reset)

The POF hysteresis voltage is defined with the V<sub>POFHYST</sub> parameter in Electrical specification on page 56.

### 4.6 POWER — Power control

The POWER peripheral provides an interface for the power and clock subsystem for task, event, and interrupt related settings.

Each core has its own POWER peripheral that is responsible for requesting resources from the power and clock subsystem. The power and clock subsystem ensure that the power mode with the proper latency settings is selected when requested by an instance of the POWER peripheral. This means that for the core, the Constant latency mode is prioritized over Low-power mode. For an overview of power modes, see Power submodes on page 24.

The POFWARN event is a system level event that enables each core to react quickly if there is a power failure. The power-fail comparator must be configured and enabled in order to receive the event, see Power-fail comparator on page 44 for more information.

Power control of the RAM blocks is controlled by the Volatile memory controller (VMC), see VMC — Volatile memory controller on page 740.

**Note:** Registers INTEN on page 50, INTENSET on page 50, and INTENCLR on page 50 are shared between the POWER and CLOCK peripherals.

## 4.6.1 Registers

| Base address D | omain      | Peripheral | Instance   | Secure mapping | DMA security | Description   | Configuration |
|----------------|------------|------------|------------|----------------|--------------|---------------|---------------|
| 0x50005000     | PPLICATION | DOWER      | POWER : S  | US             | NA           | Power control |               |
| 0x40005000     | PPLICATION | POWER      | POWER : NS | 03             | NA           | rower control |               |
| 0x41005000 N   | IETWORK    | POWER      | POWER      | NS             | NA           | Power control |               |

Table 6: Instances

| Register       | Offset | Security | Description                              |
|----------------|--------|----------|------------------------------------------|
| TASKS_CONSTLAT | 0x78   |          | Enable Constant Latency mode             |
| TASKS_LOWPWR   | 0x7C   |          | Enable Low-Power mode (variable latency) |



| Register           | Offset | Security | Description                                |          |
|--------------------|--------|----------|--------------------------------------------|----------|
| SUBSCRIBE_CONSTLAT | 0xF8   |          | Subscribe configuration for task CONSTLAT  |          |
| SUBSCRIBE_LOWPWR   | 0xFC   |          | Subscribe configuration for task LOWPWR    |          |
| EVENTS_POFWARN     | 0x108  |          | Power failure warning                      |          |
| EVENTS_SLEEPENTER  | 0x114  |          | CPU entered WFI/WFE sleep                  |          |
| EVENTS_SLEEPEXIT   | 0x118  |          | CPU exited WFI/WFE sleep                   |          |
| PUBLISH_POFWARN    | 0x188  |          | Publish configuration for event POFWARN    |          |
| PUBLISH_SLEEPENTER | 0x194  |          | Publish configuration for event SLEEPENTER |          |
| PUBLISH_SLEEPEXIT  | 0x198  |          | Publish configuration for event SLEEPEXIT  |          |
| INTEN              | 0x300  |          | Enable or disable interrupt                |          |
| INTENSET           | 0x304  |          | Enable interrupt                           |          |
| INTENCLR           | 0x308  |          | Disable interrupt                          |          |
| GPREGRET[n]        | 0x51C  |          | General purpose retention register         | Retained |

Table 7: Register overview

#### 4.6.1.1 TASKS CONSTLAT

Address offset: 0x78

**Enable Constant Latency mode** 



# 4.6.1.2 TASKS\_LOWPWR

Address offset: 0x7C

Enable Low-Power mode (variable latency)



#### 4.6.1.3 SUBSCRIBE\_CONSTLAT

Address offset: 0xF8

Subscribe configuration for task CONSTLAT





### 4.6.1.4 SUBSCRIBE\_LOWPWR

Address offset: 0xFC

Subscribe configuration for task LOWPWR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24                 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |
|-------|---------|-------|----------|-----------------------------------------|-----------------------------------------------------------------|--|
| ID    |         |       |          | В                                       | A A A A A A A                                                   |  |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                 |  |
| ID    |         |       |          |                                         |                                                                 |  |
| Α     | RW      | CHIDX |          | [2550]                                  | DPPI channel that task LOWPWR will subscribe to                 |  |
| В     | RW      | EN    |          |                                         |                                                                 |  |
|       |         |       | Disabled | 0                                       | Disable subscription                                            |  |
|       |         |       | Enabled  | 1                                       | Enable subscription                                             |  |

#### 4.6.1.5 EVENTS\_POFWARN

Address offset: 0x108 Power failure warning

| Bit n | Bit number       |                |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |                  |                |              |                         | A                                                               |
| Rese  | Reset 0x00000000 |                |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                  |                |              |                         | Description                                                     |
| Α     | RW               | EVENTS_POFWARN |              |                         | Power failure warning                                           |
|       |                  |                | NotGenerated | 0                       | Event not generated                                             |
|       | Generated        |                | 1            | Event generated         |                                                                 |

### 4.6.1.6 EVENTS\_SLEEPENTER

Address offset: 0x114

CPU entered WFI/WFE sleep



### 4.6.1.7 EVENTS\_SLEEPEXIT

Address offset: 0x118





#### CPU exited WFI/WFE sleep



#### 4.6.1.8 PUBLISH POFWARN

Address offset: 0x188

Publish configuration for event POFWARN



#### 4.6.1.9 PUBLISH\_SLEEPENTER

Address offset: 0x194

Publish configuration for event SLEEPENTER



#### 4.6.1.10 PUBLISH\_SLEEPEXIT

Address offset: 0x198

Publish configuration for event SLEEPEXIT







### 4.6.1.11 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit r | Bit number         |            |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|--------------------|------------|----------|------------------------|-----------------------------------------------------------------|
| ID    | ID                 |            |          |                        | C B A                                                           |
| Rese  | Reset 0x00000000 ( |            |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                    |            |          |                        |                                                                 |
| Α     | RW                 | POFWARN    |          |                        | Enable or disable interrupt for event POFWARN                   |
|       |                    |            | Disabled | 0                      | Disable                                                         |
|       |                    |            | Enabled  | 1                      | Enable                                                          |
| В     | RW                 | SLEEPENTER |          |                        | Enable or disable interrupt for event SLEEPENTER                |
|       |                    |            | Disabled | 0                      | Disable                                                         |
|       |                    |            | Enabled  | 1                      | Enable                                                          |
| С     | RW                 | SLEEPEXIT  |          |                        | Enable or disable interrupt for event SLEEPEXIT                 |
|       |                    |            | Disabled | 0                      | Disable                                                         |
|       |                    |            | Enabled  | 1                      | Enable                                                          |

#### 4.6.1.12 INTENSET

Address offset: 0x304

Enable interrupt

| Bit number 31 30 29 28 27 26 25 24 |                  |            |          | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                                    |  |  |  |  |
|------------------------------------|------------------|------------|----------|-----------------------------------------------------------------|----------------------------------------------------|--|--|--|--|
| ID                                 | ID               |            |          |                                                                 | C B A                                              |  |  |  |  |
| Rese                               | Reset 0x00000000 |            |          | 0 0 0 0 0 0 0 0                                                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0            |  |  |  |  |
| ID R/W Field Value ID              |                  |            |          |                                                                 | Description                                        |  |  |  |  |
| Α                                  | RW               | POFWARN    |          |                                                                 | Write '1' to enable interrupt for event POFWARN    |  |  |  |  |
|                                    |                  |            | Set      | 1                                                               | Enable                                             |  |  |  |  |
|                                    |                  |            | Disabled | 0                                                               | Read: Disabled                                     |  |  |  |  |
|                                    |                  |            | Enabled  | 1                                                               | Read: Enabled                                      |  |  |  |  |
| В                                  | RW               | SLEEPENTER |          |                                                                 | Write '1' to enable interrupt for event SLEEPENTER |  |  |  |  |
|                                    |                  |            | Set      | 1                                                               | Enable                                             |  |  |  |  |
|                                    |                  |            | Disabled | 0                                                               | Read: Disabled                                     |  |  |  |  |
|                                    |                  |            | Enabled  | 1                                                               | Read: Enabled                                      |  |  |  |  |
| С                                  | RW               | SLEEPEXIT  |          |                                                                 | Write '1' to enable interrupt for event SLEEPEXIT  |  |  |  |  |
|                                    |                  |            | Set      | 1                                                               | Enable                                             |  |  |  |  |
|                                    |                  |            | Disabled | 0                                                               | Read: Disabled                                     |  |  |  |  |
|                                    |                  |            | Enabled  | 1                                                               | Read: Enabled                                      |  |  |  |  |

#### 4.6.1.13 INTENCLR

Address offset: 0x308

Disable interrupt







| Bit number |                 | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |               |                                                     |
|------------|-----------------|------------------------|-----------------------------------------------------------------|---------------|-----------------------------------------------------|
| ID         |                 |                        |                                                                 |               | C B A                                               |
| Rese       | t 0x000         | 00000                  |                                                                 | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0             |
|            |                 |                        |                                                                 |               | Description                                         |
|            |                 |                        | Disabled                                                        | 0             | Read: Disabled                                      |
|            |                 |                        | Enabled                                                         | 1             | Read: Enabled                                       |
| В          | 3 RW SLEEPENTER |                        |                                                                 |               | Write '1' to disable interrupt for event SLEEPENTER |
|            |                 |                        | Clear                                                           | 1             | Disable                                             |
|            |                 |                        | Disabled                                                        | 0             | Read: Disabled                                      |
|            |                 |                        | Enabled                                                         | 1             | Read: Enabled                                       |
| С          | RW              | SLEEPEXIT              |                                                                 |               | Write '1' to disable interrupt for event SLEEPEXIT  |
|            |                 |                        | Clear                                                           | 1             | Disable                                             |
|            |                 |                        | Disabled                                                        | 0             | Read: Disabled                                      |
|            |                 |                        | Enabled                                                         | 1             | Read: Enabled                                       |
|            |                 |                        |                                                                 |               |                                                     |

#### 4.6.1.14 GPREGRET[n] (n=0..1) (Retained)

Address offset:  $0x51C + (n \times 0x4)$ 

This register is a retained register

General purpose retention register



This register is a retained register

# 4.7 REGULATORS — Regulator control

All system components are powered from the on-chip voltage regulators. These regulators are responsible for converting the voltage supplied on the VDD or VDDH pins to adequate voltages to be used internally.

The available regulators can be configured in multiple ways to accommodate different input voltage ranges. Some modes support sourcing power to external circuitry. The voltage modes that are supported by nRF5340 are listed in the following table.

| Voltage mode        | Input voltage range | Output voltage range |  |  |
|---------------------|---------------------|----------------------|--|--|
| Normal voltage mode | 1.7 V to 3.6 V      | -                    |  |  |
| High voltage mode   | 2.5 V to 5.5 V      | 1.8 V to 3.3 V       |  |  |

Table 8: Supported voltage modes

For an overview on the available regulators, see Power supply modes and regulators on page 41.

## 4.7.1 Normal voltage mode

Normal voltage mode uses the main regulator (VREGMAIN) and the radio regulator (VREGRADIO).





The VREGMAIN and VREGRADIO regulators operate in LDO mode by default. DC/DC mode is enabled independently for each regulator using VREGMAIN.DCDCEN (Retained) on page 55 and VREGRADIO.DCDCEN (Retained) on page 56 respectively.

When configured as shown in the following figure, nRF5340 enters normal voltage mode. Here both regulators are in DC/DC mode. An external LC filter is required for each regulator in DC/DC mode. If a regulator is only to be used in LDO mode, the inductor for this regulator is not needed. In this mode, the VDDH pin must be connected to VDD, even if the high voltage regulator (VREGH) is not in use.



(\*) Inductors required only if DC/DC mode is used

Figure 14: Normal voltage mode

Operating a regulator in DC/DC mode reduces the overall power consumption due to higher efficiency than in LDO mode. Regulator efficiency in DC/DC mode varies depending on the supply voltage and the current drawn from the regulators.

## 4.7.2 High voltage mode

High voltage mode uses the main regulator (VREGMAIN), the high voltage regulator (VREGH), and the radio regulator (VREGRADIO).

All regulators operate in LDO mode by default. DC/DC mode is enabled independently for each regulator using VREGMAIN.DCDCEN (Retained) on page 55, VREGH.DCDCEN (Retained) on page 56, and VREGRADIO.DCDCEN (Retained) on page 56.

When configured as shown in the following figure, nRF5340 enters high voltage mode. Here all three regulators are in DC/DC mode. An external LC filter is required for each of the regulators in DC/DC mode. The inductor is not needed when the regulator is exclusively in LDO mode.





Figure 15: High voltage mode

Operating a regulator in DC/DC mode reduces the overall power consumption due to higher efficiency than in LDO mode. Regulator efficiency in DC/DC mode varies depending on the supply voltage and the current drawn from the regulators.

#### 4.7.2.1 External circuitry supply

In high voltage mode, the output from VREGH can be used to supply external circuitry from the VDD pin.

As illustrated in High voltage mode on page 52, external circuitry can be powered from the VDD pin. The VDD output voltage is programmed in the register UICR.VREGHVOUT.

The supported output voltage range depends on the supply voltage provided to the VDDH pin. The difference between voltage supplied on the VDDH pin and the voltage output on the VDD pin is defined by the  $V_{REGH,DROP}$  parameter in Regulator specifications, VREGH stage on page 57.

Supplying power to external circuitry is allowed in both System OFF and System ON mode.

**Note:** The maximum allowed current drawn by external circuitry is dependent on the total internal current draw. The maximum current that can be drawn externally from REGH is defined in Regulator specifications, VREGH stage on page 57).

#### 4.7.3 GPIO levels

The GPIO high reference voltage depends on the regulator voltage mode.



In normal voltage mode, the GPIO high level equals the voltage supplied to the VDD pin. In high voltage mode, it equals the level specified in the VREGHVOUT register.

## 4.7.4 Registers

| Base address [           | Domain      | Peripheral   | Instance        | Secure mapping | DMA security | Description             | Configuration |
|--------------------------|-------------|--------------|-----------------|----------------|--------------|-------------------------|---------------|
|                          |             |              | REGULATORS      | :              |              |                         |               |
| 0x50004000<br>0x40004000 | APPLICATION | I REGULATORS | S<br>REGULATORS | US<br>:        | NA           | Regulator configuration |               |
|                          |             |              | NS              |                |              |                         |               |

Table 9: Instances

| Register         | Offset | Security | Description                         |          |
|------------------|--------|----------|-------------------------------------|----------|
| MAINREGSTATUS    | 0x428  |          | Main supply status                  | Retained |
| SYSTEMOFF        | 0x500  |          | System OFF register                 |          |
| POFCON           | 0x510  |          | Power-fail comparator configuration | Retained |
| VREGMAIN.DCDCEN  | 0x704  |          | DC/DC enable register for VREGMAIN  | Retained |
| VREGRADIO.DCDCEN | 0x904  |          | DC/DC enable register for VREGRADIO | Retained |
| VREGH.DCDCEN     | 0xB00  |          | DC/DC enable register for VREGH     | Retained |

Table 10: Register overview

### 4.7.4.1 MAINREGSTATUS (Retained)

Address offset: 0x428

This register is a retained register

Main supply status

#### Note:

| Bit number      |          | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |
|-----------------|----------|----------------------|--------------------------------------------------------------------|--|--|
| ID              |          |                      | A                                                                  |  |  |
| Reset 0x0000000 | 0        | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |  |  |
| ID R/W Fiel     |          |                      |                                                                    |  |  |
| A R VR          | EGH      |                      | VREGH status                                                       |  |  |
|                 | Inactive | 0                    | Normal voltage mode. Voltage supplied on VDD and VDDH.             |  |  |
|                 | Active   | 1                    | High voltage mode. Voltage supplied on VDDH.                       |  |  |

#### **4.7.4.2 SYSTEMOFF**

Address offset: 0x500 System OFF register





# 4.7.4.3 POFCON (Retained)

Address offset: 0x510

This register is a retained register

Power-fail comparator configuration

| Bit r | number   |               |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |               |          |                        | D D D D B B B B A                                               |
| Rese  | et 0x000 | 000000        |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |               |          |                        |                                                                 |
| Α     | RW       | POF           |          |                        | Enable or disable power-fail comparator                         |
|       |          |               | Disabled | 0                      | Disable                                                         |
|       |          |               | Enabled  | 1                      | Enable                                                          |
| В     | RW       | THRESHOLD     |          |                        | Power-fail comparator threshold setting                         |
|       |          |               | V19      | 6                      | Set threshold to 1.9 V                                          |
|       |          |               | V20      | 7                      | Set threshold to 2.0 V                                          |
|       |          |               | V21      | 8                      | Set threshold to 2.1 V                                          |
|       |          |               | V22      | 9                      | Set threshold to 2.2 V                                          |
|       |          |               | V23      | 10                     | Set threshold to 2.3 V                                          |
|       |          |               | V24      | 11                     | Set threshold to 2.4 V                                          |
|       |          |               | V25      | 12                     | Set threshold to 2.5 V                                          |
|       |          |               | V26      | 13                     | Set threshold to 2.6 V                                          |
|       |          |               | V27      | 14                     | Set threshold to 2.7 V                                          |
|       |          |               | V28      | 15                     | Set threshold to 2.8 V                                          |
| D     | RW       | THRESHOLDVDDH |          |                        | Power-fail comparator threshold setting for voltage supply      |
|       |          |               |          |                        | on VDDH                                                         |
|       |          |               | V27      | 0                      | Set threshold to 2.7 V                                          |
|       |          |               | V28      | 1                      | Set threshold to 2.8 V                                          |
|       |          |               | V29      | 2                      | Set threshold to 2.9 V                                          |
|       |          |               | V30      | 3                      | Set threshold to 3.0 V                                          |
|       |          |               | V31      | 4                      | Set threshold to 3.1 V                                          |
|       |          |               | V32      | 5                      | Set threshold to 3.2 V                                          |
|       |          |               | V33      | 6                      | Set threshold to 3.3 V                                          |
|       |          |               | V34      | 7                      | Set threshold to 3.4 V                                          |
|       |          |               | V35      | 8                      | Set threshold to 3.5 V                                          |
|       |          |               | V36      | 9                      | Set threshold to 3.6 V                                          |
|       |          |               | V37      | 10                     | Set threshold to 3.7 V                                          |
|       |          |               | V38      | 11                     | Set threshold to 3.8 V                                          |
|       |          |               | V39      | 12                     | Set threshold to 3.9 V                                          |
|       |          |               | V40      | 13                     | Set threshold to 4.0 V                                          |
|       |          |               | V41      | 14                     | Set threshold to 4.1 V                                          |
|       |          |               | V42      | 15                     | Set threshold to 4.2 V                                          |

# 4.7.4.4 VREGMAIN.DCDCEN (Retained)

Address offset: 0x704

This register is a retained register

DC/DC enable register for VREGMAIN





#### 4.7.4.5 VREGRADIO.DCDCEN (Retained)

Address offset: 0x904

This register is a retained register

DC/DC enable register for VREGRADIO



#### 4.7.4.6 VREGH.DCDCEN (Retained)

Address offset: 0xB00

This register is a retained register

DC/DC enable register for VREGH



# 4.7.5 Electrical specification

### 4.7.5.1 Recommended operating conditions

| Symbol       | Description                                      | Min. | Тур. | Max. | Units |
|--------------|--------------------------------------------------|------|------|------|-------|
| $V_{DD,POR}$ | VDD supply voltage needed during power-on reset. | 1.75 |      |      | V     |
| $V_{DD}$     | Normal voltage mode operating voltage.           | 1.7  |      | 3.6  | V     |
| $V_{DDH}$    | High voltage mode operating voltage.             | 2.5  |      | 5.5  | V     |



# 4.7.5.2 Regulator specifications, VREGH stage

| Symbol                 | Description                                                         | Min. | Тур. | Max. | Units |
|------------------------|---------------------------------------------------------------------|------|------|------|-------|
| V <sub>DDOUT</sub>     | VDD output voltage.                                                 | 1.8  |      | 3.3  | V     |
| $V_{\text{DDOUT,ERR}}$ | VDD output voltage error (deviation from setting in ).              | -10  |      | +5   | %     |
| I <sub>EXT,OFF</sub>   | External current draw <sup>1</sup> allowed in high voltage mode     |      |      | 1    | mA    |
|                        | (supply on VDDH) during System OFF.                                 |      |      |      |       |
| I <sub>EXT,DCDC</sub>  | External current draw <sup>1</sup> allowed in High Voltage mode     |      |      | 7    | mA    |
|                        | (supply on VDDH) when VREGMAIN and VREGRADIO are                    |      |      |      |       |
|                        | in DC/DC mode. Assumes worst-case power consumption                 |      |      |      |       |
|                        | from both cores <sup>2</sup> , and at the lowest VDD output voltage |      |      |      |       |
|                        | setting.                                                            |      |      |      |       |
| I <sub>EXT,LDO</sub>   | External current draw <sup>1</sup> allowed in High Voltage mode     |      |      | 1    | mA    |
|                        | (supply on VDDH) when when VREGMAIN and VREGRADIO                   |      |      |      |       |
|                        | are in LDO mode. Assumes worst-case power consumption               |      |      |      |       |
|                        | from both cores <sup>2</sup> , and at the lowest VDD output voltage |      |      |      |       |
|                        | setting.                                                            |      |      |      |       |
| V <sub>REGH,DROP</sub> | Required difference between input voltage (VDDH) and                |      |      | 0.3  | V     |
|                        | output voltage (VDD, configured in VREGHVOUT on page                |      |      |      |       |
|                        | 130), VDDH > VDD                                                    |      |      |      |       |

# 4.7.5.3 Regulator startup times

| Description                                                 | Min.                                                                                                                       | Тур.                                                                                                                    | Max.                                                                                                                           | Units                                           |
|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| SE,VREGHOUT VREGH output (VDD) rise time after VDDH reaches |                                                                                                                            |                                                                                                                         |                                                                                                                                |                                                 |
| minimum VDDH supply voltage                                 |                                                                                                                            |                                                                                                                         |                                                                                                                                |                                                 |
| VDDH rise time 10 μs                                        |                                                                                                                            | 0.2                                                                                                                     | 1.6                                                                                                                            | ms                                              |
| VDDH rise time 10 ms                                        |                                                                                                                            | 5                                                                                                                       |                                                                                                                                | ms                                              |
| VDDH rise time 50 ms                                        | 30                                                                                                                         | 50                                                                                                                      | 80                                                                                                                             | ms                                              |
|                                                             | VREGH output (VDD) rise time after VDDH reaches minimum VDDH supply voltage VDDH rise time 10 $\mu s$ VDDH rise time 10 ms | VREGH output (VDD) rise time after VDDH reaches minimum VDDH supply voltage  VDDH rise time 10 µs  VDDH rise time 10 ms | VREGH output (VDD) rise time after VDDH reaches minimum VDDH supply voltage  VDDH rise time 10 µs 0.2  VDDH rise time 10 ms 5. | VREGH output (VDD) rise time after VDDH reaches |

NORDIC\*

<sup>&</sup>lt;sup>1</sup> External current draw is defined as the sum of all GPIO currents and the current being drawn from VDD.

In practice, the maximum external current draw is limited by the maximum output current of VREGH, subtracting the actual current being drawn from VDD.

#### 4.7.5.4 Power-fail comparator

| Description                                                  | Min.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Тур.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Max.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Units                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Nominal power level warning thresholds (falling supply       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| voltage) in normal voltage mode (supply on VDD). Levels      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| are configurable between min. and max. in increments of      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 100 mV.                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Nominal power level warning thresholds (falling supply       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| voltage) in high Voltage mode (supply on VDDH). Levels are   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| configurable between min. and max. in increments of 100      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| mV.                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Threshold voltage tolerance (applies in both normal voltage  | -5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | +5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | %                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| mode and high voltage mode).                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Threshold voltage hysteresis (applies in both normal voltage | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | mV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| mode and high voltage mode).                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Brownout reset voltage range System OFF mode. Brownout       | 1.54                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1.64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| only applies to the voltage on VDD.                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Brownout reset voltage range System ON mode. Brownout        | 1.57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1.63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| only applies to the voltage on VDD.                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                              | Nominal power level warning thresholds (falling supply voltage) in normal voltage mode (supply on VDD). Levels are configurable between min. and max. in increments of 100 mV.  Nominal power level warning thresholds (falling supply voltage) in high Voltage mode (supply on VDDH). Levels are configurable between min. and max. in increments of 100 mV.  Threshold voltage tolerance (applies in both normal voltage mode and high voltage mode).  Threshold voltage hysteresis (applies in both normal voltage mode and high voltage mode).  Brownout reset voltage range System OFF mode. Brownout only applies to the voltage on VDD.  Brownout reset voltage range System ON mode. Brownout | Nominal power level warning thresholds (falling supply voltage) in normal voltage mode (supply on VDD). Levels are configurable between min. and max. in increments of 100 mV.  Nominal power level warning thresholds (falling supply voltage) in high Voltage mode (supply on VDDH). Levels are configurable between min. and max. in increments of 100 mV.  Threshold voltage tolerance (applies in both normal voltage -5 mode and high voltage mode).  Threshold voltage hysteresis (applies in both normal voltage 40 mode and high voltage mode).  Brownout reset voltage range System OFF mode. Brownout 1.54 only applies to the voltage on VDD.  Brownout reset voltage range System ON mode. Brownout 1.57 | Nominal power level warning thresholds (falling supply voltage) in normal voltage mode (supply on VDD). Levels are configurable between min. and max. in increments of 100 mV.  Nominal power level warning thresholds (falling supply 2.7 voltage) in high Voltage mode (supply on VDDH). Levels are configurable between min. and max. in increments of 100 mV.  Threshold voltage tolerance (applies in both normal voltage -5 mode and high voltage mode).  Threshold voltage hysteresis (applies in both normal voltage 40 50 mode and high voltage mode).  Brownout reset voltage range System OFF mode. Brownout 1.54 only applies to the voltage on VDD.  Brownout reset voltage range System ON mode. Brownout 1.57 | Nominal power level warning thresholds (falling supply voltage) in normal voltage mode (supply on VDD). Levels are configurable between min. and max. in increments of 100 mV.  Nominal power level warning thresholds (falling supply 2.7 4.2 voltage) in high Voltage mode (supply on VDDH). Levels are configurable between min. and max. in increments of 100 mV.  Threshold voltage tolerance (applies in both normal voltage 5 +5 +5 mode and high voltage mode).  Threshold voltage hysteresis (applies in both normal voltage mode and high voltage mode).  Brownout reset voltage range System OFF mode. Brownout 1.54 1.64 only applies to the voltage on VDD.  Brownout reset voltage range System ON mode. Brownout 1.57 1.63 |

# 4.8 USBREG — USB regulator control

The USB peripheral has its own voltage regulator. When using the USB peripheral, a 5 V USB supply needs to be provided on the VBUS pin.

The USB peripheral has a dedicated internal voltage regulator for converting the VBUS supply to 3.3 V to be used by the USB signalling interface (D+ and D- lines, and pull-up on D+). The rest of the USB peripheral (USBD) is supplied through the main supply like other on-chip features. As a consequence, both VBUS and combinations of VDDH and VDD are required for USB peripheral operation. For details on configuring the main supplies, see Power supply modes and regulators on page 41.

When VBUS rises into its valid range, the software is notified through the USBDETECTED event. The USBREMOVED event is sent when VBUS goes below its valid range. Use these events to implement the USBD startup sequence described in USBD power-up sequence on page 699.

When VBUS rises into its valid range while the device is in System OFF, the device resets and transitions to System ON mode. The RESETREAS register will have the VBUS bit set to indicate the source of the wakeup.

See VBUS detection specifications on page 63 for the voltage level where events are sent ( $V_{BUS,DETECT}$  and  $V_{BUS,REMOVE}$ ) or where the system causes a wakeup from System OFF ( $V_{BUS,DETECT}$ ).

When the USBD peripheral is enabled through the ENABLE register and VBUS is detected, the regulator is turned on. A USBPWRRDY event is sent when the regulator's worst case settling time has elapsed, indicating to the software that it can enable the USB pull-up to signal a USB connection to the host.

The software can read the state of the VBUS detection and regulator output readiness at any time through the USBREGSTATUS register.





Figure 16: USB voltage regulator

To ensure stability, the input and output of the USB regulator need to be decoupled with a suitable decoupling capacitor  $C_{VBUS}$ . See Reference circuitry on page 801 for the recommended values.

# 4.8.1 Registers

| Base address Domain   | Peripheral | Instance        | Secure mapping | DMA security | Description           | Configuration |
|-----------------------|------------|-----------------|----------------|--------------|-----------------------|---------------|
|                       |            | USBREGULAT      | TOR:           |              |                       |               |
| 0x50037000 APPLICATIO | ON USBREG  | S<br>USBREGULAT | US<br>TOR :    | NA           | USB regulator control |               |
|                       |            | NS              |                |              |                       |               |

Table 11: Instances

| Register            | Offset | Security | Description                                 |
|---------------------|--------|----------|---------------------------------------------|
| EVENTS_USBDETECTED  | 0x100  |          | Voltage supply detected on VBUS             |
| EVENTS_USBREMOVED   | 0x104  |          | Voltage supply removed from VBUS            |
| EVENTS_USBPWRRDY    | 0x108  |          | USB 3.3 V supply ready                      |
| PUBLISH_USBDETECTED | 0x180  |          | Publish configuration for event USBDETECTED |
| PUBLISH_USBREMOVED  | 0x184  |          | Publish configuration for event USBREMOVED  |
| PUBLISH_USBPWRRDY   | 0x188  |          | Publish configuration for event USBPWRRDY   |
| INTEN               | 0x300  |          | Enable or disable interrupt                 |
| INTENSET            | 0x304  |          | Enable interrupt                            |
| INTENCLR            | 0x308  |          | Disable interrupt                           |
| USBREGSTATUS        | 0x400  |          | USB supply status                           |

Table 12: Register overview

### 4.8.1.1 EVENTS\_USBDETECTED

Address offset: 0x100

Voltage supply detected on VBUS





### 4.8.1.2 EVENTS\_USBREMOVED

Address offset: 0x104

Voltage supply removed from VBUS

| Bit n | umber   |                   |              | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------------|--------------|-------------------------|---------------------------------------------------------------|
| ID    |         |                   |              |                         | А                                                             |
| Rese  | t 0x000 | 00000             |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |                   |              |                         |                                                               |
| Α     | RW      | EVENTS_USBREMOVED |              |                         | Voltage supply removed from VBUS                              |
|       |         |                   | NotGenerated | 0                       | Event not generated                                           |
|       |         |                   | Generated    | 1                       | Event generated                                               |

### 4.8.1.3 EVENTS\_USBPWRRDY

Address offset: 0x108 USB 3.3 V supply ready



#### 4.8.1.4 PUBLISH USBDETECTED

Address offset: 0x180

Publish configuration for event USBDETECTED



#### 4.8.1.5 PUBLISH\_USBREMOVED

Address offset: 0x184

Publish configuration for event USBREMOVED





### 4.8.1.6 PUBLISH\_USBPWRRDY

Address offset: 0x188

Publish configuration for event USBPWRRDY

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24                 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-----------------------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | В                                       | A A A A A A A A                                                 |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                 |
| ID    |          |       |          |                                         | Description                                                     |
| Α     | RW       | CHIDX |          | [2550]                                  | DPPI channel that event USBPWRRDY will publish to.              |
| В     | RW       | EN    |          |                                         |                                                                 |
|       |          |       | Disabled | 0                                       | Disable publishing                                              |
|       |          |       | Enabled  | 1                                       | Enable publishing                                               |

#### 4.8.1.7 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit r | number   |             |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |             |          |                        | СВА                                                             |
| Res   | et 0x000 | 00000       |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |             |          |                        |                                                                 |
| Α     | RW       | USBDETECTED |          |                        | Enable or disable interrupt for event USBDETECTED               |
|       |          |             | Disabled | 0                      | Disable                                                         |
|       |          |             | Enabled  | 1                      | Enable                                                          |
| В     | RW       | USBREMOVED  |          |                        | Enable or disable interrupt for event USBREMOVED                |
|       |          |             | Disabled | 0                      | Disable                                                         |
|       |          |             | Enabled  | 1                      | Enable                                                          |
| С     | RW       | USBPWRRDY   |          |                        | Enable or disable interrupt for event USBPWRRDY                 |
|       |          |             | Disabled | 0                      | Disable                                                         |
|       |          |             | Enabled  | 1                      | Enable                                                          |

#### **4.8.1.8 INTENSET**

Address offset: 0x304

**Enable interrupt** 



Write '1' to enable interrupt for event USBDETECTED



| Bit num | Bit number |            | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                                    |
|---------|------------|------------|-------------------------|----------------------------------------------------------------------------|----------------------------------------------------|
| ID      |            |            |                         |                                                                            | СВА                                                |
| Reset 0 | x0000      | 00000      |                         | 0 0 0 0 0 0 0 0                                                            | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0            |
| ID R,   |            |            |                         |                                                                            | Description                                        |
|         |            |            | Set                     | 1                                                                          | Enable                                             |
|         |            |            | Disabled                | 0                                                                          | Read: Disabled                                     |
|         |            |            | Enabled                 | 1                                                                          | Read: Enabled                                      |
| B R     | RW         | USBREMOVED |                         |                                                                            | Write '1' to enable interrupt for event USBREMOVED |
|         |            |            | Set                     | 1                                                                          | Enable                                             |
|         |            |            | Disabled                | 0                                                                          | Read: Disabled                                     |
|         |            |            | Enabled                 | 1                                                                          | Read: Enabled                                      |
| C R     | RW         | USBPWRRDY  |                         |                                                                            | Write '1' to enable interrupt for event USBPWRRDY  |
|         |            |            | Set                     | 1                                                                          | Enable                                             |
|         |            |            | Disabled                | 0                                                                          | Read: Disabled                                     |
|         |            |            | Enabled                 | 1                                                                          | Read: Enabled                                      |

### 4.8.1.9 INTENCLR

Address offset: 0x308

Disable interrupt

| D.:   |          |             |          | 24 20 20 20 27 26 25 2 | 422222420404047464544424244400000766540224                      |
|-------|----------|-------------|----------|------------------------|-----------------------------------------------------------------|
| Bit n | umber    |             |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| ID    |          |             |          |                        | СВА                                                             |
| Rese  | et 0x000 | 00000       |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |             |          |                        | Description                                                     |
| Α     | RW       | USBDETECTED |          |                        | Write '1' to disable interrupt for event USBDETECTED            |
|       |          |             | Clear    | 1                      | Disable                                                         |
|       |          |             | Disabled | 0                      | Read: Disabled                                                  |
|       |          |             | Enabled  | 1                      | Read: Enabled                                                   |
| В     | RW       | USBREMOVED  |          |                        | Write '1' to disable interrupt for event USBREMOVED             |
|       |          |             | Clear    | 1                      | Disable                                                         |
|       |          |             | Disabled | 0                      | Read: Disabled                                                  |
|       |          |             | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW       | USBPWRRDY   |          |                        | Write '1' to disable interrupt for event USBPWRRDY              |
|       |          |             | Clear    | 1                      | Disable                                                         |
|       |          |             | Disabled | 0                      | Read: Disabled                                                  |
|       |          |             | Enabled  | 1                      | Read: Enabled                                                   |

### 4.8.1.10 USBREGSTATUS

Address offset: 0x400 USB supply status



|       |            |             | 31 30 29 28 27 26 25 2                                                 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                    |
|-------|------------|-------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------|
|       |            |             |                                                                        | B A                                                                                |
| 0x000 | 00000      |             | 0 0 0 0 0 0 0                                                          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                            |
|       |            |             |                                                                        | Description                                                                        |
| R     | VBUSDETECT |             |                                                                        | VBUS input detection status (USBDETECTED and                                       |
|       |            |             |                                                                        | USBREMOVED events are derived from this information)                               |
|       |            | NoVbus      | 0                                                                      | VBUS voltage below valid threshold                                                 |
|       |            | VbusPresent | 1                                                                      | VBUS voltage above valid threshold                                                 |
| R     | OUTPUTRDY  |             |                                                                        | USB supply output settling time elapsed                                            |
|       |            | NotReady    | 0                                                                      | USBREG output settling time not elapsed                                            |
|       |            | Ready       | 1                                                                      | USBREG output settling time elapsed (same information as                           |
|       |            |             |                                                                        | USBPWRRDY event)                                                                   |
| R     | /W         | VBUSDETECT  | /W Field Value ID  VBUSDETECT  NoVbus VbusPresent  OUTPUTRDY  NotReady | /W Field Value ID Value  VBUSDETECT  NoVbus 0 VbusPresent 1  OUTPUTRDY  NotReady 0 |

# 4.8.2 Electrical specification

### 4.8.2.1 USB operating conditions

| Symbol           | Description                | Min.      | Тур. | Max.                 | Units |
|------------------|----------------------------|-----------|------|----------------------|-------|
| V <sub>BUS</sub> | Supply voltage on VBUS pin | 4.35      | 5    | 5.5                  | V     |
| $V_{DPDM}$       | Voltage on D+ and D- lines | VSS - 0.3 |      | V <sub>USB33</sub> + | V     |
|                  |                            |           |      | 0.3                  |       |

### 4.8.2.2 USB regulator specifications

| Symbol                       | Description                                              | Min. | Тур. | Max. | Units |
|------------------------------|----------------------------------------------------------|------|------|------|-------|
| I <sub>USB,QUIES</sub>       | USB regulator quiescent current drawn from VBUS (USBD    |      | 170  |      | μΑ    |
|                              | enabled)                                                 |      |      |      |       |
| t <sub>USBPWRRDY</sub>       | Time from USB enabled to USBPWRRDY event triggered,      |      | 1    |      | ms    |
|                              | V <sub>BUS</sub> supply provided                         |      |      |      |       |
| $V_{USB33}$                  | On voltage at the USB regulator output (DECUSB pin)      | 3.0  | 3.3  | 3.6  | V     |
| R <sub>SOURCE,VBUS</sub>     | Maximum source resistance on VBUS, including cable, when |      |      | 6    | Ω     |
|                              | VDDH is not connected to VBUS                            |      |      |      |       |
| R <sub>SOURCE,VBUSVDDH</sub> | Maximum source resistance on VBUS, including cable, when |      |      | 3.8  | Ω     |
|                              | VDDH is connected to VBUS                                |      |      |      |       |
| C <sub>DECUSB</sub>          | Decoupling capacitor on the DECUSB pin                   | 2.35 | 4.7  | 5.5  | μF    |

# 4.8.2.3 VBUS detection specifications

| Symbol                  | Description                                       | Min. | Тур. | Max. | Units |
|-------------------------|---------------------------------------------------|------|------|------|-------|
| V <sub>BUS,DETECT</sub> | Voltage at which rising VBUS gets reported by     | 3.4  | 4.0  | 4.3  | V     |
|                         | USBDETECTED                                       |      |      |      |       |
| V <sub>BUS,REMOVE</sub> | Voltage at which decreasing VBUS gets reported by | 3.0  | 3.6  | 3.9  | V     |
|                         | USBREMOVED                                        |      |      |      |       |

# 4.9 VREQCTRL — Voltage request control

The VREQCTRL can request additional voltage on the VREGRADIO regulated supply to support +3 dBm TX power on RADIO.



Setting the VREGRADIO.VREQH register will request high voltage. The request is active until the register is cleared. Status register VREGRADIO.VREQHREADY indicates when the regulator has changed to high voltage.

### 4.9.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description             | Configuration |
|---------------------|------------|----------|----------------|--------------|-------------------------|---------------|
| 0x41004000 NETWORK  | VREQCTRL   | VREQCTRL | NS             | NA           | Voltage request control |               |

Table 13: Instances

| Register             | Offset | Security | Description                                                                        |          |
|----------------------|--------|----------|------------------------------------------------------------------------------------|----------|
| VREGRADIO.VREQH      | 0x500  |          | Request high voltage on RADIO                                                      | Retained |
|                      |        |          | After requesting high voltage, the user must wait until VREQHREADY is set to Ready |          |
| VREGRADIO.VREQHREADY | 0x508  |          | High voltage on RADIO is ready                                                     |          |

Table 14: Register overview

### 4.9.1.1 VREGRADIO.VREQH (Retained)

Address offset: 0x500

This register is a retained register

Request high voltage on RADIO

After requesting high voltage, the user must wait until VREQHREADY is set to Ready



#### 4.9.1.2 VREGRADIO.VREQHREADY

Address offset: 0x508

High voltage on RADIO is ready





### 4.9.2 Electrical specification

#### 4.9.2.1 VREQCTRL electrical specifications

| Symbol                       | Description                                | Min. | Тур. | Max. | Units |  |
|------------------------------|--------------------------------------------|------|------|------|-------|--|
| t <sub>VREQH,VREQREADY</sub> | Time from VREQH requested until VREQREADY. |      | 12   |      | μs    |  |

# 4.10 RESET — Reset control

A reset in the system is triggered by either a system-level or core-level reset source.

A system-level reset resets all cores. Power-on reset, brownout reset, and pin reset are examples of a system-level reset. A core-level reset, such as a soft reset or a lockup, resets either the entire core or only part of it. The different reset sources in the system are illustrated in the following figure.



Figure 17: Reset sources

After a system-level reset, the application core starts up on its own. The network core is not automatically started, but can be started by the application core CPU, see Network Force-OFF on page 67.

After a reset occurs, the register RESETREAS on page 70 can be read to determine which source generated the reset. Each core has its own RESETREAS register. System-level and application core reset sources are also available in the network core's RESETREAS register, unless otherwise noted.



#### 4.10.1 Power-on reset

The power-on reset (POR) generator initializes the system when the VDD supply voltage is above the power-on threshold. This also applies in high voltage mode, where the VDD supply voltage is provided by the high voltage regulator (VREGH).

The system is held in a reset state until the supply has reached the minimum operating voltage, and the internal voltage regulators have started. After a power-on reset, the application core is started while the network core is held in reset, see Network Force-OFF on page 67.

#### 4.10.2 Pin reset

A pin reset is generated when the physical reset pin on the device is asserted.

Similar to a power-on reset, the application core is started after the reset pin is deasserted. The network core is held in reset, see Network Force-OFF on page 67.

The reset pin has an internal pull-up resistor with the same resistance as GPIO pull-ups, see GPIO — General purpose input/output on page 224.

#### 4.10.3 Brownout reset

The brownout reset (BOR) generator puts the system in reset state if the VDD supply voltage drops below the brownout reset threshold. This also applies in high voltage mode, where the VDD supply voltage is provided by the high voltage regulator (VREGH).

Similar to a power-on reset, the application core is started after BOR is deasserted while the network core is held in reset, see Network Force-OFF on page 67.

### 4.10.4 Wakeup from System OFF mode reset

The device is reset when it wakes up from System OFF mode.

Similar to a power-on reset, the application core is started while the network core is held in reset, see Network Force-OFF on page 67.

If the device is in Debug Interface mode, the debug access port (DAP) is not reset after a wakeup from System OFF. For more information, see Debug and trace on page 751.

#### 4.10.5 Soft reset

Soft reset is generated when the SYSRESETREQ bit of the application interrupt and reset control register (AIRCR) in the Arm core is set. For more information, see Arm documentation.

When the application core performs a soft reset, the network core is held in reset, see Network Force-OFF on page 67. A soft reset in the network core will only cause the network core to reset.

A soft reset can also be generated using the RESET on page 768 register in the associated CTRL-AP.

### 4.10.6 Watchdog timer reset

A watchdog timer (WDT) reset is generated when the watchdog timer times out.

Each core has its own WDT instance. When the application core gets a WDT reset, the network core is held in reset, see Network Force-OFF on page 67. A WDT reset in the network core will only cause the network core to reset. The reset target depends on the core where WDT is instantiated.

**Note:** Because the network core WDT reset is local for the network core, the application core is not aware of WDT timing out in the network core. Notifying the application core is possible. One way is to check the register RESETREAS on page 70 for WDT flags and report the error through interprocessor communication (IPC).



For more information about WDT, see WDT — Watchdog timer on page 743. More information about IPC is available in IPC — Interprocessor communication on page 269.

#### 4.10.7 Network Force-OFF

The application core can force the network core off.

The application core can hold the network core in Force-OFF mode, using register NETWORK.FORCEOFF on page 71.

Application core resets implicitly result in the network core being held in Force-OFF. The network core will be held in Force-OFF until the application core releases it using the NETWORK.FORCEOFF register.

For details on how to use this mode, see Force-OFF mode on page 25.

### 4.10.8 Retained registers

A retained register is one that retains its value in System OFF and/or Force-OFF modes and when reset, depending on the reset source. See individual peripheral chapters for information about which registers are retained for the various peripherals.

### 4.10.9 Application core reset behavior

Application core reset behavior depends on the reset source.

Any reset in the application core will cause a network core Force-OFF, triggering the FORCEOFF reset source in the network core. For more information, see Network Force-OFF on page 67.

In System OFF mode, the watchdog timer is not running and there is no CPU lockup possible. RAM may be fully or partially retained, depending on RAM retention settings in VMC — Volatile memory controller on page 740.

If the device is in Debug Interface mode, the debug components will not be reset. Additionally, CPU lockup will not generate a reset. See Debug and trace on page 751 for more information about the different debug components in the system.

Application core reset targets and their reset sources are summarized in the following table.

An 'x' in the table means that the specific module is reset.

|                                   |     | Reset target |       |                |     |           |  |  |  |  |  |  |  |  |  |
|-----------------------------------|-----|--------------|-------|----------------|-----|-----------|--|--|--|--|--|--|--|--|--|
| Reset source                      | СРИ | Network core | Debug | RAM            | WDT | RESETREAS |  |  |  |  |  |  |  |  |  |
| CPU lockup                        | х   | х            |       |                |     |           |  |  |  |  |  |  |  |  |  |
| Soft reset                        | х   | х            |       |                |     |           |  |  |  |  |  |  |  |  |  |
| Wakeup from System OFF mode reset | х   | х            | х     | x <sup>3</sup> | х   |           |  |  |  |  |  |  |  |  |  |
| Watchdog timer reset              | х   | х            | х     | х              | х   |           |  |  |  |  |  |  |  |  |  |
| Pin reset                         | х   | х            | х     | x              | х   |           |  |  |  |  |  |  |  |  |  |
| Brownout reset                    | х   | х            | х     | х              | х   | x         |  |  |  |  |  |  |  |  |  |
| Power-on reset                    | х   | х            | х     | х              | х   | х         |  |  |  |  |  |  |  |  |  |
| NETWORK.FORCEOFF                  |     | x            |       |                |     |           |  |  |  |  |  |  |  |  |  |

Table 15: Application core reset targets and their reset sources



**Note:** RAM is never reset, but depending on the reset source, its content may be corrupted.

Some retained registers may have a different reset behavior, as shown in the following table.

An 'x' in the table means that the specific module is reset.

|                                   |                                    |     | Reset target   |                            |              |
|-----------------------------------|------------------------------------|-----|----------------|----------------------------|--------------|
| Reset source                      | Regular<br>peripheral<br>registers | SPU | GPIO           | REGULATORBO<br>OSCILLATORS | OWER.GPREGRE |
| CPU lockup                        | х                                  | x   | x <sup>4</sup> |                            |              |
| Soft reset                        | Х                                  | х   | x <sup>4</sup> |                            |              |
| Wakeup from System OFF mode reset | х                                  |     |                |                            |              |
| Watchdog timer reset              | х                                  | х   | х              | х                          |              |
| Pin reset                         | х                                  | х   | х              | х                          |              |
| Brownout reset                    | х                                  | x   | х              | х                          | х            |
| Power-on reset                    | х                                  | х   | х              | х                          | х            |

Table 16: Application core reset behavior for retained registers

#### 4.10.10 Network core reset behavior

Network core reset behavior depends on the reset source.

In System OFF mode, or when the network core is held in Force-OFF, the watchdog timer is not running and there is no CPU lockup possible. RAM may be fully or partially retained, depending on RAM retention settings in VMC — Volatile memory controller on page 740.

If the device is in Debug Interface mode, the debug components will not be reset. Additionally, CPU lockup will not generate a reset. See Debug and trace on page 751 for more information about the different debug components in the system.

Any reset in the application core will cause a network core force off, triggering the network FORCEOFF reset source in the following table. For more information, see Network Force-OFF on page 67.

<sup>&</sup>lt;sup>3</sup> Depending on RAM retention settings.

<sup>&</sup>lt;sup>4</sup> Except MCUSEL field, the MCUSEL register of the GPIO peripheral is not reset for CPU lockup and Soft reset.

An 'x' in the table means that the specific module is reset. Pin reset, brownout reset, and power-on reset are system level reset sources with the network core and application core having the same behavior, see Application core reset behavior on page 67.

| Reset source                     | Reset target |                |     |           |
|----------------------------------|--------------|----------------|-----|-----------|
| neset source                     | CPU          | RAM            | WDT | RESETREAS |
| CPU lockup                       | х            |                |     |           |
| Soft reset                       | х            |                |     |           |
| Network FORCEOFF                 | х            | x <sup>5</sup> | х   |           |
| Application Watchdog timer reset | X            | х              | х   |           |
| Local Watchdog timer reset       | х            | Х              | Х   |           |

Table 17: Network core reset target sources

**Note:** RAM is never reset, but its content may be corrupted depending on the reset source.

Some retained registers may have a different reset behavior, as shown in following table.

An 'x' in the table means that the specific module is reset. Pin reset, brownout reset, and power-on reset are system level reset sources with the network core and application core having the same behavior, see Application core reset behavior on page 67.

|                                  | Reset target                       |                |                |
|----------------------------------|------------------------------------|----------------|----------------|
| Reset source                     | Regular<br>peripheral<br>registers | GPIO           | POWER.GPREGRET |
| CPU lockup                       | X                                  | x <sup>6</sup> |                |
| Soft reset                       | X                                  | x <sup>6</sup> |                |
| Network FORCEOFF                 | x                                  |                |                |
| Application Watchdog timer reset | x                                  | х              |                |
| Local Watchdog timer reset       | x                                  | х              |                |

Table 18: Network core reset behavior for retained registers



<sup>&</sup>lt;sup>5</sup> Depending on RAM retention settings.

<sup>&</sup>lt;sup>6</sup> MCUSEL settings are kept.

# 4.10.11 Registers

| Base address Domain       | Peripheral | Instance   | Secure mapping | DMA security | Description              | Configuration         |
|---------------------------|------------|------------|----------------|--------------|--------------------------|-----------------------|
| 0x50005000                |            | RESET : S  |                |              |                          | Not supported: LSREQ, |
| APPLICATION<br>0x40005000 | N RESET    | RESET : NS | US             | NA           | Reset control and status | LLOCKUP, LDOG, MRST,  |
| 0x40003000                |            | RESEL . NS |                |              |                          | MFORCEOFF, LCTRLAP    |
| 0x41005000 NETWORK        | RESET      | RESET      | NS             | NA           | Reset status             | Not supported:        |
|                           |            |            |                |              |                          | NETWORK.FORCEOFF      |

Table 19: Instances

| Register         | Offset | Security | Description            |
|------------------|--------|----------|------------------------|
| RESETREAS        | 0x400  |          | Reset reason           |
| NETWORK.FORCEOFF | 0x614  |          | Force network core off |

Table 20: Register overview

#### 4.10.11.1 RESETREAS

Address offset: 0x400

Reset reason

Unless cleared, the RESETREAS register will be cumulative. A field is cleared by writing 1 to it. Multiple fields can be cleared at the same time by writing a value with several of the fields set to 1.

| Bit n | umber    |          |             | 31 | 30 | 29 2 | 8 27 | 7 26 | 25 | 24 | 23 | 3 22  | 21  | 20    | 19  | 18   | 17   | 16   | 15  | 14 :  | L3 1 | 2 1  | 1 1  | 0 9   | 8    | 7   | 6  | 5 4 | 4 3 | 2 | 1 | 0 |
|-------|----------|----------|-------------|----|----|------|------|------|----|----|----|-------|-----|-------|-----|------|------|------|-----|-------|------|------|------|-------|------|-----|----|-----|-----|---|---|---|
| ID    |          |          |             |    |    |      | a    | P    | 0  | N  | М  | 1     |     |       |     | K    | J    | 1    |     |       |      |      |      |       |      | Н   | G  | FI  | E D | С | В | Α |
| Rese  | et 0x000 | 00000    |             | 0  | 0  | 0 (  | 0 0  | 0    | 0  | 0  | 0  | 0     | 0   | 0     | 0   | 0    | 0    | 0    | 0   | 0     | 0 (  | 0 (  | 0 0  | 0     | 0    | 0   | 0  | 0 ( | 0 0 | 0 | 0 | 0 |
| ID    |          |          |             |    |    |      |      |      |    |    |    |       |     |       |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| Α     | RW       | RESETPIN |             |    |    |      |      |      |    |    | Re | eset  | fro | om į  | pin | re   | set  | de   | ect | ed    |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| В     | RW       | DOG0     |             |    |    |      |      |      |    |    | Re | eset  | fro | om a  | apı | olic | atio | on v | vat | chd   | og 1 | tim  | er C | ) det | ect  | ed  |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| С     | RW       | CTRLAP   |             |    |    |      |      |      |    |    | Re | eset  | fro | om a  | apı | olic | atio | on ( | CTR | L-A   | P de | ete  | ctec | t     |      |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| D     | RW       | SREQ     |             |    |    |      |      |      |    |    | Re | eset  | fro | om a  | apı | olic | atio | n s  | oft | res   | et c | lete | ecte | ed    |      |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| Ε     | RW       | LOCKUP   |             |    |    |      |      |      |    |    | Re | eset  | fro | om a  | apı | olic | atio | n (  | CPU | loc   | kup  | de   | etec | ted   |      |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| F     | RW       | OFF      |             |    |    |      |      |      |    |    | Re | eset  | du  | ie to | o w | ake  | eup  | fro  | m   | Syst  | em   | OF   | Fm   | node  | e wh | nen | wa | keu | p   |   |   |   |
|       |          |          |             |    |    |      |      |      |    |    | is | trigg | gei | red   | by  | DE   | TEC  | T s  | ign | al fı | om   | GF   | PIO  |       |      |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | d     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
| G     | RW       | LPCOMP   |             |    |    |      |      |      |    |    | Re | eset  | du  | ie to | o w | ake  | eup  | fro  | m   | Syst  | em   | OF   | Fm   | node  | e wł | ien | wa | keu | р   |   |   |   |
|       |          |          |             |    |    |      |      |      |    |    | is | trigg | gei | red   | by  | ΑN   | AD   | ETI  | СТ  | sigi  | nal  | froi | m L  | PCO   | MP   |     |    |     |     |   |   |   |
|       |          |          | NotDetected | 0  |    |      |      |      |    |    | No | ot de | ete | ecte  | d   |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          | Detected    | 1  |    |      |      |      |    |    | De | etec  | tec | b     |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |
|       |          |          |             |    |    |      |      |      |    |    |    |       |     |       |     |      |      |      |     |       |      |      |      |       |      |     |    |     |     |   |   |   |



| Bit n                  | umber    |            |                                                                                       | 31 30                                  | 29 28 | 27 26 | 5 25 2 | 4 2:                                             | 3 22 2: | 1 20 1    | 9 18  | 3 1 7 | 16    | 15 1 | 413    | 12    | 11 10  | ງ 9  | 8     | 7    | 6   | 5  | 4 = | 2   | 1 | n |
|------------------------|----------|------------|---------------------------------------------------------------------------------------|----------------------------------------|-------|-------|--------|--------------------------------------------------|---------|-----------|-------|-------|-------|------|--------|-------|--------|------|-------|------|-----|----|-----|-----|---|---|
| ID                     | uniber   |            |                                                                                       | 3130                                   | 23 20 |       | 0 1    |                                                  |         | 1 20 1    |       | J 17  |       | 15 1 | . 7 13 | 12    | 1110   | , ,  |       |      |     |    | T   |     |   |   |
|                        | + 0,,000 | 200000     |                                                                                       |                                        |       |       |        |                                                  |         |           |       |       |       |      |        | _     |        |      |       |      |     |    |     |     |   |   |
|                        | et 0x000 |            |                                                                                       |                                        |       | 0 0   | 0 (    |                                                  | 0 0     |           | U U   | U     | U     | 0 (  | 0 0    | U     | 0 0    | U    | U     | U    | U   | U  | 0 ( | , 0 | U | U |
| ID                     | R/W      |            | Value ID                                                                              | Value                                  |       |       |        |                                                  | escrip  |           |       |       | ,     |      |        |       |        |      | -     |      |     |    |     |     |   |   |
| H RW DIF               |          |            | Reset due to wakeup from System OFF mo<br>is triggered by entering the Debug Interfac |                                        |       |       |        |                                                  |         |           |       |       |       | wa   | кеι    | ıp    |        |      |       |      |     |    |     |     |   |   |
| NatDatastad            |          |            |                                                                                       |                                        |       |       |        |                                                  |         |           |       | iter  | ng t  | ne   | Debt   | ıı gı | nterra | ace  | mod   | ıe   |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        |                                                  | lot det |           | 1     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        | D)4/     | LCDEO      | Detected                                                                              | 1                                      |       |       |        | Detected  Reset from network soft reset detected |         |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| I RW LSREQ             |          |            |                                                                                       | Reset from network soft reset detected |       |       |        |                                                  |         |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | Fι                                               | unctio  | n pre     | sent  | on    | y in  | net  | wor    | k co  | ore    |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | I     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        | D                                                | etecte  | ed        |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| J                      | RW       | LLOCKUP    |                                                                                       |                                        |       |       |        | Re                                               | eset fr | om n      | etw   | ork   | CPU   | loc  | kup    | det   | ected  | ł    |       |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | Fu                                               | unctio  | n pre     | sent  | on    | y in  | net  | wor    | k co  | ore    |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | ı     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        | D                                                | etecte  | ed        |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| K                      | RW       | LDOG       |                                                                                       |                                        |       |       |        | Re                                               | eset fr | om n      | etw   | ork   | wat   | chd  | og ti  | mei   | r dete | ecte | ed .  |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | <b>.</b>                                         | unctio  | n nre     | cont  | on    | v in  | not  | wor    | k co  | aro.   |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        |                                                  | lot det |           |       | . 011 | y III | net  | .woi   | K CC  | ле     |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        |                                                  | etecte  |           | •     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| М                      | RW       | MFORCEOFF  | Detected                                                                              | 1                                      |       |       |        |                                                  | orce-O  |           | cot f | Fron  | . an  | nlic | ation  |       | ro do  | toc  | tod   |      |     |    |     |     |   |   |
| IVI                    | IVV      | WITORCEOTT |                                                                                       |                                        |       |       |        | 10                                               | orce-c  | ) I I I E | 361   | 11011 | ıap   | piic | atioi  | 1 00  | i e ue | iec  | ieu   |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | Fu                                               | unctio  | n pre     | sent  | on    | y in  | net  | wor    | k co  | ore    |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | ı     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        | D                                                | etecte  | ed        |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| N                      | RW       | NFC        |                                                                                       |                                        |       |       |        | Re                                               | eset a  | fter w    | /ake  | up f  | rom   | Sys  | stem   | OF    | F mo   | de   | due   | to I | NFC |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | fie                                              | eld be  | ing de    | etec  | ted   |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | l     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        | D                                                | etecte  | ed        |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| 0                      | RW       | DOG1       |                                                                                       |                                        |       |       |        | Re                                               | eset fr | rom a     | ppli  | catio | on w  | vatc | hdog   | g tir | ner 1  | de   | tecte | ed   |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | ı     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        |                                                  | etecte  |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| Р                      | RW       | VBUS       |                                                                                       |                                        |       |       |        | Re                                               | eset a  | fter w    | /ake  | up f  | rom   | Sys  | stem   | OF    | F mo   | de   | due   | to ۱ | /BU | JS |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | ris                                              | sing in | nto va    | lid r | ang   | е     |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | NotDetected                                                                           | 0                                      |       |       |        | N                                                | lot det | ected     | I     |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        |                                                  | etecte  |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
| Q                      | RW       | LCTRLAP    |                                                                                       |                                        |       |       |        | Re                                               | eset fr | rom n     | etw   | ork   | CTR   | L-AI | P det  | tect  | ed     |      |       |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        | Fı                                               | unctio  | n pre     | sent  | on    | y in  | net  | wor    | k co  | ore    |      |       |      |     |    |     |     |   |   |
| NotDetected 0 Not dete |          |            |                                                                                       | ected                                  | ı     |       |        |                                                  |         |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            | Detected                                                                              | 1                                      |       |       |        | D                                                | etecte  | ed        |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |
|                        |          |            |                                                                                       |                                        |       |       |        |                                                  |         |           |       |       |       |      |        |       |        |      |       |      |     |    |     |     |   |   |

### 4.10.11.2 NETWORK.FORCEOFF

Address offset: 0x614

Force network core off

Function present only in application core



| Bit number       |         | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|---------|-------------------------|---------------------------------------------------------------|
| ID               |         |                         | А                                                             |
| Reset 0x00000001 |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID R/W Field     |         |                         | Description                                                   |
| A RW FORCEOFF    |         |                         | Force network core off                                        |
| F                | Release | 0                       | Release Force-OFF                                             |
| ŀ                | Hold    | 1                       | Hold Force-OFF                                                |

# 4.10.12 Electrical specification

# 4.10.12.1 Application core startup times

| Symbol                          | Description                                            | Min. | Тур.               | Max. | Units |
|---------------------------------|--------------------------------------------------------|------|--------------------|------|-------|
| t <sub>POR</sub>                | Time in power-on reset after supply reaches minimum    |      |                    |      |       |
|                                 | operating voltage, depending on supply rise time.      |      |                    |      |       |
| t <sub>POR,10us</sub>           | VDD rise time 10 μs                                    |      | 0.7                | 1.0  | ms    |
| t <sub>POR,10ms</sub>           | VDD rise time > 10 ms                                  |      | 0                  |      | ms    |
| t <sub>PINR</sub>               | Reset time when using pin reset, depending on pin      | **   |                    |      |       |
|                                 | capacitance                                            |      |                    |      |       |
| t <sub>PINR,500nF</sub>         | 500 nF capacitance at reset pin                        |      | 13                 | 40   | ms    |
| t <sub>PINR,10uF</sub>          | 10 $\mu\text{F}$ capacitance at reset pin              |      | 260                | 800  | ms    |
| t <sub>R2ON</sub>               | Time from reset to ON (CPU execute)                    |      | t <sub>POR</sub> + |      |       |
|                                 |                                                        |      | $t_{PINR}$         |      |       |
| t <sub>OFF2ON,NM</sub>          | Time from OFF to CPU execute when in normal voltage    |      | 38                 |      | μs    |
|                                 | mode (supply on VDD)                                   |      |                    |      |       |
| t <sub>OFF2ON,LDO,HV</sub>      | Time from OFF to CPU execute when in high voltage mode |      | 38                 |      | μs    |
|                                 | (supply on VDDH) and VREGH using LDO regulator         |      |                    |      |       |
| t <sub>OFF2ON,DCDC,HV</sub>     | Time from OFF to CPU execute when in high voltage mode |      | 38                 |      | μs    |
|                                 | (supply on VDDH) and VREGH using DC/DC regulator       |      |                    |      |       |
| t <sub>IDLE2CPU</sub>           | Time from IDLE to CPU execute                          |      | 23                 |      | μs    |
| t <sub>IDLE2CPU</sub> ,CONSTLAT | Time from IDLE to CPU execute in constant latency      |      | 10                 |      | μs    |
|                                 | submode                                                |      |                    |      |       |
| t <sub>EVTSET,CL1</sub>         | Time from HW event to PPI event in Constant Latency    |      | 62.5               |      | ns    |
|                                 | System ON mode                                         |      |                    |      |       |
| t <sub>EVTSET,CLO</sub>         | Time from HW event to PPI event in Low-Power System ON |      | 62.5               |      | ns    |
|                                 | mode                                                   |      |                    |      |       |
|                                 |                                                        |      |                    |      |       |

# 4.10.12.2 Network core startup times

| Symbol                            | Description                                                     | Min. | Тур. | Max. | Units |
|-----------------------------------|-----------------------------------------------------------------|------|------|------|-------|
| t <sub>NET,EVTSET,CL1</sub>       | Time from HW event to PPI event in Constant Latency             |      | 62.5 |      | ns    |
|                                   | System ON mode                                                  |      |      |      |       |
| t <sub>NET,EVTSET,CLO</sub>       | Time from HW event to PPI event in Low-Power System ON          |      | 62.5 |      | ns    |
|                                   | mode                                                            |      |      |      |       |
| t <sub>NET,IDLE2CPU</sub>         | Time from IDLE to CPU execute                                   |      | 15   |      | μs    |
| t <sub>NET,IDLE2CPU</sub> ,CONSTL | <sub>NT</sub> Time from IDLE to CPU execute in constant latency |      | 7    |      | μs    |
|                                   | submode                                                         |      |      |      |       |
| t <sub>FO2ON,NET64</sub>          | Time for network core from OFF to CPU execute after             |      | 20   |      | μs    |
|                                   | NETWORK.FORCEOFF is released                                    |      |      |      |       |



## 4.11 CLOCK — Clock control

The clock control system can source the system clocks from a range of internal or external high and low frequency oscillators, and distribute them to peripherals and modules based on their individual requirements. Clock distribution is automated and grouped independently by module to limit current consumption in unused branches of the clock tree.

Each core subsystem has its own clock control system that is responsible for requesting resources from the power and clock subsystem.



Figure 18: Clock control

The power and clock subsystem secures glitch-free switching from one clock source to another. This applies to all clock sources.

**Note:** Registers INTEN on page 89, INTENSET on page 89, and INTENCLR on page 90 are the same registers (at the same address) as the corresponding registers in POWER.

#### 4.11.1 HFCLK controller

Each core has a number of high frequency clock (HFCLK) control instances. Each instance distributes one or more clocks to the core.

The following table lists the core clocks that are available.



| Core clock | Description                                             |  |
|------------|---------------------------------------------------------|--|
| HCLK128M   | Scalable 128 MHz CPU clock for the application core     |  |
| HCLK64M    | 64 MHz CPU clock for the network core                   |  |
| PCLK192M   | Scalable 192 MHz clock for QSPI                         |  |
| PCLK64M    | 64 MHz peripheral clock                                 |  |
| PCLK48M    | 48 MHz clock for USB                                    |  |
| PCLK32M    | 32 MHz peripheral clock                                 |  |
| PCLK16M    | 16 MHz peripheral clock                                 |  |
| PCLK1M     | 1 MHz peripheral clock                                  |  |
| ACLK       | 11.289 MHz or 12.288 MHz tunable audio peripheral clock |  |

Table 21: Core clocks

The HFCLK clocks sourced from the power and clock subsystem to the HFCLK control instances are the following:

| HFCLK clock | Description         |
|-------------|---------------------|
| HFCLK128M   | 128 MHz HFCLK clock |
| HFCLK64M    | 64 MHz HFCLK clock  |
| HFCLK192M   | 192 MHz HFCLK clock |
| HFCLKAUDIO  | Audio HFCLK clock   |

Table 22: HFCLK clocks for HFCLK control instances

In order to generate the HFCLK clocks, the following HFCLK sources are available:

- 192 MHz/128 MHz/64 MHz internal oscillator (HFINT)
- 32 MHz crystal oscillator (HFXO), optionally using built-in capacitors as described in OSCILLATORS Oscillator control on page 98

See Clock control on page 73 for more information.

CPUs, peripherals, and other system components within a core will automatically request clocks from its corresponding local HFCLK control. The HFCLK control passes the request to the power and clock subsystem and, once the clocks are running, distributes them to the components within the core.

When HFCLK control requests within a core are stopped, the HFCLK control will stop requesting clock from the power and clock subsystem. For example, when the CPU enters sleep or when peripherals have completed their tasks. If there are no HFCLK control requests from any core, the power and clock subsystem will automatically stop the clock.

When the system enters System ON mode, and a HFCLK clock is requested, the relevant HFINT will be used as the HFCLK source. When requests for the clock are stopped, the HFINT will automatically stop.

HFCLK clocks are only available to the HFCLK controllers when the system is in System ON mode.

It is possible to have a HFCLK source running before being started by the relevant clock request (for instance, the HFCLK source is kept running during sleep). This gives shorter start-up time but causes increased power consumption. Starting the HFXO is needed when crystal clock accuracy is required.



The HFCLK source selected in register HFCLKSRC on page 94 is started by triggering the HFCLKSTART task.

The source for the HFCLK128M/HFCLK64M clocks can be configured at any time (for instance, when the HFCLK has already been started). The content of the HFCLKSRC register only takes effect when the HFCLKSTART task is triggered.

The event HFCLKSTARTED is generated when the HFCLKSTART task is triggered, the oscillator is started, and the frequency is stabilized.

The HFCLK source selected in register HFCLK192MSRC on page 96 is started by triggering the HFCLK192MSTART task.

The source for the HFCLK192M clock can be configured at any time (for instance, when the HFCLK has already been started). The content of the HFCLK192MSRC register only takes effect when the HFCLK192MSTART task is triggered.

The event HFCLK192MSTARTED is generated when the HFCLK192MSTART task is triggered, the oscillator is started, and the frequency stabilized.

HFCLKAUDIO requires HFXO, so when triggering the HFCLKAUDIOSTART task, this always starts the HFXO.

The event HFCLKAUDIOSTARTED is generated when the HFCLKAUDIOSTART task is triggered, the oscillator is started, and the frequency stabilized.

It is possible to trigger a new START task after one has already been triggered, and before the corresponding STARTED event is generated. In this case, only one STARTED event will be generated, corresponding to the last triggered START task. Triggering a START task after the STARTED event from a previous triggered START task is generated, will generate a new STARTED event.

Time from a START task to the corresponding STARTED event may differ depending on whether the HFCLK source is already running or in the process of starting. The amount of time before a STARTED event may vary when a different HFCLK source is configured before triggering a new START task.

When the clock control system switches from HFINT source to HFXO source, the HFXO becomes active. The startup time is programmable, enabling the use of different types of crystal oscillators (e.g. standard crystals that may have different startup times). The HFXO startup time is given as the sum of the following:

- HFXO power-up time, as specified in 32 MHz crystal oscillator (HFXO) on page 102.
- HFXO count time, as specified in HFXOCNT on page 131.

The HFXO must be selected and started in order to do the following:

- Use RADIO
  - The network domain HFCLKSTART task is used
- Enable USBD to respond to USB traffic
  - The application domain HFCLK192MSTART is used
- Set NFCT to activated state
  - The application domain HFCLKSTART task is used
- Improve SAADC performance by reducing clock jitter
  - The application domain HFCLKSTART task is used

Each HFCLK control can request the HFXO source independently from one another via the corresponding START task. This ensures that each core and peripheral will have access to a high accuracy clock when needed. Core clocks that originate from the same HFCLK clock will also have the same HFCLK source. This means that parts of the core that have not requested the HFXO may get a clock that is more accurate than expected, but not the other way around.



All cores that have requested a HFCLK source to start by triggering a START task must also request it to stop by triggering the corresponding STOP task (see HFCLKSTOP, HFCLK192MSTOP, and HFCLKAUDIOSTOP tasks) before the power and clock subsystem will stop it.

HFCLK source(s) will stop when all corresponding STOP tasks have been triggered and there are no requests for HFCLK clock(s) from the system.

Triggering a HFCLK STOP task is required only if the corresponding HFCLK START task has been triggered before. When a HFCLK START task is triggered, it is possible to trigger again the same HFCLK START task without triggering the corresponding HFCLK STOP task in between.

#### 4.11.1.1 Application core frequency scaling

The application core clocks can be scaled from their respective HFCLK clocks.

The application core clock HCLK128M can at any time be scaled from the HFCLK128M clock using the HFCLKCTRL register.

The HCLK192M clock can be scaled from the HFCLK192M clock using the HFCLK192MCTRL register.

**Note:** Settings Div1 and Div2 in HFCLK192MCTRL register will result in increased power consumption.

The ACLK audio clock cannot be scaled from the HFCLKAUDIO clock. Instead, its frequency can be configured in the relevant peripherals. Refer to Audio oscillator on page 76 for more information on audio clock and related peripherals.

**Note:** It is possible to scale the application core clocks at any time, for instance when a clock has already has been started, without having to stop it first.

#### 4.11.1.2 32 MHz crystal oscillator (HFXO)

The 32 MHz crystal oscillator (HFXO) is controlled by a 32 MHz external crystal, see OSCILLATORS — Oscillator control on page 98.

#### 4.11.1.3 Audio oscillator

The audio oscillator generates clock frequencies suitable for audio applications.

The audio oscillator has the following features:

- Adjustable frequency with 3.3 ppm resolution in two frequency bands 11.176 MHz to 11.402 MHz, and 12.165 MHz to 12.411 MHz
- · Low jitter, suitable for audio applications
- Always uses the HFXO

The HFCLKAUDIO clock generated by the audio oscillator is suitable for use as the source clock in the I<sup>2</sup>S and PDM audio peripherals. In order to use this clock, it must be selected in the corresponding configuration registers in these peripherals. It is required to trigger the HFCLKAUDIOSTART task before it is used. To stop the HFCLKAUDIO clock, the HFCLKAUDIOSTOP task must be triggered. After triggering this task, the oscillator will be kept running as long as a peripheral is using it.

In applications where the audio data is arriving asynchronously to on-chip clocks, the frequency can be adjusted to stay in sync with the sender. The frequency can be configured in register HFCLKAUDIO.FREQUENCY on page 95 using one of the following equations.

$$f_{out} = \frac{32M}{12}(4 + HFCLKAUDIO.FREQUENCY \cdot 2^{-16})$$

Figure 19: Calculating audio frequency  $f_{out}$  from register value



# $HFCLKAUDIO.FREQUENCY = 2^{16}(\frac{12 \cdot f_{out}}{32M} - 4)$

Figure 20: Calculating register value from audio frequency  $f_{out}$ 

The acceptable HFCLKAUDIO.FREQUENCY register value ranges for the two frequency bands are listed in the following table.

When switching between the two frequency ranges, the peripherals must be stopped.

| Frequency band           | Register value and frequency |              |              |  |
|--------------------------|------------------------------|--------------|--------------|--|
|                          | Min                          | Center       | Max          |  |
| 11.176 MHz to 11.402 MHz | 12519                        | 15298        | 18068        |  |
|                          | (11.176 MHz)                 | (11.289 MHz) | (11.402 MHz) |  |
| 12.165 MHz to 12.411 MHz | 36834                        | 39854        | 42874        |  |
|                          | (12.165 MHz)                 | (12.288 MHz) | (12.411 MHz) |  |

Table 23: HFCLKAUDIO.FREQUENCY register ranges

#### 4.11.1.4 Overriding the automatic HFCLK control system

Overriding the automatic clock control system is possible to ensure a HFCLK clock is started and kept running, even if not requested.

This can be used to avoid associated HFCLK clock start-up times and have the highest clock accuracy after wake-up from sleep.

The register HFCLKALWAYSRUN on page 95 can override the automatic clock control system for the HFCLK128M/HFCLK64M clocks. This override is initiated by performing the following steps:

- 1. Set HFCLKSRC.SRC to select the HFCLK source.
- 2. Set HFCLKALWAYSRUN.ALWAYSRUN.
- 3. Trigger the HFCLKSTART task.

The register HFCLK192MALWAYSRUN on page 97 can override the automatic clock control system for the HFCLK192M clock. This override is initiated by performing the following steps:

- 1. Set HFCLK192MSRC.SRC to select the HFCLK source.
- 2. Set HFCLK192MALWAYSRUN.ALWAYSRUN.
- 3. Trigger the HFCLK192MSTART task.

Registers HFCLKSRC/HFCLK192MSRC and HFCLKALWAYSRUN/HFCLK192MALWAYSRUN can be written at any time, but are only activated by the START task.

The register HFCLKAUDIOALWAYSRUN on page 96 can override the automatic clock control system for the HFCLKAUDIO clock. The override is initiated by performing the following steps:

- 1. Set HFCLKAUDIOALWAYSRUN.ALWAYSRUN.
- 2. Trigger the HFCLKAUDIOSTART task.

**Note:** In this case, the HFCLK source is always the HFXO.

Register HFCLKAUDIOALWAYSRUN can be written at any time, but is only activated by the START task.



#### 4.11.2 LFCLK controller

Each core has a number of low frequency clock (LFCLK) control instances. Each instance distributes one or more clocks to the core.

The LFCLK control instance in each core distributes the 32.768 kHz PCLK32KI peripheral clock to its corresponding core. The LFCLK clock is sourced from the power and clock subsystem to each LFCLK control instance.

In order to generate the LFCLK clock, the LFCLK controller uses the following LFCLK sources:

- 32.768 kHz RC oscillator (LFRC)
- 32.768 kHz crystal oscillator (LFXO)
- 32.768 kHz synthesized from HFCLK (LFSYNT)

For an illustration of the clock sources, see Clock control on page 73.

The LFCLK controller and all LFCLK sources are switched off in System OFF mode.

When peripherals require the PCLK32KI clock, such as RTC — Real-time counter on page 509 and WDT — Watchdog timer on page 743, the LFCLK control will automatically request the LFCLK clock to the power and clock subsystem. The default LFCLK source is the LFRC.

When LFCLK control requests are stopped, LFCLK will stop requesting clock from the power and clock subsystem. If there are no LFCLK control requests from other cores, the power and clock subsystem will automatically stop the LFCLK clock and the LFRC source.

The LFCLK source may also be started by triggering the LFCLKSTART task. The LFCLK source is configured by selecting the preferred LFCLK source in register LFCLKSRC on page 94. Once selected, the LFCLK source will be started by triggering the LFCLKSTART task.

The LFCLK source can be configured at any time (for instance, when the LFCLK has already been started). The content of the LFCLKSRC register only takes effect when the LFCLKSTART task is triggered.

**Note:** Automatic requests of the LFCLK clock will ignore the value in LFCLKSRC and use LFRC as source, unless the LFCLK source is started by triggering the LFCLKSTART start. In this case, the LFCLK source will correspond to the value in LFCLKSRC when the LFCLKSTART start was last triggered.

The LFCLKSTARTED event will be generated after the LFCLKSTART task has been triggered and the LFCLK source has started. Triggering a LFCLKSTART task before the LFCLKSTARTED event from a previous LFCLKSTART task is generated will only generate one LFCLKSTARTED event. Triggering a LFCLKSTART task after a LFCLKSTARTED event is generated will generate a new LFCLKSTARTED event.

The LFCLK clock is stopped when nothing requests it, e.g. RTC — Real-time counter on page 509 and WDT — Watchdog timer on page 743 are stopped, and the LFCLKSTOP task is triggered. This must be done for all cores. Triggering the LFCLKSTOP task is required only if the LFCLKSTART task has been triggered before.

When the LFCLKSTART task is triggered, it is possible to trigger a new LFCLKSTART task without triggering a LFCLKSTOP task in between.

If the LFXO is selected as the LFCLK source, the LFCLK clock will initially start running from the LFRC while the LFXO is starting up, and then automatically switch to using the LFXO once this oscillator is running.

Events will be generated in the correct order, even if an LFCLK source that is already started by another LFCLK control instance is requested. The timing of events may differ, depending on whether a LFCLK source is already running or in the process of starting.

If two instances of the LFCLK control system request different LFCLK sources, the power and clock subsystem will secure that the most accurate of the requested LFCLK sources is selected. If one LFCLK control instance requests a particular LFCLK source to stop when another LFCLK control instance (or a



peripheral) requests the same source to run, but at a lower accuracy, the power and clock subsystem will switch to the less accurate source. The following table summarizes the priorities of the LFCLK sources.

| Priority       | LFCLK source |
|----------------|--------------|
| Highest        | LFSYNT       |
| Second highest | LFXO         |
| Lowest         | LFRC         |

Table 24: LFCLK request priority

When switching the LFCLK source, such as from LFRC to LFXO, up to one LFCLK cycle may be lost.

#### 4.11.2.1 32.768 kHz RC oscillator (LFRC)

An internal 32.768 kHz RC oscillator (LFRC) is available as the LFCLK source.

The LFRC oscillator is fully embedded in nRF5340 and does not require additional external components.

#### 4.11.2.1.1 Calibrating the 32.768 kHz RC oscillator

To improve accuracy of the LFRC oscillator, it can be calibrated using the HFXO as a reference oscillator.

The LFRC oscillator can be calibrated while it is running. The calibration is started by triggering the CAL task which temporarily requests the HFCLK with the HFXO as the source for calibration.

A DONE event will be generated when the calibration is finished.

**Note:** Any core changing the LFCLK source will abort calibration without the DONE event being generated in the core triggering the CAL task.

If the CAL task is triggered while a calibration routine is already running (i.e. before the DONE event is generated), the CAL task has no effect and the calibration continues.

All cores can trigger the CAL task independently of each other. As a result, each core will receive a corresponding DONE event. If the calibration routine is already running (i.e. a core has triggered the CAL task), and the CAL task is triggered from another core, a DONE event is generated in both cores when the calibration of its corresponding LFRC oscillator is complete.

#### 4.11.2.2 32.768 kHz crystal oscillator (LFXO)

For higher LFCLK accuracy (when greater than ± 250 ppm accuracy is required), the low frequency crystal oscillator (LFXO) must be used.

This clock source requires external components and GPIO pin configuration, see OSCILLATORS — Oscillator control on page 98.

#### 4.11.2.3 32.768 kHz synthesized from HFCLK (LFSYNT)

The LFCLK can be synthesized from the HFCLK clock source.

LFSYNTH depends on the HFCLK to run. The accuracy of the LFCLK clock with the LFSYNTH as a source assumes the accuracy of the HFCLK. If high accuracy is required, the HFCLK must be generated from the HFXO.

Using the LFSYNT clock removes the requirement for an external 32.768 kHz crystal, but increases average power consumption as the HFCLK will need to be requested in the system.



## 4.11.2.4 Overriding the automatic LFCLK control system

Overriding the automatic clock control system to ensure the LFCLK clock is started and kept running is possible, even if not requested.

This can be used to avoid associated LFCLK clock start-up times and have the highest clock accuracy after wake-up from sleep.

The register LFCLKALWAYSRUN on page 96 can override the automatic clock control system. This override is initiated by performing the following steps:

- 1. Set LFCLKSRC.SRC to select the LFCLK source.
- 2. Set LFCLKALWAYSRUN.ALWAYSRUN.
- **3.** Trigger the LFCLKSTART task.

Registers LFCLKSRC.SRC and LFCLKALWAYSRUN.ALWAYSRUN can be written at any time, but are only activated by the LFCLKSTART task.

## 4.11.3 Registers

| Base address | Domain            | Peripheral | Instance   | Secure mapping | DMA security | Description   | Configuration            |
|--------------|-------------------|------------|------------|----------------|--------------|---------------|--------------------------|
| 0x50005000   | A DDI ICATION     | CLOCK      | CLOCK : S  | US             | NA           | Clock control |                          |
| 0x40005000   | APPLICATION CLOCK |            | CLOCK : NS | 03             | NA .         | Clock control |                          |
| 0x41005000   | NETWORK           | CLOCK      | CLOCK      | NS             | NA           | Clock control | HFCLKAUDIO not           |
|              |                   |            |            |                |              |               | supported                |
|              |                   |            |            |                |              |               | HFCLK192M not supported  |
|              |                   |            |            |                |              |               | HFCLKCTRL reset value is |
|              |                   |            |            |                |              |               | 0x0.                     |

Table 25: Instances

| Register                  | Offset | Security | Description                                             |
|---------------------------|--------|----------|---------------------------------------------------------|
| TASKS_HFCLKSTART          | 0x000  |          | Start HFCLK128M/HFCLK64M source as selected in HFCLKSRC |
| TASKS_HFCLKSTOP           | 0x004  |          | Stop HFCLK128M/HFCLK64M source                          |
| TASKS_LFCLKSTART          | 0x008  |          | Start LFCLK source as selected in LFCLKSRC              |
| TASKS_LFCLKSTOP           | 0x00C  |          | Stop LFCLK source                                       |
| TASKS_CAL                 | 0x010  |          | Start calibration of LFRC oscillator                    |
| TASKS_HFCLKAUDIOSTART     | 0x018  |          | Start HFCLKAUDIO source                                 |
| TASKS_HFCLKAUDIOSTOP      | 0x01C  |          | Stop HFCLKAUDIO source                                  |
| TASKS_HFCLK192MSTART      | 0x020  |          | Start HFCLK192M source as selected in HFCLK192MSRC      |
| TASKS_HFCLK192MSTOP       | 0x024  |          | Stop HFCLK192M source                                   |
| SUBSCRIBE_HFCLKSTART      | 0x080  |          | Subscribe configuration for task HFCLKSTART             |
| SUBSCRIBE_HFCLKSTOP       | 0x084  |          | Subscribe configuration for task HFCLKSTOP              |
| SUBSCRIBE_LFCLKSTART      | 0x088  |          | Subscribe configuration for task LFCLKSTART             |
| SUBSCRIBE_LFCLKSTOP       | 0x08C  |          | Subscribe configuration for task LFCLKSTOP              |
| SUBSCRIBE_CAL             | 0x090  |          | Subscribe configuration for task CAL                    |
| SUBSCRIBE_HFCLKAUDIOSTART | 0x098  |          | Subscribe configuration for task HFCLKAUDIOSTART        |
| SUBSCRIBE_HFCLKAUDIOSTOP  | 0x09C  |          | Subscribe configuration for task HFCLKAUDIOSTOP         |
| SUBSCRIBE_HFCLK192MSTART  | 0x0A0  |          | Subscribe configuration for task HFCLK192MSTART         |
| SUBSCRIBE_HFCLK192MSTOP   | 0x0A4  |          | Subscribe configuration for task HFCLK192MSTOP          |
| EVENTS_HFCLKSTARTED       | 0x100  |          | HFCLK128M/HFCLK64M source started                       |
| EVENTS_LFCLKSTARTED       | 0x104  |          | LFCLK source started                                    |
| EVENTS_DONE               | 0x11C  |          | Calibration of LFRC oscillator complete event           |
| EVENTS_HFCLKAUDIOSTARTED  | 0x120  |          | HFCLKAUDIO source started                               |
| EVENTS_HFCLK192MSTARTED   | 0x124  |          | HFCLK192M source started                                |



| Register                  | Offset | Security | Description                                                                           |
|---------------------------|--------|----------|---------------------------------------------------------------------------------------|
| PUBLISH_HFCLKSTARTED      | 0x180  |          | Publish configuration for event HFCLKSTARTED                                          |
| PUBLISH_LFCLKSTARTED      | 0x184  |          | Publish configuration for event LFCLKSTARTED                                          |
| PUBLISH_DONE              | 0x19C  |          | Publish configuration for event DONE                                                  |
| PUBLISH_HFCLKAUDIOSTARTED | 0x1A0  |          | Publish configuration for event HFCLKAUDIOSTARTED                                     |
| PUBLISH_HFCLK192MSTARTED  | 0x1A4  |          | Publish configuration for event HFCLK192MSTARTED                                      |
| INTEN                     | 0x300  |          | Enable or disable interrupt                                                           |
| INTENSET                  | 0x304  |          | Enable interrupt                                                                      |
| INTENCLR                  | 0x308  |          | Disable interrupt                                                                     |
| INTPEND                   | 0x30C  |          | Pending interrupts                                                                    |
| HFCLKRUN                  | 0x408  |          | Status indicating that HFCLKSTART task has been triggered                             |
| HFCLKSTAT                 | 0x40C  |          | Status indicating which HFCLK128M/HFCLK64M source is running                          |
|                           |        |          | This register value in any CLOCK instance reflects status only due to configurations/ |
|                           |        |          | actions in that CLOCK instance.                                                       |
| LFCLKRUN                  | 0x414  |          | Status indicating that LFCLKSTART task has been triggered                             |
| LFCLKSTAT                 | 0x418  |          | Status indicating which LFCLK source is running                                       |
|                           |        |          | This register value in any CLOCK instance reflects status only due to configurations/ |
|                           |        |          | actions in that CLOCK instance.                                                       |
| LFCLKSRCCOPY              | 0x41C  |          | Copy of LFCLKSRC register, set when LFCLKSTART task was triggered                     |
| HFCLKAUDIORUN             | 0x450  |          | Status indicating that HFCLKAUDIOSTART task has been triggered                        |
| HFCLKAUDIOSTAT            | 0x454  |          | Status indicating which HFCLKAUDIO source is running                                  |
| HFCLK192MRUN              | 0x458  |          | Status indicating that HFCLK192MSTART task has been triggered                         |
| HFCLK192MSTAT             | 0x45C  |          | Status indicating which HFCLK192M source is running                                   |
| HFCLKSRC                  | 0x514  |          | Clock source for HFCLK128M/HFCLK64M                                                   |
| LFCLKSRC                  | 0x518  |          | Clock source for LFCLK                                                                |
| HFCLKCTRL                 | 0x558  |          | HFCLK128M frequency configuration                                                     |
| HFCLKAUDIO.FREQUENCY      | 0x55C  |          | Audio PLL frequency in 11.176 MHz - 11.402 MHz or 12.165 MHz - 12.411 MHz             |
|                           |        |          | frequency bands                                                                       |
| HFCLKALWAYSRUN            | 0x570  |          | Automatic or manual control of HFCLK128M/HFCLK64M                                     |
| LFCLKALWAYSRUN            | 0x574  |          | Automatic or manual control of LFCLK                                                  |
| HFCLKAUDIOALWAYSRUN       | 0x57C  |          | Automatic or manual control of HFCLKAUDIO                                             |
| HFCLK192MSRC              | 0x580  |          | Clock source for HFCLK192M                                                            |
| HFCLK192MALWAYSRUN        | 0x584  |          | Automatic or manual control of HFCLK192M                                              |
|                           |        |          |                                                                                       |

Table 26: Register overview

## 4.11.3.1 TASKS\_HFCLKSTART

Address offset: 0x000

Start HFCLK128M/HFCLK64M source as selected in HFCLKSRC



## 4.11.3.2 TASKS\_HFCLKSTOP

Address offset: 0x004



#### Stop HFCLK128M/HFCLK64M source



#### 4.11.3.3 TASKS\_LFCLKSTART

Address offset: 0x008

Start LFCLK source as selected in LFCLKSRC

| Bit n | umber    |                  |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------------|---------|------------------------|-----------------------------------------------------------------|
| ID    |          |                  |         |                        | А                                                               |
| Rese  | et 0x000 | 00000            |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                  |         |                        | Description                                                     |
| Α     | W        | TASKS_LFCLKSTART |         |                        | Start LFCLK source as selected in LFCLKSRC                      |
|       |          |                  | Trigger | 1                      | Trigger task                                                    |

## 4.11.3.4 TASKS\_LFCLKSTOP

Address offset: 0x00C Stop LFCLK source

| Bit n | umber   |                 |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------------|---------|------------------------|-----------------------------------------------------------------|
| ID    |         |                 |         |                        | A                                                               |
| Rese  | t 0x000 | 00000           |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                 |         |                        | Description                                                     |
| Α     | W       | TASKS_LFCLKSTOP |         |                        | Stop LFCLK source                                               |
|       |         |                 | Trigger | 1                      | Trigger task                                                    |

## 4.11.3.5 TASKS\_CAL

Address offset: 0x010

Start calibration of LFRC oscillator



#### 4.11.3.6 TASKS\_HFCLKAUDIOSTART

Address offset: 0x018
Start HFCLKAUDIO source





## 4.11.3.7 TASKS\_HFCLKAUDIOSTOP

Address offset: 0x01C
Stop HFCLKAUDIO source



## 4.11.3.8 TASKS\_HFCLK192MSTART

Address offset: 0x020

Start HFCLK192M source as selected in HFCLK192MSRC



#### 4.11.3.9 TASKS HFCLK192MSTOP

Address offset: 0x024
Stop HFCLK192M source



#### 4.11.3.10 SUBSCRIBE\_HFCLKSTART

Address offset: 0x080

Subscribe configuration for task HFCLKSTART





#### 4.11.3.11 SUBSCRIBE HFCLKSTOP

Address offset: 0x084

Subscribe configuration for task HFCLKSTOP



## 4.11.3.12 SUBSCRIBE\_LFCLKSTART

Address offset: 0x088

Subscribe configuration for task LFCLKSTART



#### 4.11.3.13 SUBSCRIBE\_LFCLKSTOP

Address offset: 0x08C

Subscribe configuration for task LFCLKSTOP







#### 4.11.3.14 SUBSCRIBE\_CAL

Address offset: 0x090

Subscribe configuration for task CAL



#### 4.11.3.15 SUBSCRIBE\_HFCLKAUDIOSTART

Address offset: 0x098

Subscribe configuration for task HFCLKAUDIOSTART



#### 4.11.3.16 SUBSCRIBE\_HFCLKAUDIOSTOP

Address offset: 0x09C

Subscribe configuration for task HFCLKAUDIOSTOP



#### 4.11.3.17 SUBSCRIBE HFCLK192MSTART

Address offset: 0x0A0

Subscribe configuration for task HFCLK192MSTART





## 4.11.3.18 SUBSCRIBE\_HFCLK192MSTOP

Address offset: 0x0A4

Subscribe configuration for task HFCLK192MSTOP



## 4.11.3.19 EVENTS\_HFCLKSTARTED

Address offset: 0x100

HFCLK128M/HFCLK64M source started

| Bit n | umber   |                     |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                     |              |                         | A                                                               |
| Rese  | t 0x000 | 00000               |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                     |              |                         |                                                                 |
| Α     | RW      | EVENTS_HFCLKSTARTED | )            |                         | HFCLK128M/HFCLK64M source started                               |
|       |         |                     | NotGenerated | 0                       | Event not generated                                             |
|       |         |                     | Generated    | 1                       | Event generated                                                 |

#### 4.11.3.20 EVENTS\_LFCLKSTARTED

Address offset: 0x104

LFCLK source started



#### 4.11.3.21 EVENTS\_DONE

Address offset: 0x11C





#### Calibration of LFRC oscillator complete event



#### 4.11.3.22 EVENTS HFCLKAUDIOSTARTED

Address offset: 0x120

**HFCLKAUDIO** source started



#### 4.11.3.23 EVENTS\_HFCLK192MSTARTED

Address offset: 0x124

HFCLK192M source started



## 4.11.3.24 PUBLISH\_HFCLKSTARTED

Address offset: 0x180

Publish configuration for event HFCLKSTARTED







#### 4.11.3.25 PUBLISH\_LFCLKSTARTED

Address offset: 0x184

Publish configuration for event LFCLKSTARTED



#### 4.11.3.26 PUBLISH\_DONE

Address offset: 0x19C

Publish configuration for event **DONE** 



## 4.11.3.27 PUBLISH\_HFCLKAUDIOSTARTED

Address offset: 0x1A0

Publish configuration for event HFCLKAUDIOSTARTED



#### 4.11.3.28 PUBLISH\_HFCLK192MSTARTED

Address offset: 0x1A4

Publish configuration for event HFCLK192MSTARTED



| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |   |               |
|-------|----------|-------|----------|-------------------------|---------------------------------------------------------------|---|---------------|
| ID    | ID       |       | ID       |                         |                                                               | В | A A A A A A A |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |   |               |
| ID    |          |       |          |                         | Description                                                   |   |               |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that event HFCLK192MSTARTED will publish         |   |               |
|       |          |       |          |                         | to.                                                           |   |               |
| В     | RW       | EN    |          |                         |                                                               |   |               |
|       |          |       | Disabled | 0                       | Disable publishing                                            |   |               |
|       |          |       | Enabled  | 1                       | Enable publishing                                             |   |               |

## 4.11.3.29 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit r | umber    |                   |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                   |          |                         | E D C B A                                                       |
| Res   | et 0x000 | 00000             |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                   |          |                         |                                                                 |
| Α     | RW       | HFCLKSTARTED      |          |                         | Enable or disable interrupt for event HFCLKSTARTED              |
|       |          |                   | Disabled | 0                       | Disable                                                         |
|       |          |                   | Enabled  | 1                       | Enable                                                          |
| В     | RW       | LFCLKSTARTED      |          |                         | Enable or disable interrupt for event LFCLKSTARTED              |
|       |          | Disabled          | 0        | Disable                 |                                                                 |
|       |          |                   | Enabled  | 1                       | Enable                                                          |
| С     | RW       | DONE              |          |                         | Enable or disable interrupt for event DONE                      |
|       |          |                   | Disabled | 0                       | Disable                                                         |
|       |          |                   | Enabled  | 1                       | Enable                                                          |
| D     | RW       | HFCLKAUDIOSTARTED |          |                         | Enable or disable interrupt for event HFCLKAUDIOSTARTED         |
|       |          |                   | Disabled | 0                       | Disable                                                         |
|       |          |                   | Enabled  | 1                       | Enable                                                          |
| Е     | RW       | HFCLK192MSTARTED  |          |                         | Enable or disable interrupt for event HFCLK192MSTARTED          |
|       |          |                   | Disabled | 0                       | Disable                                                         |
|       |          |                   | Enabled  | 1                       | Enable                                                          |

## 4.11.3.30 INTENSET

Address offset: 0x304

Enable interrupt

| Bit r | Bit number       |              |          | 31 30 29 28 27 26 25 2                               | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|--------------|----------|------------------------------------------------------|-----------------------------------------------------------------|--|--|--|
| ID    |                  |              |          |                                                      | E D C B A                                                       |  |  |  |
| Res   | Reset 0x00000000 |              |          | 0 0 0 0 0 0 0                                        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |
| ID    |                  |              |          |                                                      |                                                                 |  |  |  |
| Α     | RW               | HFCLKSTARTED |          | Write '1' to enable interrupt for event HFCLKSTARTED |                                                                 |  |  |  |
|       |                  |              | Set      | 1                                                    | Enable                                                          |  |  |  |
|       |                  |              | Disabled | 0                                                    | Read: Disabled                                                  |  |  |  |
|       |                  |              | Enabled  | 1                                                    | Read: Enabled                                                   |  |  |  |
| В     | RW               | LFCLKSTARTED |          |                                                      | Write '1' to enable interrupt for event LFCLKSTARTED            |  |  |  |
|       |                  |              | Set      | 1                                                    | Enable                                                          |  |  |  |
|       |                  |              | Disabled | 0                                                    | Read: Disabled                                                  |  |  |  |
|       |                  |              | Enabled  | 1                                                    | Read: Enabled                                                   |  |  |  |
| С     | RW               | DONE         |          |                                                      | Write '1' to enable interrupt for event DONE                    |  |  |  |

| Bit n | umber            |                   |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |
|-------|------------------|-------------------|----------|------------------------|-----------------------------------------------------------------|--|--|--|--|
| ID    |                  |                   |          |                        | E D C B A                                                       |  |  |  |  |
| Rese  | Reset 0x00000000 |                   |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |  |
| ID    |                  |                   |          |                        | Description                                                     |  |  |  |  |
|       |                  |                   | Set      | 1                      | Enable                                                          |  |  |  |  |
|       |                  |                   | Disabled | 0                      | Read: Disabled                                                  |  |  |  |  |
|       |                  |                   | Enabled  | 1                      | Read: Enabled                                                   |  |  |  |  |
| D     | RW               | HFCLKAUDIOSTARTED |          |                        | Write '1' to enable interrupt for event                         |  |  |  |  |
|       |                  |                   |          |                        | HFCLKAUDIOSTARTED                                               |  |  |  |  |
|       |                  |                   | Set      | 1                      | Enable                                                          |  |  |  |  |
|       |                  |                   | Disabled | 0                      | Read: Disabled                                                  |  |  |  |  |
|       |                  |                   | Enabled  | 1                      | Read: Enabled                                                   |  |  |  |  |
| E     | RW               | HFCLK192MSTARTED  |          |                        | Write '1' to enable interrupt for event HFCLK192MSTARTED        |  |  |  |  |
|       |                  |                   | Set      | 1                      | Enable                                                          |  |  |  |  |
|       |                  |                   | Disabled | 0                      | Read: Disabled                                                  |  |  |  |  |
|       |                  |                   | Enabled  | 1                      | Read: Enabled                                                   |  |  |  |  |

#### 4.11.3.31 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |                   |          | 31 30 29 28 27 2 | 26 25 24 | 1 23 22 2                                             | 21 20 1 | 19 1  | 8 17   | 16   | 15 1 | 4 13 | 12  | 11 10 | 0 9 | 8   | 7   | 6 5 | 4 | 3 | 2 1 | 1 0 |
|-------|----------|-------------------|----------|------------------|----------|-------------------------------------------------------|---------|-------|--------|------|------|------|-----|-------|-----|-----|-----|-----|---|---|-----|-----|
| ID    |          |                   |          |                  |          |                                                       |         |       |        |      |      |      |     |       | Е   | D   | С   |     |   |   | E   | 3 A |
| Rese  | et 0x000 | 00000             |          | 0 0 0 0 0        | 0 0 0    | 0 0                                                   | 0 0     | 0 0   | 0 0    | 0    | 0 0  | 0    | 0   | 0 0   | 0   | 0   | 0   | 0 0 | 0 | 0 | 0 ( | 0 0 |
|       |          |                   |          |                  |          |                                                       |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
| Α     | RW       | HFCLKSTARTED      |          |                  |          | Write '                                               | 1' to d | lisak | ole ir | nter | rupt | for  | eve | nt HI | CLF | STA | RTE | D   |   |   |     |     |
|       |          |                   | Clear    | 1                |          | Disable                                               | e       |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Disabled | 0                |          | Read: I                                               | Disable | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Enabled  | 1                |          | Read: I                                               | Enable  | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
| В     | RW       | LFCLKSTARTED      |          |                  |          | Write '1' to disable interrupt for event LFCLKSTARTED |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Clear    | 1                |          | Disable                                               |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Disabled | 0                |          | Read: Disabled                                        |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Enabled  | 1                |          | Read: Enabled                                         |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
| С     | RW       | DONE              |          |                  |          | Write '1' to disable interrupt for event DONE         |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Clear    | 1                |          | Disable                                               | e       |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Disabled | 0                |          | Read: I                                               | Disable | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Enabled  | 1                |          | Read: I                                               | Enable  | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
| D     | RW       | HFCLKAUDIOSTARTED |          |                  |          | Write '                                               | 1' to d | lisak | ole ir | nter | rupt | for  | eve | nt    |     |     |     |     |   |   |     |     |
|       |          |                   |          |                  |          | HFCLK                                                 | AUDIO   | STA   | RTE    | D    |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Clear    | 1                |          | Disable                                               | e       |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Disabled | 0                |          | Read: I                                               | Disable | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Enabled  | 1                |          | Read: I                                               | Enable  | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
| Ε     | RW       | HFCLK192MSTARTED  |          |                  |          | Write '                                               | 1' to d | lisat | ole ir | nter | rupt | for  | eve | nt    |     |     |     |     |   |   |     |     |
|       |          |                   |          |                  |          | HFCLK:                                                | 192MS   | STAF  | RTED   | )    |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Clear    | 1                |          | Disable                                               | e       |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Disabled | 0                |          | Read: [                                               | Disable | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   | Enabled  | 1                |          | Read: I                                               | Enable  | ed    |        |      |      |      |     |       |     |     |     |     |   |   |     |     |
|       |          |                   |          |                  |          |                                                       |         |       |        |      |      |      |     |       |     |     |     |     |   |   |     |     |

## 4.11.3.32 INTPEND

Address offset: 0x30C
Pending interrupts



| Bit n | umber    |                   |            | 31 30 29 28 27 26 25 24 | 1 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |
|-------|----------|-------------------|------------|-------------------------|-----------------------------------------------------------------|--|--|--|--|
| ID    |          |                   |            |                         | E D C B A                                                       |  |  |  |  |
| Rese  | et 0x000 | 00000             |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |  |
| ID    |          |                   |            |                         | Description                                                     |  |  |  |  |
| Α     | R        | HFCLKSTARTED      |            |                         | Read pending status of interrupt for event HFCLKSTARTED         |  |  |  |  |
|       |          |                   | NotPending | 0                       | Read: Not pending                                               |  |  |  |  |
|       |          |                   | Pending    | 1                       | Read: Pending                                                   |  |  |  |  |
| В     | R        | LFCLKSTARTED      |            |                         | Read pending status of interrupt for event LFCLKSTARTED         |  |  |  |  |
|       |          |                   | NotPending | 0                       | Read: Not pending                                               |  |  |  |  |
|       |          |                   | Pending    | 1                       | Read: Pending                                                   |  |  |  |  |
| С     | R        | DONE              |            |                         | Read pending status of interrupt for event DONE                 |  |  |  |  |
|       |          |                   | NotPending | 0                       | Read: Not pending                                               |  |  |  |  |
|       |          |                   | Pending    | 1                       | Read: Pending                                                   |  |  |  |  |
| D     | R        | HFCLKAUDIOSTARTED |            |                         | Read pending status of interrupt for event                      |  |  |  |  |
|       |          |                   |            |                         | HFCLKAUDIOSTARTED                                               |  |  |  |  |
|       |          |                   | NotPending | 0                       | Read: Not pending                                               |  |  |  |  |
|       |          |                   | Pending    | 1                       | Read: Pending                                                   |  |  |  |  |
| Е     | R        | HFCLK192MSTARTED  |            |                         | Read pending status of interrupt for event                      |  |  |  |  |
|       |          |                   |            |                         | HFCLK192MSTARTED                                                |  |  |  |  |
|       |          |                   | NotPending | 0                       | Read: Not pending                                               |  |  |  |  |
|       |          |                   | Pending    | 1                       | Read: Pending                                                   |  |  |  |  |

#### 4.11.3.33 HFCLKRUN

Address offset: 0x408

Status indicating that HFCLKSTART task has been triggered



#### 4.11.3.34 HFCLKSTAT

Address offset: 0x40C

Status indicating which HFCLK128M/HFCLK64M source is running

This register value in any CLOCK instance reflects status only due to configurations/actions in that CLOCK instance.



| Bit r | umber            |               |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|---------------|------------|------------------------|-----------------------------------------------------------------|--|--|--|
| ID    |                  |               |            |                        | C B A                                                           |  |  |  |
| Rese  | Reset 0x00000000 |               |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |
| ID    |                  |               |            |                        |                                                                 |  |  |  |
| Α     | R                | SRC           |            | Active clock source    |                                                                 |  |  |  |
|       |                  |               | HFINT      | 0                      | Clock source: HFINT - 128 MHz on-chip oscillator                |  |  |  |
|       |                  |               | HFXO       | 1                      | Clock source: HFXO - 128 MHz clock derived from external        |  |  |  |
|       |                  |               |            |                        | 32 MHz crystal oscillator                                       |  |  |  |
| В     | R                | ALWAYSRUNNING |            |                        | ALWAYSRUN activated                                             |  |  |  |
|       |                  |               | NotRunning | 0                      | Automatic clock control enabled                                 |  |  |  |
|       |                  |               | Running    | 1                      | Oscillator is always running                                    |  |  |  |
| С     | R                | STATE         |            | HFCLK state            |                                                                 |  |  |  |
|       |                  |               | NotRunning | 0                      | HFCLK not running                                               |  |  |  |
|       |                  |               | Running    | 1                      | HFCLK running                                                   |  |  |  |

#### 4.11.3.35 LFCLKRUN

Address offset: 0x414

Status indicating that LFCLKSTART task has been triggered



#### 4.11.3.36 LFCLKSTAT

Address offset: 0x418

Status indicating which LFCLK source is running

This register value in any CLOCK instance reflects status only due to configurations/actions in that CLOCK instance.





#### 4.11.3.37 LFCLKSRCCOPY

Address offset: 0x41C

Copy of LFCLKSRC register, set when LFCLKSTART task was triggered



#### 4.11.3.38 HFCLKAUDIORUN

Address offset: 0x450

Status indicating that HFCLKAUDIOSTART task has been triggered



#### 4.11.3.39 HFCLKAUDIOSTAT

Address offset: 0x454

Status indicating which HFCLKAUDIO source is running



#### 4.11.3.40 HFCLK192MRUN

Address offset: 0x458

Status indicating that HFCLK192MSTART task has been triggered





#### 4.11.3.41 HFCLK192MSTAT

Address offset: 0x45C

Status indicating which HFCLK192M source is running

| Bit n | umber            |               |            | 31 30 29 28 27 26 25 2                                      | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|---------------|------------|-------------------------------------------------------------|-----------------------------------------------------------------|--|--|--|
| ID    |                  |               |            |                                                             | C B A                                                           |  |  |  |
| Rese  | Reset 0x00000000 |               |            | 0 0 0 0 0 0 0                                               | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |
| ID    |                  |               |            |                                                             |                                                                 |  |  |  |
| Α     | R                | SRC           |            | Active clock source                                         |                                                                 |  |  |  |
|       |                  |               | HFINT      | 0                                                           | Clock source: HFINT - on-chip oscillator                        |  |  |  |
|       |                  |               | HFXO       | 1 Clock source: HFXO - derived from external 32 MHz crystal |                                                                 |  |  |  |
|       |                  |               |            |                                                             | oscillator                                                      |  |  |  |
| В     | R                | ALWAYSRUNNING |            |                                                             | ALWAYSRUN activated                                             |  |  |  |
|       |                  |               | NotRunning | 0                                                           | Automatic clock control enabled                                 |  |  |  |
|       |                  |               | Running    | 1                                                           | Oscillator is always running                                    |  |  |  |
| С     | R                | STATE         |            |                                                             | HFCLK192M state                                                 |  |  |  |
|       |                  |               | NotRunning | 0                                                           | HFCLK192M not running                                           |  |  |  |
|       |                  |               | Running    | 1                                                           | HFCLK192M running                                               |  |  |  |

#### 4.11.3.42 HFCLKSRC

Address offset: 0x514

Clock source for HFCLK128M/HFCLK64M



#### 4.11.3.43 LFCLKSRC

Address offset: 0x518 Clock source for LFCLK





#### 4.11.3.44 HFCLKCTRL

Address offset: 0x558

HFCLK128M frequency configuration

Using any value except for the enumerations will yield unexpected results

Note: Not present in the CLOCK instance of the network core



#### 4.11.3.45 HFCLKAUDIO.FREQUENCY

Address offset: 0x55C

Audio PLL frequency in 11.176 MHz - 11.402 MHz or 12.165 MHz - 12.411 MHz frequency bands

Note: Not present in the CLOCK instance of the network core



#### 4.11.3.46 HFCLKALWAYSRUN

Address offset: 0x570

Automatic or manual control of HFCLK128M/HFCLK64M

The AlwaysRun setting will ensure the clock source is always running, independent of the automatic clock request system.

**Note:** This setting is activated by triggering the HFCLKSTART task.

NORDIC\*



#### 4.11.3.47 LFCLKALWAYSRUN

Address offset: 0x574

Automatic or manual control of LFCLK

The AlwaysRun setting will ensure the clock source is always running, independent of the automatic clock request system.

Note: This setting is activated by triggering the LFCLKSTART task.



#### 4.11.3.48 HFCLKAUDIOALWAYSRUN

Address offset: 0x57C

Automatic or manual control of HFCLKAUDIO

The AlwaysRun setting will ensure the clock source is always running, independent of the automatic clock request system.

**Note:** This setting is activated by triggering the HFCLKAUDIOSTART task.



#### 4.11.3.49 HFCLK192MSRC

Address offset: 0x580

Clock source for HFCLK192M





#### 4.11.3.50 HFCLK192MALWAYSRUN

Address offset: 0x584

Automatic or manual control of HFCLK192M

The AlwaysRun setting will ensure the clock source is always running, independent of the automatic clock request system.

**Note:** This setting is activated by triggering the HFCLK192MSTART task.



#### 4.11.3.51 HFCLK192MCTRL

Address offset: 0x5B8

HFCLK192M frequency configuration



## 4.11.4 Electrical specification

#### 4.11.4.1 128 MHz clock source (HFCLK128M)



| Symbol                         | Description                                                             | Min. | Тур. | Max. | Units |
|--------------------------------|-------------------------------------------------------------------------|------|------|------|-------|
| f <sub>NOM_HFCLK128M</sub>     | Nominal output frequency                                                |      | 128  |      | MHz   |
| f <sub>TOL_HFINT128M</sub>     | Frequency tolerance when running from internal oscillator               |      | ±1.5 | ±7   | %     |
| f <sub>TOL_HFXO128M</sub>      | Frequency tolerance when running from crystal oscillator                |      | ±10  | ±60  | ppm   |
| t <sub>HFCLK128M_128M_64</sub> | <sub>4M</sub> Time for HFCLKCTRL to take effect when switching from 128 |      | 2.5  |      | μs    |
|                                | MHz to 64 MHz                                                           |      |      |      |       |
| t <sub>HFCLK128M_64M_128</sub> | <sub>BM</sub> Time for HFCLKCTRL to take effect when switching from 64  |      | 9.0  |      | μs    |
|                                | MHz to 128 MHz                                                          |      |      |      |       |

## 4.11.4.2 64 MHz clock source (HFCLK64M)

| Symbol                    | Description                                               | Min. | Тур. | Max. | Units |
|---------------------------|-----------------------------------------------------------|------|------|------|-------|
| f <sub>NOM_HFCLK64M</sub> | Nominal output frequency                                  |      | 64   |      | MHz   |
| f <sub>TOL_HFINT64M</sub> | Frequency tolerance when running from internal oscillator |      | ±1.5 | ±8   | %     |
| f <sub>TOL_HFXO64M</sub>  | Frequency tolerance when running from crystal oscillator  |      | ±10  | ±60  | ppm   |

## 4.11.4.3 192 MHz clock source (HFCLK192M)

| Symbol                     | Description                                               | Min. | Тур. | Max. | Units |
|----------------------------|-----------------------------------------------------------|------|------|------|-------|
| f <sub>NOM_HFCLK192M</sub> | Nominal output frequency                                  |      | 192  |      | MHz   |
| f <sub>TOL_HFINT192M</sub> | Frequency tolerance when running from internal oscillator |      | ±1.5 | ±7   | %     |
| f <sub>TOL_HFXO192M</sub>  | Frequency tolerance when running from crystal oscillator  |      | ±10  | ±60  | ppm   |

## 4.11.4.4 Audio clock source (HFCLKAUDIO)

| Symbol                      | Description                                              | Min. | Тур.   | Max. | Units |
|-----------------------------|----------------------------------------------------------|------|--------|------|-------|
| f <sub>NOM_HFCLKAUDIO</sub> | Nominal output frequency                                 |      | 11.289 |      | MHz   |
|                             |                                                          |      | or     |      |       |
|                             |                                                          |      | 12.288 |      |       |
| f <sub>TOL_HFXOAUDIO</sub>  | Frequency tolerance when running from crystal oscillator |      | ±10    | ±60  | ppm   |

## 4.11.4.5 32 kHz clock source (LFCLK)

| Symbol                  | Description                                                     | Min. | Тур.   | Max. | Units |
|-------------------------|-----------------------------------------------------------------|------|--------|------|-------|
| f <sub>NOM_LFCLK</sub>  | Nominal output frequency                                        |      | 32.768 |      | kHz   |
| t <sub>START_LFXO</sub> | Startup time for 32.768 kHz crystal oscillator                  |      | 0.31   |      | S     |
| I <sub>LFXO</sub>       | Run current for 32.768 kHz crystal oscillator                   |      | 0.16   |      | μΑ    |
| f <sub>TOL_LFRC</sub>   | Frequency tolerance, uncalibrated                               |      |        | ±3.2 | %     |
| $f_{TOL\_CAL\_LFRC}$    | Frequency tolerance after calibration. Constant                 |      |        | ±250 | ppm   |
|                         | temperature within $\pm 0.5$ °C, calibration performed at least |      |        |      |       |
|                         | every 8 seconds, averaging interval > 7.5 ms, defined as 3      |      |        |      |       |
|                         | sigma.                                                          |      |        |      |       |
| t <sub>START_LFRC</sub> | Startup time for internal RC oscillator                         |      | 500    |      | μs    |
| I <sub>LFRC</sub>       | Run current for LFRC                                            |      |        | 1.0  | μΑ    |

## 4.12 OSCILLATORS — Oscillator control

The system oscillators are shared between the cores in the system and automatically controlled by the clock control system, see CLOCK — Clock control on page 73.



The system has the following crystal oscillators:

- High-frequency 32 MHz crystal oscillator (HFXO)
- Low-frequency 32.768 kHz crystal oscillator (LFXO)

The crystal oscillators can be configured to use either built-in or external capacitors.

## 4.12.1 High-frequency (32 MHz) crystal oscillator (HFXO)

The high-frequency crystal oscillator (HFXO) is controlled by a 32 MHz external crystal.

The crystal oscillator is designed for use with an AT-cut quartz crystal in parallel resonant mode, connected between pins XC1 and XC2. To achieve correct oscillation frequency, the load capacitance must match the specification in the crystal data sheet. The following figure shows how the 32 MHz crystal is connected to the high frequency crystal oscillator.



Figure 21: Circuit diagram of the high-frequency crystal oscillator

The load capacitance (CL) is the total capacitance seen by the crystal across its terminals and is calculated by the following equation.

$$CL = \frac{(C1' \cdot C2')}{(C1' + C2')}$$

$$C1' = C1 + C_{pcb1} + C_{pin}$$

$$C2' = C2 + C_{pcb2} + C_{pin}$$

Figure 22: Load capacitance equation

C1 and C2 are ceramic SMD capacitors connected between each crystal terminal and ground. For more information, see Reference circuitry on page 801.  $C_{pcb1}$  and  $C_{pcb2}$  are stray capacitance on the PCB.  $C_{pin}$  is the pin input capacitance on pins XC1 and XC2. See table 32 MHz crystal oscillator (HFXO) on page 102. The load capacitors C1 and C2 should have the same value.

For reliable operation, the crystal load capacitance, shunt capacitance, equivalent series resistance, and drive level must comply with the specifications in table 32 MHz crystal oscillator (HFXO) on page 102. It is recommended to use a crystal with lower than maximum load capacitance and/or shunt capacitance. A low load capacitance will reduce both startup time and current consumption.

#### 4.12.1.1 Using internal capacitors

Optional internal capacitors ranging from 7.0 pF to 20.0 pF in 0.5 pF steps, are provided on pins XC1 and XC2.

Enabling internal capacitors eliminates the need for external capacitors for the 32 MHz crystal. The configuration of the internal capacitors must take place before starting the high-frequency crystal oscillator (HFXO).

The internal capacitors are used instead of the external capacitors C1 and C2, and the total capacitance seen by the crystal across its terminals is calculated by the load capacitance equation in High-frequency (32 MHz) crystal oscillator (HFXO) on page 99.



To enable the internal capacitors, find the correct XOSC32MCAPS.CAPVALUE field using the following equation.

```
CAPVALUE = (((FICR->XOSC32MTRIM.SLOPE+56)*(CAPACITANCE*2-14))
+((FICR->XOSC32MTRIM.OFFSET-8)<<4)+32)>>6;
```

The equation has the following variables

- CAPACITANCE is the desired capacitor value in pF, holding any value between 7.0 pF and 20.0 pF in 0.5 pF steps.
- FICR->XOSC32MTRIM are factory trim values which usually are different from device to device.

Finally, set XOSC32MCAPS.ENABLE to Enabled, to activate the capacitors.

After this, when HFXO is started, it will use the internal capacitor values together with the external crystal.

**Note:** It is possible to avoid using floating point numbers by pre-calculating the (CAPACITANCE\*2-14) field of the above equation.

## 4.12.2 Low-frequency (32.768 kHz) crystal oscillator (LFXO)

For higher LFCLK accuracy (when greater than  $\pm$  250 ppm accuracy is required), the 32.768 kHz crystal oscillator (LFXO) must be used.

To use the LFXO, a 32.768 kHz crystal must be connected between the XL1 and XL2 pins, as illustrated in the following figure.



Figure 23: Circuit diagram of the low-frequency crystal oscillator

To enable oscillator functionality on XL1 and XL2 pins, use value *Peripheral* for the MCUSEL bitfield of the register PIN\_CNF[n] (n=0..31) (Retained) on page 233.

To achieve correct oscillation frequency, the load capacitance (CL) must match the specification in the crystal data sheet. The load capacitance (CL) is the total capacitance seen by the crystal across its terminals. It is calculated by the following equation.

$$CL = \frac{(C1' \cdot C2')}{(C1' + C2')}$$

$$C1' = C1 + C_{pcb1} + C_{pin}$$

$$C2' = C2 + C_{pcb2} + C_{pin}$$

Figure 24: Load capacitance equation

C1 and C2 are ceramic SMD capacitors connected between each crystal terminal and ground.  $C_{pcb1}$  and  $C_{pcb2}$  are stray capacitance on the PCB.  $C_{pin}$  is the pin input capacitance on the XL1 and XL2 pins (see 32.768 kHz crystal oscillator (LFXO) on page 104). The load capacitors C1 and C2 should have the same value.

For more information, see Reference circuitry on page 801.

NORDIC

#### 4.12.2.1 Using internal capacitors

Optional internal capacitors of 6 pF, 7 pF, and 9 pF are provided between pins XL1 and XL2.

Enabling the internal capacitor between XL1 and XL2 pins eliminates the need for external capacitors for the 32 kHz crystal, as shown in the following figure.



Figure 25: Internal capacitor for the 32 kHz crystal

To enable this capacitor, choose the correct  $C_{INT}$  capacitance in register XOSC32KI.INTCAP. The value of the internal capacitor  $C_{INT}$  must match the specification in the crystal data sheet.  $C_{INT}$  is the capacitance seen by the crystal across its terminals, including pin capacitance but excluding PCB stray capacitance.

## 4.12.3 Low-frequency (32.768 kHz) external source

The 32.768 kHz crystal oscillator (LFXO) is designed to work with external sources.

The following external sources are supported:

- A low swing clock. The signal should be applied to the XL1 pin with the XL2 pin grounded. Set OSCILLATORS.XOSC32KI.BYPASS=Disabled.
- A rail-to-rail clock. The signal should be applied to the XL1 pin with the XL2 pin left unconnected. Set OSCILLATORS.XOSC32KI.BYPASS=Enabled.

In order to use an external source, configure LFCLKSRC.SRC=LFXO.

## 4.12.4 Registers

| Base address Domain      | Peripheral     | Instance         | Secure mapping | DMA security | Description              | Configuration |
|--------------------------|----------------|------------------|----------------|--------------|--------------------------|---------------|
|                          |                | OSCILLATORS      | :              |              |                          |               |
| 0x50004000<br>0x40004000 | ON OSCILLATORS | S<br>OSCILLATORS | US<br>:        | NA           | Oscillator configuration |               |
|                          |                | NS               |                |              |                          |               |

Table 27: Instances

| Register        | Offset | Security | Description                                                                     |          |
|-----------------|--------|----------|---------------------------------------------------------------------------------|----------|
| XOSC32MCAPS     | 0x5C4  |          | Programmable capacitance of XC1 and XC2                                         | Retained |
| XOSC32KI.BYPASS | 0x6C0  |          | Enable or disable bypass of LFCLK crystal oscillator with external clock source | Retained |
| XOSC32KI.INTCAP | 0x6D0  |          | Control usage of internal load capacitors                                       | Retained |

Table 28: Register overview

#### 4.12.4.1 XOSC32MCAPS (Retained)

Address offset: 0x5C4

This register is a retained register



#### Programmable capacitance of XC1 and XC2



#### 4.12.4.2 XOSC32KI.BYPASS (Retained)

Address offset: 0x6C0

This register is a retained register

Enable or disable bypass of LFCLK crystal oscillator with external clock source



#### 4.12.4.3 XOSC32KI.INTCAP (Retained)

Address offset: 0x6D0

This register is a retained register

Control usage of internal load capacitors



## 4.12.5 Electrical specification

#### 4.12.5.1 32 MHz crystal oscillator (HFXO)

| Symbol            | Description                | Min. | Тур. | Max. | Units |
|-------------------|----------------------------|------|------|------|-------|
| f <sub>HFXO</sub> | External crystal frequency |      | 32   |      | MHz   |



| Symbol                       | Description                                                                     | Min. | Тур. | Max. | Units |
|------------------------------|---------------------------------------------------------------------------------|------|------|------|-------|
| f <sub>TOL_HFXO</sub>        | Frequency tolerance requirement for 2.4 GHz proprietary                         |      |      | ±60  | ppm   |
|                              | radio applications                                                              |      |      |      |       |
| f <sub>TOL_HFXO_BLE</sub>    | Frequency tolerance requirement, Bluetooth Low Energy                           |      |      | ±40  | ppm   |
|                              | applications, packet length ≤ 200 bytes                                         |      |      |      |       |
| f <sub>TOL_HFXO_BLE_LP</sub> | Frequency tolerance requirement, Bluetooth Low Energy                           |      |      | ±30  | ppm   |
|                              | applications, packet length > 200 bytes                                         |      |      |      |       |
| C <sub>L_HFXO</sub>          | Load capacitance                                                                | 6    | 8    | 12   | pF    |
| C <sub>0_HFXO</sub>          | Shunt capacitance                                                               |      |      | 7    | pF    |
| R <sub>S_HFXO_7PF</sub>      | Equivalent series resistance 3 pF < CO <= 7 pF                                  |      |      | 60   | Ω     |
| R <sub>S_HFXO_3PF</sub>      | Equivalent series resistance CO <= 3 pF                                         |      |      | 100  | Ω     |
| P <sub>D_HFXO</sub>          | Drive level                                                                     |      |      | 100  | μW    |
| C <sub>PIN_HFXO</sub>        | Input capacitance XC1 and XC2 with internal capacitors disabled                 |      | 5.5  |      | pF    |
| $C_{PIN\_HFXO\_INT}$         | Input capacitance XC1 and XC2 with internal capacitors                          |      | 2.5  |      | pF    |
|                              | enabled                                                                         |      |      |      |       |
| C <sub>HFXO_INT_MIN</sub>    | Input capacitance XC1 and XC2, internal capacitor at                            |      | 7    |      | pF    |
|                              | minimum value, excluding C <sub>PIN_HFXO_INT</sub>                              |      |      |      |       |
| C <sub>HFXO_INT_MAX</sub>    | Input capacitance XC1 and XC2, internal capacitor at                            |      | 20   |      | pF    |
|                              | maximum value, excluding C <sub>PIN_HFXO_INT</sub>                              |      |      |      |       |
| I <sub>STBY_X32M</sub>       | Core standby current for various crystals                                       |      |      |      |       |
| I <sub>STBY_X32M_X0</sub>    | Typical parameters for a given 2.5mm x 2.0mm crystal:                           |      | 65   |      | μΑ    |
|                              | CL_HFXO = 8 pF, CO_HFXO = 1 pF, LM_HFXO = 7 mH,                                 |      |      |      |       |
|                              | $RS_HFXO = 20 \Omega$                                                           |      |      |      |       |
| I <sub>STBY_X32M_X1</sub>    | Typical parameters for a given 1.6mm x 1.2mm crystal:                           |      | 187  |      | μΑ    |
|                              | CL_HFXO = 8 pF, CO_HFXO = 0.4 pF, LM_HFXO = 20 mH,                              |      |      |      |       |
|                              | RS_HFXO = $40 \Omega$                                                           |      |      |      |       |
| I <sub>STBY_X32M_X2</sub>    | Typical parameters for a given 2.0mm x 1.6mm crystal:                           |      | 135  |      | μΑ    |
|                              | CL HFXO = 8 pF, C0 HFXO = 0.73 pF, LM HFXO = 9.47 mH,                           |      |      |      |       |
|                              | RS HFXO = 16.32 Ω                                                               |      |      |      |       |
| I <sub>STBY X32M X3</sub>    | Typical parameters for a given 1.2mm x 1.0mm crystal:                           |      | 181  |      | μΑ    |
|                              | CL HFXO = 8 pF, C0 HFXO = 0.42 pF, LM HFXO = 22.7 mH,                           |      |      |      |       |
|                              |                                                                                 |      |      |      |       |
| lozunz vonu                  | RS_HFXO = $100 \Omega$ Average startup current for various crystals, first 1 ms |      |      |      |       |
| I <sub>START_X32M</sub>      | Typical parameters for a given 2.5mm x 2.0mm crystal:                           |      | 363  |      | μΑ    |
| -STAKT_X3ZM_XU               |                                                                                 |      | 003  |      |       |
|                              | CL_HFXO = 8 pF, C0_HFXO = 1 pF, LM_HFXO = 7 mH,                                 |      |      |      |       |
|                              | $RS_{\perp}HFXO = 20 \Omega$                                                    |      |      |      |       |
| I <sub>START_X32M_X1</sub>   | Typical parameters for a given 1.6mm x 1.2mm crystal:                           |      | 790  |      | μΑ    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.4 pF, LM_HFXO = 20 mH,                              |      |      |      |       |
|                              | RS_HFXO = $40 \Omega$                                                           |      |      |      |       |
| I <sub>START_X32M_X2</sub>   | Typical parameters for a given 2.0mm x 1.6mm crystal:                           |      | 467  |      | μΑ    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.73 pF, LM_HFXO = 9.47 mH,                           |      |      |      |       |
|                              | RS_HFXO = $16.32 \Omega$                                                        |      |      |      |       |
| I <sub>START_X32M_X3</sub>   | Typical parameters for a given 1.2mm x 1.0mm crystal:                           |      | 863  |      | μΑ    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.42 pF, LM_HFXO = 22.7 mH,                           |      |      |      |       |
|                              | RS_HFXO = $100 \Omega$                                                          |      |      |      |       |
| t <sub>POWERUP_X32M</sub>    | Power-up time for various crystals                                              |      |      |      |       |
| t <sub>POWERUP_X32M_X0</sub> | Typical parameters for a given 2.5mm x 2.0mm crystal:                           |      | 60   |      | μs    |
|                              |                                                                                 |      |      |      |       |
|                              | CL_HFXO = 8 pF, CO_HFXO = 1 pF, LM_HFXO = 7 mH,                                 |      |      |      |       |
|                              | $RS_{HFXO} = 20 \Omega$                                                         |      |      |      |       |



| Symbol                       | Description                                           | Min. | Тур. | Max. | Units |
|------------------------------|-------------------------------------------------------|------|------|------|-------|
| t <sub>POWERUP_X32M_X1</sub> | Typical parameters for a given 1.6mm x 1.2mm crystal: |      | 187  |      | μs    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.4 pF, LM_HFXO = 20 mH,    |      |      |      |       |
|                              | RS_HFXO = $40 \Omega$                                 |      |      |      |       |
| t <sub>POWERUP_X32M_X2</sub> | Typical parameters for a given 2.0mm x 1.6mm crystal: |      | 60   |      | μs    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.73 pF, LM_HFXO = 9.47 mH, |      |      |      |       |
|                              | RS_HFXO = $16.32 \Omega$                              |      |      |      |       |
| t <sub>POWERUP_X32M_X3</sub> | Typical parameters for a given 1.2mm x 1.0mm crystal: |      | 211  |      | μs    |
|                              | CL_HFXO = 8 pF, C0_HFXO = 0.42 pF, LM_HFXO = 22.7 mH, |      |      |      |       |
|                              | RS_HFXO = $100 \Omega$                                |      |      |      |       |

# 4.12.5.2 32.768 kHz crystal oscillator (LFXO)

| Symbol               | Description                                                | Min. | Тур.   | Max. | Units |
|----------------------|------------------------------------------------------------|------|--------|------|-------|
| f <sub>LFXO</sub>    | External crystal frequency                                 |      | 32.768 |      | kHz   |
| $f_{TOL\_LFXO\_BLE}$ | Frequency tolerance requirement, Bluetooth Low Energy      |      |        | ±500 | ppm   |
|                      | applications                                               |      |        |      |       |
| $f_{TOL\_LFXO\_ANT}$ | Frequency tolerance requirement for ANT applications       |      |        | ±50  | ppm   |
| C <sub>L_LFXO</sub>  | Load capacitance                                           |      | 7      | 9    | pF    |
| $C_{0\_LFXO}$        | Shunt capacitance                                          |      | 1      | 2    | pF    |
| R <sub>S_LFXO</sub>  | Equivalent series resistance                               |      | 60     | 90   | kΩ    |
| $P_{D\_LFXO}$        | Drive level                                                |      |        | 0.5  | μW    |
| C <sub>pin</sub>     | Input capacitance on XL1 and XL2 pads when internal        |      | 4      |      | pF    |
|                      | capacitor is disabled                                      |      |        |      |       |
| C <sub>pin</sub>     | Total capacitance between XL1 and XL2 pads when internal   | 6    | 7      | 9    | pF    |
|                      | capacitor enabled                                          |      |        |      |       |
| $V_{AMP,IN,XO,LOW}$  | Peak-to-peak amplitude for external low swing clock. Input | 200  |        | 1000 | mV    |
|                      | signal must not swing outside supply rails.                |      |        |      |       |



# 5 Application core

The application core contains a low-power microcontroller with embedded flash memory and a full featured Arm Cortex-M33 processor.

In addition, the application core includes a rich set of peripherals for serial communication, analog interfaces, and cryptographic acceleration. See the following figure for more information. Arrows with white heads indicate signals that share physical pins with other signals, while arrows with black heads are dedicated to one signal.

# 5.1 Block diagram

The following image shows the application core block diagram.





Figure 26: Application core block diagram



## 5.2 CPU

The Arm Cortex-M33 processor has a 32-bit instruction set (Thumb-2 technology) that implements a super set of 16- and 32-bit instructions to maximize code density and performance.

This processor implements several features that enable energy-efficient arithmetic and high-performance signal processing including:

- Digital signal processing (DSP) instructions
- Single-cycle multiply and accumulate (MAC) instructions
- · Hardware divide
- 8- and 16-bit single instruction multiple data (SIMD) instructions
- · Single-precision floating-point unit (FPU)
- · Memory Protection Unit (MPU)
- Arm TrustZone for Armv8-M

The Arm Cortex Microcontroller Software Interface Standard (CMSIS) is implemented and available for the application processor.

Real-time execution is highly deterministic in thread mode, to and from sleep modes, and when handling events at configurable priority levels via the Nested Vectored Interrupt Controller (NVIC).

Executing code from internal or external flash will have a wait state penalty. The instruction cache can be enabled to minimize flash wait states when fetching instructions. For more information on cache, see Cache on page 337. CPU performance parameters including wait states for different configurations, CPU current consumption and efficiency, and processing power and efficiency based on the CoreMark benchmark can be found in Electrical specification on page 107.

## 5.2.1 Floating point interrupt

The floating point unit (FPU) may generate exceptions, for example, due to overflow or underflow. These exceptions may trigger interrupts when enabled in the FPU peripheral. For more information, see FPU — Floating point unit (FPU) exceptions on page 219.

## 5.2.2 Electrical specification

## 5.2.2.1 CPU performance

| Symbol                      | Description                                              | Min. | Тур. | Max. | Units     |
|-----------------------------|----------------------------------------------------------|------|------|------|-----------|
| W <sub>FLASH128</sub>       | CPU wait states, running CoreMark at 128 MHz from flash, |      |      | 4    |           |
|                             | cache disabled                                           |      |      |      |           |
| W <sub>FLASHCACHE128</sub>  | CPU wait states, running CoreMark at 128 MHz from flash, |      |      | 5    |           |
|                             | cache enabled                                            |      |      |      |           |
| W <sub>RAM128</sub>         | CPU wait states, running CoreMark at 128 MHz from RAM    |      | 0    |      |           |
| W <sub>FLASH64</sub>        | CPU wait states, running CoreMark at 64 MHz from flash,  |      |      | 5    |           |
|                             | cache disabled                                           |      |      |      |           |
| W <sub>FLASHCACHE64</sub>   | CPU wait states, running CoreMark at 64 MHz from flash,  |      |      | 6    |           |
|                             | cache enabled                                            |      |      |      |           |
| W <sub>RAM64</sub>          | CPU wait states, running CoreMark at 64 MHz from RAM     |      | 0    |      |           |
| CM <sub>FLASHCACHE128</sub> | CoreMark, running from flash, cache enabled, HFXO128M    |      | 514  |      | CoreMark  |
| CM <sub>FLASH128/MHz</sub>  | CoreMark per MHz, running from flash, cache enabled,     |      | 4.0  |      | CoreMark/ |
|                             | HFXO128M                                                 |      |      |      | MHz       |
| CM <sub>FLASH128/mA</sub>   | CoreMark per mA, running from flash, cache enabled, DCDC |      | 66   |      | CoreMark/ |
|                             | 3 V, HFXO128M                                            |      |      |      | mA        |



| Symbol                     | Description                                              | Min. | Тур. | Max. | Units     |
|----------------------------|----------------------------------------------------------|------|------|------|-----------|
| CM <sub>FLASHCACHE64</sub> | CoreMark, running from flash, cache enabled, HFXO64M     |      | 257  |      | CoreMark  |
| CM <sub>FLASH64/MHz</sub>  | CoreMark per MHz, running from flash, cache enabled,     |      | 4.0  |      | CoreMark/ |
|                            | HFXO64M                                                  |      |      |      | MHz       |
| CM <sub>FLASH64/mA</sub>   | CoreMark per mA, running from flash, cache enabled, DCDC |      | 72.5 |      | CoreMark/ |
|                            | 3 V, HFXO64M                                             |      |      |      | mA        |

# 5.2.3 CPU and support module configuration

The Arm Cortex-M33 processor has a number of CPU options and support modules implemented on the device.

| Option/Module             | Description                         | Implemented                                        |  |  |  |
|---------------------------|-------------------------------------|----------------------------------------------------|--|--|--|
| Core options              |                                     |                                                    |  |  |  |
| PRIORITIES                | Priority bits                       | 3                                                  |  |  |  |
| WIC                       | Wakeup Interrupt Controller         | NO                                                 |  |  |  |
| Endianness                | Memory system endianness            | Little endian                                      |  |  |  |
| DWT                       | Data Watchpoint and Trace           | YES                                                |  |  |  |
| Modules                   |                                     |                                                    |  |  |  |
| MPU                       | Number of non-secure MPU regions    | 8                                                  |  |  |  |
|                           | Number of secure MPU regions        | 8                                                  |  |  |  |
| SAU                       | Number of SAU regions               | 0                                                  |  |  |  |
|                           |                                     | See SPU for more information about secure regions. |  |  |  |
| FPU                       | Floating-point unit                 | YES                                                |  |  |  |
| DSP                       | Digital Signal Processing Extension | YES                                                |  |  |  |
| Arm TrustZone for Armv8-M | Armv8-M Security Extensions         | YES                                                |  |  |  |
| CPIF                      | Coprocessor interface               | NO                                                 |  |  |  |
| ETM                       | Embedded Trace Macrocell            | YES                                                |  |  |  |
| ITM                       | Instrumentation Trace Macrocell     | YES                                                |  |  |  |
| МТВ                       | Micro Trace Buffer                  | NO                                                 |  |  |  |
| СТІ                       | Cross Trigger Interface             | YES                                                |  |  |  |
| BPU                       | Breakpoint Unit                     | YES                                                |  |  |  |
| нтм                       | AHB Trace Macrocell                 | NO                                                 |  |  |  |

# 5.3 Memory

The application core contains flash memory and RAM that can be used for code and data storage.



The following figure shows how the CPU, network core, and peripherals with EasyDMA can access RAM via the AHB multilayer interconnect. The domain configuration (DCNF) registers can block access from external DMA masters, see DCNF — Domain configuration on page 201.



Figure 27: Memory layout



# 5.3.1 Peripheral instantiation

The following table describes the abbreviations used in the Instance, Secure mapping, and DMA security columns of the instantiation table.

| Abbreviation | Description                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| NS           | Non-secure - Peripheral is always accessible as a Non-Secure peripheral                                                                   |
| S            | Secure - Peripheral is always accessible as a Secure peripheral                                                                           |
| US           | User Selectable - A Secure or Non-secure attribute for the peripheral is defined in the SPU                                               |
| SPLIT        | Both Secure and Non-secure - The same resource is shared by both secure and non-secure code                                               |
| NA           | Not Applicable - Peripheral has no DMA capability                                                                                         |
| NSA          | NoSeparateAttribute - Peripheral with DMA and DMA transfer has the same security attribute as assigned to the peripheral                  |
| SA           | SeparateAttribute - Peripheral with DMA and DMA transfers can have a different security attribute than the one assigned to the peripheral |

Table 29: Instantiation table abbreviations

The Secure mapping column in the following table defines configuration capabilities for the Arm TrustZone for Armv8-M secure attribute. The DMA security column describes the DMA capabilities of the peripheral.

# 5.3.1.1 Instantiation

| ID | Base address             | Peripheral  | Instance                          | Secure mapping | DMA security | Description                           |
|----|--------------------------|-------------|-----------------------------------|----------------|--------------|---------------------------------------|
| 0  | 0x50000000<br>0x40000000 | DCNF        | DCNF : S<br>DCNF : NS             | US             | NA           | Domain configuration                  |
| 0  | 0x50000000<br>0x40000000 | FPU         | FPU: S<br>FPU: NS                 | US             | NA           | Floating Point unit interrupt control |
| 1  | 0x50001000               | CACHE       | CACHE                             | S              | NA           | Cache                                 |
| 3  | 0x50003000               | SPU         | SPU                               | S              | NA           | System protection unit                |
| 4  | 0x50004000<br>0x40004000 | OSCILLATORS | OSCILLATORS : S OSCILLATORS : NS  | US             | NA           | Oscillator configuration              |
| 4  | 0x50004000<br>0x40004000 | REGULATORS  | REGULATORS : S<br>REGULATORS : NS | US             | NA           | Regulator configuration               |
| 5  | 0x50005000<br>0x40005000 | CLOCK       | CLOCK : S<br>CLOCK : NS           | US             | NA           | Clock control                         |
| 5  | 0x50005000<br>0x40005000 | POWER       | POWER : S<br>POWER : NS           | US             | NA           | Power control                         |
| 5  | 0x50005000<br>0x40005000 | RESET       | RESET : S<br>RESET : NS           | US             | NA           | Reset control and status              |
| 6  | 0x50006000<br>0x40006000 | CTRLAPPERI  | CTRLAP : S<br>CTRLAP : NS         | US             | NSA          | Control access port CPU side          |
| 8  | 0x50008000<br>0x40008000 | SPIM        | SPIM0 : S<br>SPIM0 : NS           | US             | SA           | SPI master 0                          |
| 8  | 0x50008000<br>0x40008000 | SPIS        | SPISO : S<br>SPISO : NS           | US             | SA           | SPI slave 0                           |



| ID | Base address             | Peripheral | Instance                  | Secure mapping | DMA security | Description                                                |
|----|--------------------------|------------|---------------------------|----------------|--------------|------------------------------------------------------------|
| 8  | 0x50008000               | TWIM       | TWIM0 : S                 | US             | SA           | Two-wire interface master 0                                |
|    | 0x40008000               |            | TWIM0 : NS                |                |              |                                                            |
| 8  | 0x50008000<br>0x40008000 | TWIS       | TWIS0 : S<br>TWIS0 : NS   | US             | SA           | Two-wire interface slave 0                                 |
| 8  | 0x50008000<br>0x40008000 | UARTE      | UARTEO : S<br>UARTEO : NS | US             | SA           | Universal asynchronous receiver/transmitter with EasyDMA 0 |
| 9  | 0x50009000<br>0x40009000 | SPIM       | SPIM1 : S<br>SPIM1 : NS   | US             | SA           | SPI master 1                                               |
| 9  | 0x50009000<br>0x40009000 | SPIS       | SPIS1 : S<br>SPIS1 : NS   | US             | SA           | SPI slave 1                                                |
| 9  | 0x50009000<br>0x40009000 | TWIM       | TWIM1 : S<br>TWIM1 : NS   | US             | SA           | Two-wire interface master 1                                |
| 9  | 0x50009000<br>0x40009000 | TWIS       | TWIS1 : S<br>TWIS1 : NS   | US             | SA           | Two-wire interface slave 1                                 |
| 9  | 0x50009000<br>0x40009000 | UARTE      | UARTE1: S<br>UARTE1: NS   | US             | SA           | Universal asynchronous receiver/transmitter with EasyDMA 1 |
| 10 | 0x5000A000<br>0x4000A000 | SPIM       | SPIM4 : S<br>SPIM4 : NS   | US             | SA           | SPI master 4 (high-speed)                                  |
| 11 | 0x5000B000<br>0x4000B000 | SPIM       | SPIM2 : S<br>SPIM2 : NS   | US             | SA           | SPI master 2                                               |
| 11 | 0x5000B000<br>0x4000B000 | SPIS       | SPIS2 : S<br>SPIS2 : NS   | US             | SA           | SPI slave 2                                                |
| 11 | 0x5000B000<br>0x4000B000 | TWIM       | TWIM2 : S<br>TWIM2 : NS   | US             | SA           | Two-wire interface master 2                                |
| 11 | 0x5000B000<br>0x4000B000 | TWIS       | TWIS2 : S<br>TWIS2 : NS   | US             | SA           | Two-wire interface slave 2                                 |
| 11 | 0x5000B000<br>0x4000B000 | UARTE      | UARTE2 : S<br>UARTE2 : NS | US             | SA           | Universal asynchronous receiver/transmitter with EasyDMA 2 |
| 12 | 0x5000C000<br>0x4000C000 | SPIM       | SPIM3 : S<br>SPIM3 : NS   | US             | SA           | SPI master 3                                               |
| 12 | 0x5000C000<br>0x4000C000 | SPIS       | SPIS3 : S<br>SPIS3 : NS   | US             | SA           | SPI slave 3                                                |
| 12 | 0x5000C000<br>0x4000C000 | TWIM       | TWIM3 : S<br>TWIM3 : NS   | US             | SA           | Two-wire interface master 3                                |
| 12 | 0x5000C000<br>0x4000C000 | TWIS       | TWIS3 : S<br>TWIS3 : NS   | US             | SA           | Two-wire interface slave 3                                 |
| 12 | 0x5000C000<br>0x4000C000 | UARTE      | UARTE3 : S<br>UARTE3 : NS | US             | SA           | Universal asynchronous receiver/transmitter with EasyDMA 3 |
| 13 | 0x5000D000               | GPIOTE     | GPIOTE0                   | S              | NA           | GPIO tasks and events                                      |
| 14 | 0x5000E000<br>0x4000E000 | SAADC      | SAADC : S<br>SAADC : NS   | US             | SA           | Successive approximation analog-to-digital converter       |
| 15 | 0x5000F000<br>0x4000F000 | TIMER      | TIMER0 : S<br>TIMER0 : NS | US             | NA           | Timer 0                                                    |
| 16 | 0x50010000<br>0x40010000 | TIMER      | TIMER1:S<br>TIMER1:NS     | US             | NA           | Timer 1                                                    |
| 17 | 0x50011000<br>0x40011000 | TIMER      | TIMER2 : S<br>TIMER2 : NS | US             | NA           | Timer 2                                                    |
| 20 | 0x50014000<br>0x40014000 | RTC        | RTC0 : S<br>RTC0 : NS     | US             | NA           | Real time counter 0                                        |
| 21 | 0x50015000<br>0x40015000 | RTC        | RTC1 : S<br>RTC1 : NS     | US             | NA           | Real time counter 1                                        |
| 23 | 0x50017000<br>0x40017000 | DPPIC      | DPPIC : S<br>DPPIC : NS   | SPLIT          | NA           | DPPI controller                                            |



| ID | Base address             | Peripheral | Instance                                    | Secure mapping | DMA security | Description                                             |
|----|--------------------------|------------|---------------------------------------------|----------------|--------------|---------------------------------------------------------|
| 24 | 0x50018000               | WDT        | WDT0:S                                      | US             | NA           | Watchdog timer 0                                        |
| 24 | 0x40018000               | WDI        | WDT0: NS                                    | 03             | IVA          | watching timer o                                        |
| 25 | 0x50019000<br>0x40019000 | WDT        | WDT1:S<br>WDT1:NS                           | US             | NA           | Watchdog timer 1                                        |
| 26 | 0x5001A000<br>0x4001A000 | COMP       | COMP: S<br>COMP: NS                         | US             | NA           | Comparator                                              |
| 26 | 0x5001A000<br>0x4001A000 | LPCOMP     | LPCOMP : S<br>LPCOMP : NS                   | US             | NA           | Low-power comparator                                    |
| 27 | 0x5001B000<br>0x4001B000 | EGU        | EGU0 : S<br>EGU0 : NS                       | US             | NA           | Event generator unit 0                                  |
| 28 | 0x5001C000<br>0x4001C000 | EGU        | EGU1 : S<br>EGU1 : NS                       | US             | NA           | Event generator unit 1                                  |
| 29 | 0x5001D000<br>0x4001D000 | EGU        | EGU2 : S<br>EGU2 : NS                       | US             | NA           | Event generator unit 2                                  |
| 30 | 0x5001E000<br>0x4001E000 | EGU        | EGU3 : S<br>EGU3 : NS                       | US             | NA           | Event generator unit 3                                  |
| 31 | 0x5001F000<br>0x4001F000 | EGU        | EGU4 : S<br>EGU4 : NS                       | US             | NA           | Event generator unit 4                                  |
| 32 | 0x50020000<br>0x40020000 | EGU        | EGU5 : S<br>EGU5 : NS                       | US             | NA           | Event generator unit 5                                  |
| 33 | 0x50021000<br>0x40021000 | PWM        | PWM0 : S<br>PWM0 : NS                       | US             | SA           | Pulse width modulation unit 0                           |
| 34 | 0x50022000<br>0x40022000 | PWM        | PWM1 : S<br>PWM1 : NS                       | US             | SA           | Pulse width modulation unit 1                           |
| 35 | 0x50023000<br>0x40023000 | PWM        | PWM2 : S<br>PWM2 : NS                       | US             | SA           | Pulse width modulation unit 2                           |
| 36 | 0x50024000<br>0x40024000 | PWM        | PWM3 : S<br>PWM3 : NS                       | US             | SA           | Pulse width modulation unit 3                           |
| 38 | 0x50026000<br>0x40026000 | PDM        | PDM0 : S<br>PDM0 : NS                       | US             | SA           | Pulse density modulation (digital microphone) interface |
| 40 | 0x50028000<br>0x40028000 | 125        | 12S0 : S<br>12S0 : NS                       | US             | SA           | Inter-IC sound interface                                |
| 42 | 0x5002A000<br>0x4002A000 | IPC        | IPC : S<br>IPC : NS                         | US             | NA           | Interprocessor communication                            |
| 43 | 0x5002B000<br>0x4002B000 | QSPI       | QSPI : S<br>QSPI : NS                       | US             | SA           | External memory (quad serial peripheral) interface      |
| 45 | 0x5002D000<br>0x4002D000 | NFCT       | NFCT : S<br>NFCT : NS                       | US             | SA           | Near field communication tag                            |
| 47 | 0x4002F000               | GPIOTE     | GPIOTE1                                     | NS             | NA           | GPIO tasks and events                                   |
| 48 | 0x50030000<br>0x40030000 | MUTEX      | MUTEX : S<br>MUTEX : NS                     | US             | NA           | Mutual exclusive hardware support                       |
| 51 | 0x50033000<br>0x40033000 | QDEC       | QDEC0 : S<br>QDEC0 : NS                     | US             | NA           | Quadrature decoder 0                                    |
| 52 | 0x50034000<br>0x40034000 | QDEC       | QDEC1 : S<br>QDEC1 : NS                     | US             | NA           | Quadrature decoder 1                                    |
| 54 | 0x50036000<br>0x40036000 | USBD       | USBD : S<br>USBD : NS                       | US             | SA           | Universal serial bus device                             |
| 55 | 0x50037000<br>0x40037000 | USBREG     | USBREGULATOR :<br>S<br>USBREGULATOR :<br>NS | US             | NA           | USB regulator control                                   |
| 57 | 0x50039000<br>0x40039000 | KMU        | KMU : S<br>KMU : NS                         | SPLIT          | NA           | Key management unit                                     |



| ID  | Base address | Peripheral | Instance   | Secure mapping | DMA security | Description                                 |
|-----|--------------|------------|------------|----------------|--------------|---------------------------------------------|
| 57  | 0x50039000   | NVMC       | NVMC : S   | SPLIT          | NA           | Non-volatile memory controller              |
|     | 0x40039000   |            | NVMC : NS  |                |              | ·                                           |
| 66  | 0x50842500   | GPIO       | P0 : S     | SPLIT          | NA           | General purpose input and output, port 0    |
| 00  | 0x40842500   | drio       | P0 : NS    | Jr Lii         | NA           | deneral purpose input and output, port o    |
| 66  | 0x50842800   | GPIO       | P1:S       | SPLIT          | NA           | General purpose input and output, port 1    |
| 00  | 0x40842800   | GPIO       | P1 : NS    | SPLII          | NA           | General purpose input and output, port 1    |
| 68  | 0x50844000   | CRYPTOCELL | CRYPTOCELL | S              | NSA          | CryptoCell subsystem control interface      |
| 129 | 0x50081000   | VMC        | VMC : S    | US             | NA           | Volatile memory controller                  |
| 123 | 0x40081000   | VIVIC      | VMC : NS   | 03             | NA           | volatile memory controller                  |
| N/A | 0x00F00000   | CACHEDATA  | CACHEDATA  | S              | NA           | Cache data                                  |
| N/A | 0x00F08000   | CACHEINFO  | CACHEINFO  | S              | NA           | Cache info                                  |
| N/A | 0x00FF0000   | FICR       | FICR       | S              | NA           | Factory information configuration registers |
| N/A | 0x00FF8000   | UICR       | UICR       | S              | NA           | User information configuration registers    |
| N/A | 0xE0042000   | СТІ        | СТІ        | S              | NA           | Cross-trigger interface                     |
| N/A | 0xE0080000   | TAD        | TAD        | S              | NA           | Trace and debug control                     |
|     |              |            |            |                |              |                                             |

Table 30: Instantiation table

# 5.4 Core components

# 5.4.1 CACHE — Instruction/data cache

The cache is two-way set associative with a least recently used (LRU) replacement policy. Both instruction and data accesses towards flash memory or XIP code regions are cached.

The cache has the following features:

- 128-bit cache line
- Configurable as a cache or general purpose RAM
- Hit/miss counters per NVM region and access type (instruction or data)
- Readable cache content (for profiling)
  - Data, tag, valid, and most recently used (MRU) bits
  - Can be disabled when not in use
- Manual invalidation and erase support
- Locking cache updates on cache misses





Figure 28: Cache overview

In Cache mode (MODE=Cache), instruction and data accesses from the CPU over the code bus towards internal or external flash, are cached. The contents of the cache, i.e. data, tag, valid, and MRU bits, are memory mapped, see Cache content on page 114. This can be used for performance profiling of code running in the system. Access to the cache content region is read-only by default, but can be blocked by enabling a lock bit in DEBUGLOCK on page 119. Preventing cache content updates on cache misses can be enabled through register DEBUGLOCK on page 119. When enabled, cache content is not replaced, but kept intact. The cache is still enabled and provides fast instruction and data fetches for cached content.

Access to internal or external flash memory will not be cached when in Ram mode (MODE=Ram). Instead, the cache data content, as described in Cache content on page 114, can be used as read/write RAM.

#### 5.4.1.1 Cache content

Cache information is divided into cache info content and cache data content.

Cache info content is organized in memory as shown in the following figure.





Figure 29: Cache info content

The V field contains the bit that indicates if a cache entry is valid or not. All V fields are cleared when invalidating the cache using register INVALIDATE on page 118, when disabling the cache using register ENABLE on page 117, or when changing MODE from Ram to Cache. The MRU field indicates which way was used most recently in the set. The MRU bit is updated on each fetch from the cache and is used for the cache replacement policy. The Tag field is used to check if an entry in the cache matches the address being fetched.

The following figure shows how the cache data content is organized in memory.



Figure 30: Cache data content

Each set consists of two ways, each containing 128 bits of data. The 128-bit data is available as 4x32-bit words in sequential order. When operating in Ram mode (MODE = Ram), the data is accessible as general purpose RAM.

The cache info and cache data content are memory mapped in the CACHEINFO and CACHEDATA regions. These can be accessed in the CACHEINFO registers and CACHEDATA registers respectively.



# 5.4.1.2 Profiling

The cache includes profiling counters IHIT, IMISS, DHIT, and DMISS for both flash and execute-in-place (XIP).

Cache performance on executed code is indicated by these counters when enabled through PROFILINGENABLE on page 118. The counters can be cleared at any time using PROFILINGCLEAR on page 118. Writing to this register will clear all profiling counters. After being cleared, the counters will increment at the next instruction, or data fetch, according to the rules in the following table.

| Profiling counter | Description                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------|
| IHIT              | Increased on a cache hit for instruction fetch                                                   |
| IMISS             | Increased on a cache miss for instruction fetch                                                  |
| DHIT              | Increased on a cache hit for data fetch (i.e. LOAD type instruction targeting the cache region)  |
| DMISS             | Increased on a cache miss for data fetch (i.e. LOAD type instruction targeting the cache region) |

Table 31: Profiling counters

# 5.4.1.3 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description | Configuration |
|------------------------|------------|----------|----------------|--------------|-------------|---------------|
| 0x50001000 APPLICATION | N CACHE    | CACHE    | S              | NA           | Cache       |               |

*Table 32: Instances* 

| Register           | Offset | Security | Description                                                                           |
|--------------------|--------|----------|---------------------------------------------------------------------------------------|
| PROFILING[n].IHIT  | 0x400  |          | Instruction fetch cache hit counter for cache region n, where n=0 means Flash and n=1 |
|                    |        |          | means XIP.                                                                            |
| PROFILING[n].IMISS | 0x404  |          | Instruction fetch cache miss counter for cache region n, where n=0 means Flash and    |
|                    |        |          | n=1 means XIP.                                                                        |
| PROFILING[n].DHIT  | 0x408  |          | Data fetch cache hit counter for cache region n, where n=0 means Flash and n=1        |
|                    |        |          | means XIP.                                                                            |
| PROFILING[n].DMISS | 0x40C  |          | Data fetch cache miss counter for cache region n, where n=0 means Flash and n=1       |
|                    |        |          | means XIP.                                                                            |
| ENABLE             | 0x500  |          | Enable cache.                                                                         |
| INVALIDATE         | 0x504  |          | Invalidate the cache.                                                                 |
| ERASE              | 0x508  |          | Erase the cache.                                                                      |
| PROFILINGENABLE    | 0x50C  |          | Enable the profiling counters.                                                        |
| PROFILINGCLEAR     | 0x510  |          | Clear the profiling counters.                                                         |
| MODE               | 0x514  |          | Cache mode.                                                                           |
|                    |        |          | Switching from Cache to Ram mode causes the RAM to be cleared.                        |
|                    |        |          | Switching from RAM to Cache mode causes the cache to be invalidated.                  |
| DEBUGLOCK          | 0x518  |          | Lock debug mode.                                                                      |
| ERASESTATUS        | 0x51C  |          | Cache erase status.                                                                   |
| WRITELOCK          | 0x520  |          | Lock cache updates. Prevents updating of cache content on cache misses, but will      |
|                    |        |          | continue to lookup instruction/data fetches in content already present in the cache.  |
|                    |        |          | Ignored in RAM mode.                                                                  |

Table 33: Register overview

# 5.4.1.3.1 PROFILING[n].IHIT (n=0..1)

Address offset:  $0x400 + (n \times 0x20)$ 



Instruction fetch cache hit counter for cache region n, where n=0 means Flash and n=1 means XIP.



## 5.4.1.3.2 PROFILING[n].IMISS (n=0..1)

Address offset:  $0x404 + (n \times 0x20)$ 

Instruction fetch cache miss counter for cache region n, where n=0 means Flash and n=1 means XIP.



## 5.4.1.3.3 PROFILING[n].DHIT (n=0..1)

Address offset:  $0x408 + (n \times 0x20)$ 

Data fetch cache hit counter for cache region n, where n=0 means Flash and n=1 means XIP.



## 5.4.1.3.4 PROFILING[n].DMISS (n=0..1)

Address offset:  $0x40C + (n \times 0x20)$ 

Data fetch cache miss counter for cache region n, where n=0 means Flash and n=1 means XIP.



117

#### 5.4.1.3.5 ENABLE

Address offset: 0x500

Enable cache.





# **5.4.1.3.6 INVALIDATE**

Address offset: 0x504 Invalidate the cache.

| Bit n | umber   |            |            | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|------------|------------------|------------------------------------------------------------------------|
| ID    |         |            |            |                  | А                                                                      |
| Rese  | t 0x000 | 00000      |            | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |            |            |                  |                                                                        |
| Α     | W       | INVALIDATE |            |                  | Invalidate the cache                                                   |
|       |         |            | Invalidate | 1                | Invalidate the cache                                                   |

# 5.4.1.3.7 ERASE

Address offset: 0x508 Erase the cache.

| Bit n | umber   |       |       | 31 30 | 29 2 | 8 27 2 | 26 25 | 5 24 | 23  | 22  | 21 2 | 20 1 | 19 18 | 3 17 | 16 | 15 | 14 1 | 3 12 | 11 | 10 9 | 8 | 7 | 6 | 5 4 | 1 3 | 2 | 1 0 |
|-------|---------|-------|-------|-------|------|--------|-------|------|-----|-----|------|------|-------|------|----|----|------|------|----|------|---|---|---|-----|-----|---|-----|
| ID    |         |       |       |       |      |        |       |      |     |     |      |      |       |      |    |    |      |      |    |      |   |   |   |     |     |   | Α   |
| Rese  | t 0x000 | 00000 |       | 0 0   | 0 0  | 0      | 0 0   | 0    | 0   | 0   | 0    | 0 (  | 0 0   | 0    | 0  | 0  | 0 0  | 0    | 0  | 0 0  | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 0 |
| ID    |         |       |       |       |      |        |       |      |     |     |      |      |       |      |    |    |      |      |    |      |   |   |   |     |     |   |     |
| Α     | W       | ERASE |       |       |      |        |       |      | Era | ase | the  | cac  | che   |      |    |    |      |      |    |      |   |   |   |     |     |   |     |
|       |         |       | Erase | 1     |      |        |       |      | Era | ase | cacl | he   |       |      |    |    |      |      |    |      |   |   |   |     |     |   |     |

#### 5.4.1.3.8 PROFILINGENABLE

Address offset: 0x50C

Enable the profiling counters.

| Bit n | umber   |        |         | 31 30 29 28 27 | 26 25 24 | 23 22 2 | 1 20 1 | 9 18    | 17 16 | 5 15 1 | 4 13 | 12 1: | 1 10 | 9 8 | 7 | 6 | 5 4 | 3 | 2 | 1 0 |
|-------|---------|--------|---------|----------------|----------|---------|--------|---------|-------|--------|------|-------|------|-----|---|---|-----|---|---|-----|
| ID    |         |        |         |                |          |         |        |         |       |        |      |       |      |     |   |   |     |   |   | Α   |
| Rese  | t 0x000 | 00000  |         | 0 0 0 0 0      | 0 0 0    | 0 0     | 0 0    | 0 0     | 0 0   | 0 (    | 0 0  | 0 0   | 0    | 0 0 | 0 | 0 | 0 0 | 0 | 0 | 0 0 |
| ID    |         |        |         |                |          |         |        |         |       |        |      |       |      |     |   |   |     |   |   |     |
| Α     | RW      | ENABLE |         |                |          | Enable  | the p  | rofilir | ng co | unter  | s    |       |      |     |   |   |     |   |   |     |
|       |         |        | Disable | 0              |          | Disable | profi  | ling    |       |        |      |       |      |     |   |   |     |   |   |     |
|       |         |        | Enable  | 1              |          | Enable  | profil | ing     |       |        |      |       |      |     |   |   |     |   |   |     |

#### 5.4.1.3.9 PROFILINGCLEAR

Address offset: 0x510

Clear the profiling counters.

The profiling counters can be cleared at any time. When cleared, all profiling counters will be set to zero, and will increment at the next instruction or data fetch.





## 5.4.1.3.10 MODE

Address offset: 0x514

Cache mode.

Switching from Cache to Ram mode causes the RAM to be cleared.

Switching from RAM to Cache mode causes the cache to be invalidated.



#### 5.4.1.3.11 DEBUGLOCK

Address offset: 0x518

Lock debug mode.

This register is ignored when CACHE is used in RAM mode. Once this register has been set to Locked, the debug mode can only be unlocked by resetting the device.



#### 5.4.1.3.12 ERASESTATUS

Address offset: 0x51C Cache erase status.





#### 5.4.1.3.13 WRITELOCK

Address offset: 0x520

Lock cache updates. Prevents updating of cache content on cache misses, but will continue to lookup instruction/data fetches in content already present in the cache.

Ignored in RAM mode.



# 5.4.1.4 Electrical specification

#### 5.4.1.4.1 Cache size

| Symbol                    | Description    | Min. | Тур. | Max. | Units |
|---------------------------|----------------|------|------|------|-------|
| Size <sub>CACHEDATA</sub> | CACHEDATA size |      | 8192 |      | Bytes |

# 5.4.1.5 Registers

| Base address Domain    | Peripheral | Instance  | Secure mapping | DMA security | Description | Configuration |
|------------------------|------------|-----------|----------------|--------------|-------------|---------------|
| 0x00F08000 APPLICATION | CACHEINFO  | CACHEINFO | S              | NA           | Cache info  |               |

Table 34: Instances

| Register      | Offset | Security | Description                           |
|---------------|--------|----------|---------------------------------------|
| SET[n].WAY[o] | 0x0    |          | Cache information for SET[n], WAY[o]. |

Table 35: Register overview

## 5.4.1.5.1 SET[n].WAY[o] (n=0..255) (o=0..1)

Address offset:  $0x0 + (n \times 0x8) + (o \times 0x4)$ Cache information for SET[n], WAY[o].

| Bit n | umber    |       |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |         | СВ                      | A A A A A A A A A A A A A A A A A A A                           |
| Rese  | et 0x000 | 00000 |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |         |                         |                                                                 |
| Α     | RW       | TAG   |         |                         | Cache tag.                                                      |
| В     | R        | V     |         |                         | Valid bit                                                       |
|       |          |       | Invalid | 0                       | Invalid cache line                                              |
|       |          |       | Valid   | 1                       | Valid cache line                                                |
| С     | R        | MRU   |         |                         | Most recently used way.                                         |
|       |          |       | Way0    | 0                       | Way0 was most recently used                                     |
|       |          |       | Way1    | 1                       | Way1 was most recently used                                     |



# 5.4.1.6 Registers

| Base address Domain    | Peripheral | Instance  | Secure mapping | DMA security | Description | Configuration |
|------------------------|------------|-----------|----------------|--------------|-------------|---------------|
| 0x00F00000 APPLICATION | CACHEDATA  | CACHEDATA | S              | NA           | Cache data  |               |

Table 36: Instances

| Register            | Offset | Security | Description                                 |
|---------------------|--------|----------|---------------------------------------------|
| SET[n].WAY[o].DATA0 | 0x0    |          | Cache data bits [31:0] of SET[n], WAY[o].   |
| SET[n].WAY[o].DATA1 | 0x4    |          | Cache data bits [63:32] of SET[n], WAY[o].  |
| SET[n].WAY[o].DATA2 | 0x8    |          | Cache data bits [95:64] of SET[n], WAY[o].  |
| SET[n].WAY[o].DATA3 | 0xC    |          | Cache data bits [127:96] of SET[n], WAY[o]. |

Table 37: Register overview

# 5.4.1.6.1 SET[n].WAY[o].DATA0 (n=0..255) (o=0..1)

Address offset:  $0x0 + (n \times 0x20) + (o \times 0x10)$ Cache data bits [31:0] of SET[n], WAY[o].

| Α     | RW      | Data   |         |         |      |    | D    | ata  |    |      |      |      |    |      |      |      |    |      |     |   |   |    |     |   |     |
|-------|---------|--------|---------|---------|------|----|------|------|----|------|------|------|----|------|------|------|----|------|-----|---|---|----|-----|---|-----|
| ID    |         |        |         |         |      |    |      |      |    |      |      |      |    |      |      |      |    |      |     |   |   |    |     |   |     |
| Res   | et 0x00 | 000000 | 0 0     | 0 0 0   | 0    | 0  | 0 (  | 0    | 0  | 0    | 0 0  | 0    | 0  | 0    | 0 0  | 0    | 0  | 0 (  | 0   | 0 | 0 | 0  | 0 0 | 0 | 0   |
| ID    |         |        | Α Α .   | A A A   | A    | Α  | A A  | A    | Α  | Α    | ΑА   | A    | Α  | Α    | 4 A  | Α    | Α  | A A  | A A | Α | Α | Α. | 4 Α | Α | Α , |
| Bit r | number  |        | 31 30 2 | 29 28 2 | 7 26 | 25 | 24 2 | 3 22 | 21 | 20 : | 19 1 | 8 17 | 16 | 15 1 | 4 13 | 3 12 | 11 | 10 9 | 8 ( | 7 | 6 | 5  | 4 3 | 2 | 1   |

# 5.4.1.6.2 SET[n].WAY[o].DATA1 (n=0..255) (o=0..1)

Address offset:  $0x4 + (n \times 0x20) + (o \times 0x10)$ Cache data bits [63:32] of SET[n], WAY[o].

| Bit r | umber   |       | 313 | 0 29 | 28 2 | 7 26 | 5 25 | 24 | 23  | 22 2 | 21 2 | 0 19 | 18 : | L7 1 | 6 15 | 14 | 13 1 | 2 11 | 10 | 9 | 8 7 | 7 ( | 5 5 | 4 | 3   | 2 1 | 0 |
|-------|---------|-------|-----|------|------|------|------|----|-----|------|------|------|------|------|------|----|------|------|----|---|-----|-----|-----|---|-----|-----|---|
| ID    |         |       | A A | A    | Α /  | 4 A  | Α    | Α  | Α   | A ,  | A A  | A    | Α    | A A  | A A  | Α  | A A  | 4 A  | Α  | Α | A A | Δ / | A A | A | Α / | 4 A | Α |
| Rese  | t 0x000 | 00000 | 0 0 | 0    | 0 (  | 0 0  | 0    | 0  | 0   | 0    | 0 0  | 0    | 0    | 0 (  | 0    | 0  | 0 (  | 0 0  | 0  | 0 | 0 ( | ) ( | 0   | 0 | 0 ( | 0   | 0 |
| ID    |         |       |     |      |      |      |      |    |     |      |      |      |      |      |      |    |      |      |    |   |     |     |     |   |     |     |   |
| Α     | RW      | Data  |     |      |      |      |      |    | Dat | а    |      |      |      |      |      |    |      |      |    |   |     |     |     |   |     |     |   |

# 5.4.1.6.3 SET[n].WAY[o].DATA2 (n=0..255) (o=0..1)

Address offset:  $0x8 + (n \times 0x20) + (o \times 0x10)$ Cache data bits [95:64] of SET[n], WAY[o].

| A RW Data     |      |  |     |      | D    | ata |      |      |     |      |    |    |      |       |      |    |      |     |      |      |   |     |     |     |   |   |   |     |
|---------------|------|--|-----|------|------|-----|------|------|-----|------|----|----|------|-------|------|----|------|-----|------|------|---|-----|-----|-----|---|---|---|-----|
| ID R/W F      |      |  |     |      |      |     |      |      |     |      |    |    |      |       |      |    |      |     |      |      |   |     |     |     |   |   |   |     |
| Reset 0x00000 | 0000 |  | 0   | 0 0  | 0    | 0   | 0    | 0 (  | ) ( | 0    | 0  | 0  | 0    | 0 0   | 0    | 0  | 0    | 0 0 | 0    | 0    | 0 | 0   | ) ( | 0   | 0 | 0 | 0 | 0 0 |
| ID            |      |  | Α . | 4 Α  | Α    | Α   | Α.   | A A  | A A | A    | Α  | Α  | Α    | А А   | Α    | Α  | A    | ДД  | A    | Α    | Α | A . | Δ , | Δ Δ | A | Α | Α | А А |
| Bit number    |      |  | 313 | 0 29 | 9 28 | 27  | 26 2 | 25 2 | 4 2 | 3 22 | 21 | 20 | 19 1 | 18 17 | 7 16 | 15 | 14 1 | 3 1 | 2 11 | . 10 | 9 | 8   | 7 ( | 5 5 | 4 | 3 | 2 | 1 0 |

# 5.4.1.6.4 SET[n].WAY[o].DATA3 (n=0..255) (o=0..1)

Address offset:  $0xC + (n \times 0x20) + (o \times 0x10)$ 

4406\_640 v1.3

121



Cache data bits [127:96] of SET[n], WAY[o].



# 5.4.2 FICR — Factory information configuration registers

Factory information configuration registers (FICR) are pre-programmed in factory and cannot be erased by the user. These registers contain chip-specific information and configuration.

Note: FICR is not accessible from the network core.

# 5.4.2.1 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description             | Configuration |
|------------------------|------------|----------|----------------|--------------|-------------------------|---------------|
| 0x00FF0000 APPLICATION | FICR       | FICR     | S              | NA           | Factory information     |               |
|                        |            |          |                |              | configuration registers |               |

Table 38: Instances

| Register          | Offset | Security | Description                                                            |
|-------------------|--------|----------|------------------------------------------------------------------------|
| INFO.CONFIGID     | 0x200  |          | Configuration identifier                                               |
| INFO.DEVICEID[n]  | 0x204  |          | Device identifier                                                      |
| INFO.PART         | 0x20C  |          | Part code                                                              |
| INFO.VARIANT      | 0x210  |          | Part Variant, Hardware version and Production configuration            |
| INFO.PACKAGE      | 0x214  |          | Package option                                                         |
| INFO.RAM          | 0x218  |          | RAM variant                                                            |
| INFO.FLASH        | 0x21C  |          | Flash variant                                                          |
| INFO.CODEPAGESIZE | 0x220  |          | Code memory page size in bytes                                         |
| INFO.CODESIZE     | 0x224  |          | Code memory size                                                       |
| INFO.DEVICETYPE   | 0x228  |          | Device type                                                            |
| TRIMCNF[n].ADDR   | 0x300  |          | Address of the PAR register which will be written                      |
| TRIMCNF[n].DATA   | 0x304  |          | Data                                                                   |
| NFC.TAGHEADER0    | 0x450  |          | Default header for NFC Tag. Software can read these values to populate |
|                   |        |          | NFCID1_3RD_LAST, NFCID1_2ND_LAST and NFCID1_LAST.                      |
| NFC.TAGHEADER1    | 0x454  |          | Default header for NFC Tag. Software can read these values to populate |
|                   |        |          | NFCID1_3RD_LAST, NFCID1_2ND_LAST and NFCID1_LAST.                      |
| NFC.TAGHEADER2    | 0x458  |          | Default header for NFC Tag. Software can read these values to populate |
|                   |        |          | NFCID1_3RD_LAST, NFCID1_2ND_LAST and NFCID1_LAST.                      |
| NFC.TAGHEADER3    | 0x45C  |          | Default header for NFC Tag. Software can read these values to populate |
|                   |        |          | NFCID1_3RD_LAST, NFCID1_2ND_LAST and NFCID1_LAST.                      |
| TRNG90B.BYTES     | 0xC00  |          | Amount of bytes for the required entropy bits                          |
| TRNG90B.RCCUTOFF  | 0xC04  |          | Repetition counter cutoff                                              |
| TRNG90B.APCUTOFF  | 0xC08  |          | Adaptive proportion cutoff                                             |
| TRNG90B.STARTUP   | 0xC0C  |          | Amount of bytes for the startup tests                                  |
| TRNG90B.ROSC1     | 0xC10  |          | Sample count for ring oscillator 1                                     |
| TRNG90B.ROSC2     | 0xC14  |          | Sample count for ring oscillator 2                                     |
| TRNG90B.ROSC3     | 0xC18  |          | Sample count for ring oscillator 3                                     |
| TRNG90B.ROSC4     | 0xC1C  |          | Sample count for ring oscillator 4                                     |
|                   |        |          |                                                                        |



| Register    | Offset | Security | Description                             |
|-------------|--------|----------|-----------------------------------------|
| XOSC32MTRIM | 0xC20  |          | XOSC32M capacitor selection trim values |

Table 39: Register overview

#### 5.4.2.1.1 INFO.CONFIGID

Address offset: 0x200 Configuration identifier

| Α     | R         | HWID  |             |                 | Identifica | ition n | umbe  | r for | the  | нw   |      |    |     |   |   |     |     |   |     |
|-------|-----------|-------|-------------|-----------------|------------|---------|-------|-------|------|------|------|----|-----|---|---|-----|-----|---|-----|
| ID    |           |       |             |                 | Descriptio |         |       |       |      |      |      |    |     |   |   |     |     |   |     |
| Rese  | et OxFFFI | FFFFF | 1 1 1 1     | 1 1 1 1         | 1 1 1      | 1 1     | 1 1   | 1 1   | 1    | 1 :  | 1 1  | 1  | 1 1 | 1 | 1 | 1 1 | . 1 | 1 | 1 1 |
| ID    |           |       |             |                 |            |         |       | A     | A A  | A    | A A  | Α  | A A | Α | Α | A A | A   | Α | A A |
| Bit n | umber     |       | 31 30 29 28 | 3 27 26 25 24 2 | 23 22 21 2 | 20 19   | 18 17 | 16 1  | 5 14 | 13 1 | 2 11 | 10 | 9 8 | 7 | 6 | 5 4 | 3   | 2 | 1 0 |

# 5.4.2.1.2 INFO.DEVICEID[n] (n=0..1)

Address offset:  $0x204 + (n \times 0x4)$ 

Device identifier

| Bit n | umber                                    |          |  | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------------------------------|----------|--|------------------------|-----------------------------------------------------------------|
| ID    |                                          |          |  | A A A A A A A          | A A A A A A A A A A A A A A A A A A A                           |
| Rese  | eset <b>0xFFFFFFF</b> R/W Field Value ID |          |  | 1 1 1 1 1 1 1 :        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |                                          |          |  |                        |                                                                 |
| Α     | R                                        | DEVICEID |  |                        | 64 bit unique device identifier                                 |

DEVICEID[0] contains the least significant bits of the device identifier. DEVICEID[1] contains the most significant bits of the device identifier.

#### 5.4.2.1.3 INFO.PART

Address offset: 0x20C

Part code

| Bit n | umber   |       |             | 313  | 0 2 | 9 28 | 3 27 | 26 | 25 | 24 : | 23 2 | 22 2 | 1 2   | 0 1 | 9 1 | 8 17 | 7 16 | 15 | 14 | 13 | 12 : | 11 1 | 0 9 | 9 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1 0 |
|-------|---------|-------|-------------|------|-----|------|------|----|----|------|------|------|-------|-----|-----|------|------|----|----|----|------|------|-----|-----|---|---|---|---|---|-----|-----|
| ID    |         |       |             | A A  | Α Α | A A  | Α    | Α  | Α  | Α    | Α    | A    | Δ /   | Δ , | \ A | Δ Α  | A    | Α  | Α  | Α  | Α    | A .  | A A | A А | Α | Α | Α | Α | Α | A A | A A |
| Rese  | t 0x000 | 05340 |             | 0 (  | ) ( | 0 0  | 0    | 0  | 0  | 0    | 0    | 0    | 0 (   | 0 ( | ) ( | 0    | 0    | 0  | 1  | 0  | 1    | 0    | 0 1 | 1 1 | 0 | 1 | 0 | 0 | 0 | 0 ( | 0 ( |
| ID    |         |       |             |      |     |      |      |    |    |      | Des  |      |       |     |     |      |      |    |    |    |      |      |     |     |   |   |   |   |   |     |     |
| Α     | R       | PART  |             |      |     |      |      |    |    |      | Par  | t co | de    |     |     |      |      |    |    |    |      |      |     |     |   |   |   |   |   |     |     |
|       |         |       | N5340       | 0x53 | 340 | )    |      |    |    | -    | nRF  | 534  | 40    |     |     |      |      |    |    |    |      |      |     |     |   |   |   |   |   |     |     |
|       |         |       | Unspecified | 0xFF | FF  | FFF  | F    |    |    |      | Uns  | spe  | cifie | ed  |     |      |      |    |    |    |      |      |     |     |   |   |   |   |   |     |     |

## **5.4.2.1.4 INFO.VARIANT**

Address offset: 0x210

Part Variant, Hardware version and Production configuration



| Bit n | umber   |         |             | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|-------------|----------------------|------------------------------------------------------------------|
| ID    |         |         |             | A A A A A A A        | A A A A A A A A A A A A A A A A A A A                            |
| Rese  | t OxFFF | FFFF    |             | 1 1 1 1 1 1 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                          |
| ID    |         |         |             |                      |                                                                  |
| Α     | R       | VARIANT |             |                      | Part Variant, Hardware version and Production                    |
|       |         |         |             |                      | configuration, encoded as ASCII                                  |
|       |         |         | QKAA        | 0x514B4141           | QKAA                                                             |
|       |         |         | CLAA        | 0x434C4141           | CLAA                                                             |
|       |         |         | Unspecified | 0xFFFFFFF            | Unspecified                                                      |

# 5.4.2.1.5 INFO.PACKAGE

Address offset: 0x214

Package option

| Bit n | umber   |         |     | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|-----|-------------------------|---------------------------------------------------------------|
| ID    |         |         |     | A A A A A A A           | A A A A A A A A A A A A A A A A A A A                         |
| Rese  | t OxFFF | FFFFF   |     | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                       |
| ID    |         |         |     |                         |                                                               |
| Α     | R       | PACKAGE |     |                         | Package option                                                |
|       |         |         | QK  | 0x2000                  | QKxx - 94-pin aQFN                                            |
|       |         |         | QI. | 0.000                   | QKXX - 94-pin aQFN                                            |
|       |         |         | CL  | 0x2005                  | CLxx - WLCSP                                                  |

## 5.4.2.1.6 INFO.RAM

Address offset: 0x218

RAM variant

|       |         |       |             | 31 30 29 28 27 26 2 A A A A A A A  1 1 1 1 1 1 1  Value  0x10 0x20 0x40 0x80 0x100 |     |      |      |      |    |     |     |      |      |     |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|-------|---------|-------|-------------|------------------------------------------------------------------------------------|-----|------|------|------|----|-----|-----|------|------|-----|----|------|------|------|------|-----|------------|------|------|---|---|---|---|---|---|---|-----|-----|
| Bit n | umber   |       |             | 31                                                                                 | 30  | 29 2 | 28 2 | 7 26 | 25 | 24  | 23  | 22   | 21   | 20  | 19 | 18 : | 17 1 | .6 1 | 15 1 | 4 1 | 3 1        | 2 1: | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 : | 1 0 |
| ID    |         |       |             | Α                                                                                  | Α   | Α    | A A  | A    | Α  | Α   | Α   | Α    | Α    | Α   | Α  | Α    | A .  | Α.   | Α.   | Δ / | \ <i>A</i> | Δ Α  | Α    | Α | Α | Α | Α | Α | Α | A | Δ , | А А |
| Rese  | t OxFFF | FFFFF |             | 1                                                                                  | 1   | 1    | 1 1  | . 1  | 1  | 1   | 1   | 1    | 1    | 1   | 1  | 1    | 1    | 1    | 1    | 1 1 | L 1        | L 1  | 1    | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 : | 1 1 |
| ID    |         |       |             |                                                                                    |     |      |      |      |    |     |     |      |      |     |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
| Α     | R       | RAM   |             |                                                                                    |     |      |      |      |    | RA  | M   | vari | ant  | :   |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K16         |                                                                                    |     |      |      |      |    | 16  | kB  | yte  | RA   | M   |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K32         |                                                                                    |     |      |      |      | 32 | kB  | yte | RA   | M    |     |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K64         | 0x                                                                                 | 40  |      |      |      |    |     | 64  | kB   | yte  | RA  | M  |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K128        |                                                                                    |     |      |      |      | 12 | 8 k | Byt | e R  | ΑM   |     |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K256        | 0x                                                                                 | 100 |      |      |      |    |     | 25  | 6 k  | Byt  | e R | ΑM |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | K512        | 0x                                                                                 | 200 |      |      |      |    |     | 51  | 2 k  | Byt  | e R | ΑM |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |
|       |         |       | Unspecified | 0x                                                                                 | FFF | FFFI | FF   |      |    |     | Un  | nsp  | ecif | ied |    |      |      |      |      |     |            |      |      |   |   |   |   |   |   |   |     |     |

# 5.4.2.1.7 INFO.FLASH

Address offset: 0x21C

Flash variant



| Bit n | umber    |       |             | 31                      | 30 | 29 | 28 | 27 2 | 6 25 | 5 24 | 23   | 22 : | 21  | 20 1 | 19 1 | 8 17 | 7 16 | 15 | 14 | 13 : | 12 1 | 111 | .0 9 | 8   | 7 | 6 | 5 | 4   | 3 2 | 2 1 | 0   |
|-------|----------|-------|-------------|-------------------------|----|----|----|------|------|------|------|------|-----|------|------|------|------|----|----|------|------|-----|------|-----|---|---|---|-----|-----|-----|-----|
| ID    |          |       |             | Α                       | Α  | Α  | Α  | A    | 4 A  | Α    | Α    | Α    | Α   | A    | A A  | 4 A  | Α    | Α  | Α  | Α    | Α.   | A A | Δ A  | A   | Α | Α | Α | Α,  | Δ , | Δ Δ | A   |
| Rese  | t OxFFFI | FFFF  |             | 1                       | 1  | 1  | 1  | 1 :  | 1 1  | 1    | 1    | 1    | 1   | 1    | 1 :  | l 1  | 1    | 1  | 1  | 1    | 1    | 1 : | 1 1  | . 1 | 1 | 1 | 1 | 1 : | 1 1 | l 1 | . 1 |
| ID    |          |       |             | Value<br>0x80           |    |    |    |      |      |      |      |      |     |      |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
| Α     | R        | FLASH |             |                         |    |    |    |      | Fla  | sh v | vari | iant |     |      |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | K128        | 0x80<br>0x100           |    |    |    |      | 12   | 8 kE | Byte | e FL | ASF | ł    |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | K256        | 0x80                    |    |    |    |      | 25   | 6 kE | Byte | e FL | ASF | ł    |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | K512        | 0x100                   |    |    |    |      | 51   | 2 kE | Byte | e FL | ASF | ł    |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | K1024       |                         |    |    |    |      | 1 N  | ⁄ΙВу | te   | FLA  | SH  |      |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | K2048       | 0x100<br>0x200          |    |    |    |      |      | 2 N  | ⁄ΙВу | te   | FLA | SH   |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |
|       |          |       | Unspecified | 0x100<br>0x200<br>0x400 |    |    |    |      |      | Un   | spe  | cifi | ied |      |      |      |      |    |    |      |      |     |      |     |   |   |   |     |     |     |     |

## 5.4.2.1.8 INFO.CODEPAGESIZE

Address offset: 0x220

Code memory page size in bytes

| Bit n | umber           |              |       | 31                  | 30 : | 29 2 | 28 27 | ' 26 | 25 | 24  | 23 2 | 2 2 | 1 20 | 19  | 18 1 | 7 16 | 5 15 | 14 : | .3 1 | 2 11 | 10  | 9 8 | 7 | 6 | 5 | 4   | 3 2 | 1 | 0 |
|-------|-----------------|--------------|-------|---------------------|------|------|-------|------|----|-----|------|-----|------|-----|------|------|------|------|------|------|-----|-----|---|---|---|-----|-----|---|---|
| ID    | eset 0x00001000 |              |       |                     |      | A    | А А   | Α    | Α  | Α   | A A  | \   | A A  | Α   | A    | 4 Α  | Α    | Α    | Α Δ  | Α    | Α . | 4 Δ | A | Α | Α | Α   | А А | Α | Α |
| Rese  | t 0x000         |              | 0     | 0                   | 0    | 0 0  | 0     | 0    | 0  | 0 ( | ) (  | 0   | 0    | 0   | 0 0  | 0    | 0    | 0 1  | 0    | 0    | 0   | 0   | 0 | 0 | 0 | 0 0 | 0   | 0 |   |
| ID    |                 |              |       |                     |      |      |       |      |    |     |      |     |      |     |      |      |      |      |      |      |     |     |   |   |   |     |     |   |   |
| Α     | R               | CODEPAGESIZE |       | 0 0 0 0 0 0 0 Value |      |      |       |      |    |     | Cod  | e m | nem  | ory | page | siz  | e in | byte | es   |      |     |     |   |   |   |     |     |   |   |
|       |                 |              | K4096 | 0x2                 | 100  | 0    |       |      |    |     | 4 kB | yte | !    |     |      |      |      |      |      |      |     |     |   |   |   |     |     |   |   |

## 5.4.2.1.9 INFO.CODESIZE

Address offset: 0x224 Code memory size

| Bit number       | 31 30 2 | 29 28 27 26 25 24 | 23 22 21 20 19 18 1 | 17 16 15 14 13 12 11 | 1098765        | 4 3 2 1 0 |
|------------------|---------|-------------------|---------------------|----------------------|----------------|-----------|
| ID               | A A /   | A A A A A         | A A A A A A         | A A A A A A          | A A A A A      | A A A A A |
| Reset 0x00000100 | 0 0 (   | 0 0 0 0 0 0       | 0 0 0 0 0 0         | 0 0 0 0 0 0 0        | 0 0 1 0 0 0    | 0 0 0 0 0 |
| ID R/W Field Va  |         |                   |                     |                      |                |           |
| A R CODESIZE     |         |                   | Code memory size    | in number of pages   | 3              |           |
|                  |         |                   | Total code space is | :: CODEPAGESIZE * C  | CODESIZE bytes |           |
| P2               | 256 256 |                   | 256 pages           |                      |                |           |

# 5.4.2.1.10 INFO.DEVICETYPE

Address offset: 0x228

Device type

| Bit nu | umber   |            |      | 31                       | 30  | 29 2 | 8 2 | 7 26 | 5 25 | 5 24 | 23 | 22   | 21   | 20  | 19  | 18 1  | 7 16 | 5 15 | 14  | 13 1 | 2 11 | . 10 | 9   | 8   | 7 ( | 5 5      | 4 | 3 | 2   | 1 0 |
|--------|---------|------------|------|--------------------------|-----|------|-----|------|------|------|----|------|------|-----|-----|-------|------|------|-----|------|------|------|-----|-----|-----|----------|---|---|-----|-----|
| ID     |         |            |      | Α                        | Α   | A    | Α / | 4 A  | Α    | Α    | Α  | Α    | Α    | Α   | Α   | A A   | A A  | A    | Α   | A    | A A  | Α    | Α   | A A | Α Α | <b>Δ</b> | A | Α | Α   | А А |
| Rese   | t 0x000 | 00000      |      |                          |     |      |     |      | 0    | 0    | 0  | 0    | 0    | 0   | 0 ( | 0     | 0    | 0    | 0 ( | 0    | 0    | 0    | 0 ( | ) ( | 0   | 0        | 0 | 0 | 0 0 |     |
| ID     |         |            |      | <b>0 0 0 0 0 0 0 0</b> 0 |     |      |     |      |      |      |    |      |      |     |     |       |      |      |     |      |      |      |     |     |     |          |   |   |     |     |
| Α      | R       | DEVICETYPE |      |                          |     |      |     |      |      |      | De | evic | e ty | ype |     |       |      |      |     |      |      |      |     |     |     |          |   |   |     |     |
|        |         |            | Die  | 0x0                      | 000 | 000  | 0   |      |      |      | De | evic | e is | an  | ph  | /sica | al D | ΙE   |     |      |      |      |     |     |     |          |   |   |     |     |
|        |         |            | FPGA | 0xF                      | FFI | FFFF | F   |      |      |      | De | evic | e is | an  | FP  | ŝΑ    |      |      |     |      |      |      |     |     |     |          |   |   |     |     |





## 5.4.2.1.11 TRIMCNF[n].ADDR (n=0..31)

Address offset:  $0x300 + (n \times 0x8)$ 

Address of the PAR register which will be written

| Α     | R        | Address |                   |      | Ad   | ldre | ss    |    |      |      |      |      |      |      |     |   |   |     |            |   |   |     |
|-------|----------|---------|-------------------|------|------|------|-------|----|------|------|------|------|------|------|-----|---|---|-----|------------|---|---|-----|
| ID    |          |         |                   |      |      |      |       |    |      |      |      |      |      |      |     |   |   |     |            |   |   |     |
| Rese  | t OxFFFI | FFFF    | 1 1 1 1 1 1       | 1    | 1 1  | 1    | 1 1   | 1  | 1 1  | . 1  | 1    | l 1  | 1 :  | l 1  | . 1 | 1 | 1 | 1 : | l 1        | 1 | 1 | 1 1 |
| ID    |          |         | A A A A A A       | Α ,  | 4 A  | Α    | A A   | Α  | A A  | A    | Α /  | A A  | A A  | A A  | Α   | Α | Ą | A A | <b>А</b> А | Α | Α | А А |
| Bit n | umber    |         | 31 30 29 28 27 26 | 25 2 | 4 23 | 22 2 | 21 20 | 19 | 18 1 | 7 16 | 15 1 | 4 13 | 12 1 | 1 10 | 9   | 8 | 7 | 6 5 | 5 4        | 3 | 2 | 1 0 |

# 5.4.2.1.12 TRIMCNF[n].DATA (n=0..31)

Address offset:  $0x304 + (n \times 0x8)$ 

Data

| Δ     | R        | Data  |    |      |      |      |    |    |      | Dat  | a to | n he | ٧٧ د | ritt | en i | nto i | the | PΔR  | rec  | iste | r    |   |    |    |     |     |   |   |     |
|-------|----------|-------|----|------|------|------|----|----|------|------|------|------|------|------|------|-------|-----|------|------|------|------|---|----|----|-----|-----|---|---|-----|
| ID    |          |       |    |      |      |      |    |    |      | Des  |      |      |      |      |      |       |     |      |      |      |      |   |    |    |     |     |   |   |     |
| Res   | et OxFFF | FFFFF | 1  | 1 1  | l 1  | 1    | 1  | 1  | 1    | 1    | 1    | 1    | 1    | 1 :  | 1 1  | 1     | 1   | 1    | 1 1  | 1    | 1    | 1 | 1  | 1  | 1 1 | 1   | 1 | 1 | 1 1 |
| ID    |          |       | Α  | A A  | A A  | A    | Α  | Α  | Α    | Α    | A    | A A  | Α.   | A A  | Α Α  | A     | Α   | A    | A A  | A    | Α    | Α | Α, | Α. | A A | A A | Α | Α | А А |
| Bit r | umber    |       | 31 | 30 2 | 9 28 | 3 27 | 26 | 25 | 24 2 | 23 2 | 22 2 | 21 2 | 20 1 | 19 1 | 8 1  | 7 16  | 15  | 14 1 | .3 1 | 2 11 | . 10 | 9 | 8  | 7  | 6 5 | 5 4 | 3 | 2 | 1 0 |

#### 5.4.2.1.13 NFC.TAGHEADER0

Address offset: 0x450

Default header for NFC Tag. Software can read these values to populate NFCID1\_3RD\_LAST, NFCID1\_2ND\_LAST and NFCID1\_LAST.

| Bit n | umber   |       | 313                                   | 30 29 | 9 28 2 | 27 26 | 6 25 | 24  | 23  | 22 2  | 21 2  | 0 19 | 9 18 | 17    | 16  | 15 1 | .4 13 | 12  | 11 1 | .0 9 | 8  | 7 | 6 | 5 | 4   | 3 2 | 1 0 |   |
|-------|---------|-------|---------------------------------------|-------|--------|-------|------|-----|-----|-------|-------|------|------|-------|-----|------|-------|-----|------|------|----|---|---|---|-----|-----|-----|---|
| ID    |         |       | D                                     | D D   | D      | D D   | D    | D   | С   | С     | C (   | C C  | : С  | С     | С   | В    | ВВ    | В   | В    | 3 B  | В  | Α | Α | Α | Α , | A A | Α Δ |   |
| Rese  | t OxFFF | FFF5F | 1                                     | 1 1   | . 1    | 1 1   | . 1  | 1   | 1   | 1     | 1 1   | L 1  | . 1  | 1     | 1   | 1    | 1 1   | 1   | 1    | 1 1  | 1  | 0 | 1 | 0 | 1 : | l 1 | 1 1 |   |
| ID    |         |       | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |       |        |       |      |     |     |       |       |      |      |       |     |      |       |     |      |      |    |   |   |   |     |     |     | ı |
| Α     | R       | MFGID |                                       |       |        | Det   | faul | t M | anu | fact  | ure   | r ID | : No | ordic | Ser | nico | ndu   | cto | AS   | A h  | as |   |   |   |     |     |     |   |
|       |         |       |                                       |       |        |       |      |     | ICN | /I 0> | ζ5F   |      |      |       |     |      |       |     |      |      |    |   |   |   |     |     |     |   |
| В     | R       | UD1   |                                       |       |        |       |      |     | Un  | iqu   | e ide | enti | fier | byt   | e 1 |      |       |     |      |      |    |   |   |   |     |     |     |   |
| С     | R       | UD2   |                                       |       |        |       |      |     |     | iqu   | e ide | enti | fier | byt   | e 2 |      |       |     |      |      |    |   |   |   |     |     |     |   |
| D     | R       | UD3   |                                       |       |        |       |      |     | Un  | iqu   | e ide | enti | fier | byt   | e 3 |      |       |     |      |      |    |   |   |   |     |     |     |   |

### **5.4.2.1.14 NFC.TAGHEADER1**

Address offset: 0x454

Default header for NFC Tag. Software can read these values to populate NFCID1\_3RD\_LAST, NFCID1\_2ND\_LAST and NFCID1\_LAST.



, ,



#### **5.4.2.1.15 NFC.TAGHEADER2**

Address offset: 0x458

Default header for NFC Tag. Software can read these values to populate NFCID1\_3RD\_LAST,

NFCID1\_2ND\_LAST and NFCID1\_LAST.



#### 5.4.2.1.16 NFC.TAGHEADER3

Address offset: 0x45C

Default header for NFC Tag. Software can read these values to populate NFCID1\_3RD\_LAST,

NFCID1\_2ND\_LAST and NFCID1\_LAST.

| Bit n | umber   |                |  | 313 | 30 29 | 9 28 | 3 27 | 26 | 25 | 24 | 23 2 | 22 : | 21 2 | 20 1 | 9 1  | 3 17 | 7 16 | 15 | 14 1 | 3 12 | 2 11 | 10 | 9 | 8 | 7 | 6  | 5 4 | 4 3 | 2 | 1 | 0 |
|-------|---------|----------------|--|-----|-------|------|------|----|----|----|------|------|------|------|------|------|------|----|------|------|------|----|---|---|---|----|-----|-----|---|---|---|
| ID    |         |                |  | D   | D C   | D    | D    | D  | D  | D  | С    | С    | C (  | С (  | 0    | . C  | С    | В  | В    | 3 B  | В    | В  | В | В | Α | Α. | Α / | 4 Α | A | Α | Α |
| Rese  | t OxFFF | FFFF           |  | 1   | 1 1   | . 1  | 1    | 1  | 1  | 1  | 1    | 1    | 1    | 1 :  | 1 1  | . 1  | 1    | 1  | 1 :  | l 1  | 1    | 1  | 1 | 1 | 1 | 1  | 1 : | 1 1 | 1 | 1 | 1 |
| ID    |         |                |  |     |       |      |      |    |    |    |      |      |      |      |      |      |      |    |      |      |      |    |   |   |   |    |     |     |   |   |   |
| A-D   | R       | UD[i] (i=1215) |  |     |       |      |      |    |    |    | Uni  | qu   | e id | ent  | ifie | by   | te i |    |      |      |      |    |   |   |   |    |     |     |   |   |   |

#### 5.4.2.1.17 TRNG90B.BYTES

Address offset: 0xC00

Amount of bytes for the required entropy bits

| Α     | R      | BYTE:   | <u> </u> |    |      |      |            |      |    |    | Am   | our  | ıt of | bvt | es f | or t | he   | rea  | uire | d er | ntro | l va | oits |   |   |   |   |   |    |     |
|-------|--------|---------|----------|----|------|------|------------|------|----|----|------|------|-------|-----|------|------|------|------|------|------|------|------|------|---|---|---|---|---|----|-----|
| ID    |        |         |          |    |      |      |            |      |    |    | Des  |      |       |     |      |      |      |      |      |      |      |      |      |   |   |   |   |   |    |     |
| Res   | et 0x0 | 0000210 |          | 0  | 0    | 0 (  | 0          | 0    | 0  | 0  | 0    | 0    | 0 0   | 0   | 0    | 0    | 0    | 0 (  | 0    | 0    | 0    | 0    | 1 (  | 0 | 0 | 0 | 1 | 0 | 0  | 0 0 |
| ID    |        |         |          | А  | Α    | Α /  | <b>А</b> А | Α    | Α  | Α  | Α    | A ,  | 4 Α   | Α   | Α    | Α    | Α.   | Δ,   | A A  | Α    | Α    | Α.   | Α /  | A | Α | Α | Α | Α | Α. | 4 A |
| Bit r | numbe  | er      |          | 31 | 30 2 | 29 2 | 8 27       | 7 26 | 25 | 24 | 23 2 | 22 2 | 1 20  | 19  | 18   | 17   | 16 1 | .5 1 | 4 13 | 12   | 11   | 10   | 9 8  | 7 | 6 | 5 | 4 | 3 | 2  | 1 0 |

#### 5.4.2.1.18 TRNG90B.RCCUTOFF

Address offset: 0xC04

Repetition counter cutoff

| Α     | R        | RCCUTOFF |                      | Repetition counter cutoff                                        |
|-------|----------|----------|----------------------|------------------------------------------------------------------|
| ID    |          |          |                      |                                                                  |
| Res   | et OxFFF | FFFFF    | 1 1 1 1 1 1 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                          |
| ID    |          |          | A A A A A A          | A A A A A A A A A A A A A A A A A A A                            |
| Bit r | number   |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 5.4.2.1.19 TRNG90B.APCUTOFF

Address offset: 0xC08

Adaptive proportion cutoff



| Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  ID A A A A A A A A A A A A A A A A A A A |
|--------------------------------------------------------------------------------------------------------------------------------------------|
| ID A A A A A A A A A A A A A A A A A A A                                                                                                   |
|                                                                                                                                            |
| Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                           |
|                                                                                                                                            |

#### 5.4.2.1.20 TRNG90B.STARTUP

Address offset: 0xC0C

Amount of bytes for the startup tests

| Bit n | umber   |         | 313 | 0 29 | 28 2 | 27 2 | 6 2 | 5 2 | 4 23 | 3 22 | 21 2  | 20 1 | 9 18 | 3 17 | 16  | L5 1 | 4 13 | 12   | 11 1 | .0 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 |
|-------|---------|---------|-----|------|------|------|-----|-----|------|------|-------|------|------|------|-----|------|------|------|------|------|---|---|---|---|-----|-----|---|---|
| ID    |         |         | A A | 4 A  | Α    | A    | Α Δ | λ Δ | A    | Α    | Α     | Α /  | 4 A  | Α    | Α   | Α /  | 4 A  | Α    | Α.   | 4 A  | Α | Α | Α | Α | A A | 4 A | Α | Α |
| Rese  | t OxFFF | FFFFF   | 1 1 | 1 1  | 1    | 1 :  | 1 1 | ۱ 1 | . 1  | 1    | 1     | 1 :  | 1 1  | 1    | 1   | 1 :  | l 1  | 1    | 1    | 1 1  | 1 | 1 | 1 | 1 | 1 : | l 1 | 1 | 1 |
| ID    |         |         |     |      |      |      |     |     |      |      |       |      |      |      |     |      |      |      |      |      |   |   |   |   |     |     |   |   |
| Α     | R       | STARTUP |     |      |      |      |     |     | Aı   | mοι  | ınt c | of b | /tes | for  | the | staı | tup  | test | s    |      |   |   |   |   |     |     |   | _ |

#### 5.4.2.1.21 TRNG90B.ROSC1

Address offset: 0xC10

Sample count for ring oscillator 1

| Α     | R        | ROSC1 |                |       | Sa    | mple | cou  | nt fo | r rin | g os | cillat | or 1 |      |            |   |     |   |     |     |   |   |     |
|-------|----------|-------|----------------|-------|-------|------|------|-------|-------|------|--------|------|------|------------|---|-----|---|-----|-----|---|---|-----|
| ID    |          |       |                |       |       |      |      |       |       |      |        |      |      |            |   |     |   |     |     |   |   |     |
| Rese  | et OxFFF | FFFFF | 1 1 1 1 1      | 1 1   | 1 1   | 1 :  | l 1  | 1 :   | 1 1   | 1    | 1 1    | 1    | 1 1  | l <b>1</b> | 1 | 1   | 1 | 1 1 | . 1 | 1 | 1 | 1 1 |
| ID    |          |       | A A A A A      | A A   | A A   | A A  | A A  | Α /   | 4 A   | A    | А А    | Α    | A A  | A A        | Α | Α . | A | A A | A   | Α | Α | АА  |
| Bit r | number   |       | 31 30 29 28 27 | 26 25 | 24 23 | 22 2 | 1 20 | 19 1  | .8 17 | 16 1 | .5 14  | 13   | 12 1 | 1 10       | 9 | 8   | 7 | 6 5 | 4   | 3 | 2 | 1 0 |

## 5.4.2.1.22 TRNG90B.ROSC2

Address offset: 0xC14

Sample count for ring oscillator 2

| Bit n | umber   |       | 31 | 30 2 | 9 28 | 3 27 | 26 | 25 | 24 2 | 23 22 | 2 2: | 1 20 | 19   | 18 1  | 7 16 | 5 15 | 14 : | l3 1 | 2 11 | l 10 | 9 | 8   | 7 ( | 5 5 | 4   | 3 | 2 | 1 0 |
|-------|---------|-------|----|------|------|------|----|----|------|-------|------|------|------|-------|------|------|------|------|------|------|---|-----|-----|-----|-----|---|---|-----|
| ID    |         |       | Α  | Α /  | 4 A  | A    | Α  | Α  | Α    | ДД    | . A  | Α    | Α    | Α /   | 4 A  | Α    | Α    | A A  | A A  | Α    | Α | A A | ۱ ۸ | Δ Δ | A   | Α | Α | АА  |
| Rese  | t OxFFF | FFFFF | 1  | 1    | 1 1  | 1    | 1  | 1  | 1    | 1 1   | 1    | 1    | 1    | 1 :   | 1 1  | 1    | 1    | 1 1  | l 1  | 1    | 1 | 1 : | L   | 1 1 | . 1 | 1 | 1 | 1 1 |
| ID    |         |       |    |      |      |      |    |    |      |       |      |      |      |       |      |      |      |      |      |      |   |     |     |     |     |   |   |     |
| Α     | R       | ROSC2 |    |      |      |      |    |    |      | Sam   | ole  | cou  | nt f | or ri | ng c | scil | lato | r 2  |      |      |   |     |     |     |     |   |   |     |

## 5.4.2.1.23 TRNG90B.ROSC3

Address offset: 0xC18

Sample count for ring oscillator 3

| Α     | R        | ROSC3 |     |      |      |      |      |    | Sam  | ple | cou  | ınt f | or r | ing o | osci | llato | or 3 |      |      |   |   |   |     |     |   |   |     |
|-------|----------|-------|-----|------|------|------|------|----|------|-----|------|-------|------|-------|------|-------|------|------|------|---|---|---|-----|-----|---|---|-----|
| ID    |          |       |     |      |      |      |      |    | Des  |     |      |       |      |       |      |       |      |      |      |   |   |   |     |     |   |   |     |
| Res   | et OxFFF | FFFFF | 1 1 | 1 1  | 1 1  | L 1  | . 1  | 1  | 1    | 1 : | l 1  | 1     | 1    | 1 1   | . 1  | 1     | 1    | 1 1  | . 1  | 1 | 1 | 1 | 1 1 | 1   | 1 | 1 | 1 1 |
| ID    |          |       | A A | A A  | A A  | A A  | A    | Α  | A    | Α Α | 4 A  | Α     | Α.   | ДД    | A    | Α     | Α    | A A  | A    | Α | Α | Α | A A | A A | Α | Α | A A |
| Bit r | number   |       | 313 | 0 29 | 28 2 | 7 26 | 6 25 | 24 | 23 2 | 2 2 | 1 20 | 19    | 18 1 | 17 10 | 5 15 | 14    | 13 1 | 12 1 | 1 10 | 9 | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 0 |



#### 5.4.2.1.24 TRNG90B.ROSC4

Address offset: 0xC1C

Sample count for ring oscillator 4



#### 5.4.2.1.25 XOSC32MTRIM

Address offset: 0xC20

XOSC32M capacitor selection trim values

**Note:** To enable the optional internal capacitors on XC1 and XC2 pins, see to the "Using internal capacitors" section of the OSCILLATORS chapter.



# 5.4.3 UICR — User information configuration registers

The user information configuration registers (UICRs) are non-volatile memory (NVM) registers for configuring user specific settings and storing secure cryptographic keys or OTP values.

The cryptographic key part of the UICR (addresses starting at 0x100 and higher) is handled by the Key Management Unit (KMU), see KMU — Key management unit on page 275 for more information.

For information on writing registers, see NVMC — Non-volatile memory controller on page 334 and Memory on page 19.

Note: UICR is not accessible from the network core.

## 5.4.3.1 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description             | Configuration |
|------------------------|------------|----------|----------------|--------------|-------------------------|---------------|
| 0x00FF8000 APPLICATION | UICR       | UICR     | S              | NA           | User information        |               |
|                        |            |          |                |              | configuration registers |               |

Table 40: Instances



| Register                | Offset | Security | Description                                                                           |
|-------------------------|--------|----------|---------------------------------------------------------------------------------------|
| APPROTECT               | 0x000  |          | Access port protection                                                                |
| VREGHVOUT               | 0x010  |          | Output voltage from the high voltage (VREGH) regulator stage. The maximum output      |
|                         |        |          | voltage from this stage is given as VDDH - VREGHDROP.                                 |
| HFXOCNT                 | 0x014  |          | HFXO startup counter                                                                  |
| SECUREAPPROTECT         | 0x01C  |          | Secure access port protection                                                         |
| ERASEPROTECT            | 0x020  |          | Erase protection                                                                      |
| TINSTANCE               | 0x024  |          | SW-DP Target instance                                                                 |
| NFCPINS                 | 0x028  |          | Setting of pins dedicated to NFC functionality: NFC antenna or GPIO                   |
| OTP[n]                  | 0x100  |          | One time programmable memory                                                          |
| KEYSLOT.CONFIG[n].DEST  | 0x400  |          | Destination address where content of the key value registers                          |
|                         |        |          | (KEYSLOT.KEYn.VALUE[0-3]) will be pushed by KMU. Note that this address must match    |
|                         |        |          | that of a peripherals APB mapped write-only key registers, else the KMU can push this |
|                         |        |          | key value into an address range which the CPU can potentially read.                   |
| KEYSLOT.CONFIG[n].PERM  | 0x404  |          | Define permissions for the key slot. Bits 0-15 and 16-31 can only be written when     |
|                         |        |          | equal to 0xFFFF.                                                                      |
| KEYSLOT.KEY[n].VALUE[o] | 0x800  |          | Define bits [31+o*32:0+o*32] of value assigned to KMU key slot.                       |

Table 41: Register overview

#### **5.4.3.1.1 APPROTECT**

Address offset: 0x000
Access port protection



### 5.4.3.1.2 VREGHVOUT

Address offset: 0x010

Output voltage from the high voltage (VREGH) regulator stage. The maximum output voltage from this stage is given as VDDH - VREGHDROP.





#### 5.4.3.1.3 HFXOCNT

Address offset: 0x014 HFXO startup counter

The CLKSTARTED events are generated after the HFXO power up time + the HFXOCNT-defined debounce time + PLL lock time has elapsed. If the HFXO has already been requested by another clock source and is already running, the CLKSTARTED event is generated as soon as the PLL has locked.

**Note:** When HFXOCNT field of this register is 0xFF, e.g. after UICR being erased, a debounce time of (4\*64 us + 0.5 us) is used



#### 5.4.3.1.4 SECUREAPPROTECT

Address offset: 0x01C

Secure access port protection

| Bit number       |             | 31 | 1 30 | 29  | 9 2 | 8 2 | 27 2 | 6 2 | 5 2 | 4 2 | 23  | 22   | 21   | 20   | 19   | 18    | 17   | 16   | 15  | 14  | 13  | 12   | 11   | 10     | 9    | 8   | 7   | 6  | 5 4 | 1 3 | 2 | 1 | 0 |
|------------------|-------------|----|------|-----|-----|-----|------|-----|-----|-----|-----|------|------|------|------|-------|------|------|-----|-----|-----|------|------|--------|------|-----|-----|----|-----|-----|---|---|---|
| ID               |             | Α  | Α    | Α   |     | Δ.  | A    | Δ Α | Δ / | Δ.  | Α   | Α    | Α    | Α    | Α    | Α     | Α    | Α    | Α   | Α   | Α   | Α    | Α    | Α      | Α    | Α   | Α   | Α. | A A | Δ Δ | A | A | Α |
| Reset 0x00000000 |             | 0  | 0    | 0   | 0   | 0   | 0 (  | 0 0 | ) ( | )   | 0   | 0    | 0    | 0    | 0    | 0     | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0      | 0    | 0   | 0   | 0  | 0 ( | 0   | 0 | 0 | 0 |
| ID R/W Field     |             |    |      |     |     |     |      |     |     |     |     |      |      |      |      |       |      |      |     |     |     |      |      |        |      |     |     |    |     |     |   |   |   |
| A RW PALL        |             |    |      |     |     |     |      |     |     | E   | Blo | cks  | de   | bu   | gge  | er re | ead  | l/w  | rit | e a | cce | ss t | o a  | ıll s  | ecu  | re  | CPl | J  |     |     |   |   |   |
|                  |             |    |      |     |     |     |      |     |     | r   | reg | iste | ers  | an   | d se | ecu   | re r | ne   | mo  | ry  | ma  | рре  | ed i | add    | lres | ses |     |    |     |     |   |   |   |
|                  |             |    |      |     |     |     |      |     |     | ι   | Usi | ng   | an   | y va | alue | e ex  | cep  | ot l | Jnp | oro | tec | ted  | wi   | ill le | ead  | to  | the |    |     |     |   |   |   |
|                  |             |    |      |     |     |     |      |     |     | F   | orc | tec  | ctio | n b  | eir  | ıg e  | nal  | ble  | d.  |     |     |      |      |        |      |     |     |    |     |     |   |   |   |
|                  |             |    |      |     |     |     |      |     |     | E   | Bit | s w  | ith  | val  | ue   | '1'   | car  | ı be | e w | rit | ten | to ' | 0'.  | Bit    | s w  | ith | val | ue | '0' |     |   |   |   |
|                  |             |    |      |     |     |     |      |     |     | (   | car | no   | t b  | e w  | ritt | ten   | to   | '1'. |     |     |     |      |      |        |      |     |     |    |     |     |   |   |   |
|                  | Unprotected | 0> | x50  | FA5 | 50F | FΑ  |      |     |     | ι   | Jn  | pro  | teo  | cte  | t    |       |      |      |     |     |     |      |      |        |      |     |     |    |     |     |   |   |   |
|                  | Protected   | 0> | к00( | 000 | 000 | 00  |      |     |     | F   | Pro | tec  | cte  | b    |      |       |      |      |     |     |     |      |      |        |      |     |     |    |     |     |   |   |   |



#### 5.4.3.1.5 ERASEPROTECT

Address offset: 0x020

**Erase protection** 

| Bit nu | ımber |       |             | 313 | 0   | 29 2 | 8 2 | 27 20 | 6 25 | 5 24 | 23  | 22 2  | 1 2 | 20 19 | 9 18 | 8 17 | 16   | 15   | 14  | 13   | 12 1 | 1 1  | 0 9  | 8    | 7   | 6 | 5 - | 4 3 | 2   | 1 0   |
|--------|-------|-------|-------------|-----|-----|------|-----|-------|------|------|-----|-------|-----|-------|------|------|------|------|-----|------|------|------|------|------|-----|---|-----|-----|-----|-------|
| ID     |       |       |             | Α . | Д   | Α ,  | Δ , | ДД    | A    | Α    | Α   | Α /   | Д   | ΑД    | . Δ  | A A  | Α    | Α    | Α   | Α    | A A  | λ Α  | A    | Α    | Α   | Α | Α.  | A A | A A | . A A |
| Reset  | 0x000 | 00000 |             | 0   | 0   | 0 (  | 0 ( | 0 0   | 0    | 0    | 0   | 0 (   | 0   | 0 0   | 0    | 0    | 0    | 0    | 0   | 0    | 0 (  | ) (  | 0    | 0    | 0   | 0 | 0   | 0 0 | 0   | 0 0   |
| ID     |       |       |             |     |     |      |     |       |      |      |     |       |     |       |      |      |      |      |     |      |      |      |      |      |     |   |     |     |     |       |
| Α      | RW    | PALL  |             |     |     |      |     |       |      |      | Blo | ocks  | N۷  | /MC   | ER.  | ASE  | ALL  | . an | d C | TRL  | AP I | ERA  | SEA  | LL   |     |   |     |     |     |       |
|        |       |       |             |     |     |      |     |       |      |      | fur | nctio | na  | lity. |      |      |      |      |     |      |      |      |      |      |     |   |     |     |     |       |
|        |       |       |             |     |     |      |     |       |      |      | Us  | ing a | any | valı  | ue ( | exce | pt   | Unp  | oro | tect | ed v | vill | lead | d to | the | 2 |     |     |     |       |
|        |       |       |             |     |     |      |     |       |      |      | pro | otect | tio | n be  | ing  | ena  | able | ed.  |     |      |      |      |      |      |     |   |     |     |     |       |
|        |       |       | Unprotected | 0xF | FFI | FFFF | F   |       |      |      | Un  | prot  | ec  | ted   |      |      |      |      |     |      |      |      |      |      |     |   |     |     |     |       |
|        |       |       | Protected   | 0x0 | 00  | 000  | 00  |       |      |      | Pro | otect | ted | i     |      |      |      |      |     |      |      |      |      |      |     |   |     |     |     |       |

#### **5.4.3.1.6 TINSTANCE**

Address offset: 0x024 SW-DP Target instance

| Bit n | umber   |           | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|------------------------|-----------------------------------------------------------------|
| ID    |         |           | A A A A                |                                                                 |
| Rese  | t OxFFF | FFFFF     | 1 1 1 1 1 1 1 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |         |           |                        | Description                                                     |
| Α     | RW      | TINSTANCE |                        | TINSTANCE bits are negated and used in the SW-DP                |
|       |         |           |                        | DLPIDR.TINSTANCE field.                                         |
|       |         |           |                        | E.g. 0xF in this field is translated to 0x0 in                  |
|       |         |           |                        | DLPIDR.TINSTANCE field.                                         |

## 5.4.3.1.7 NFCPINS

Address offset: 0x028

Setting of pins dedicated to NFC functionality: NFC antenna or GPIO

**Note:** When used as NFC antenna pin, the corresponding pin must be controlled by the application core, and the GPIO PIN\_CNF register initialized to its reset value.



# 5.4.3.1.8 OTP[n] (n=0..191)

Address offset:  $0x100 + (n \times 0x4)$ 



#### One time programmable memory



## 5.4.3.1.9 KEYSLOT.CONFIG[n].DEST (n=0..127)

Address offset:  $0x400 + (n \times 0x8)$ 

Destination address where content of the key value registers (KEYSLOT.KEYn.VALUE[0-3]) will be pushed by KMU. Note that this address must match that of a peripherals APB mapped write-only key registers, else the KMU can push this key value into an address range which the CPU can potentially read.

Note: Writing/reading this register requires the KMU SELECTKEYSLOT register to be set to n+1.



## 5.4.3.1.10 KEYSLOT.CONFIG[n].PERM (n=0..127)

Address offset:  $0x404 + (n \times 0x8)$ 

Define permissions for the key slot. Bits 0-15 and 16-31 can only be written when equal to 0xFFFF.

Note: Writing/reading this register requires the KMU SELECTKEYSLOT register to be set to n+1.

| Bit r | number   |       |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |       |          |                        | D C B A                                                         |
| Rese  | et OxFFF | FFFFF |          | 1 1 1 1 1 1 1 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |          |       |          |                        |                                                                 |
| Α     | RW       | WRITE |          |                        | Write permission for key slot                                   |
|       |          |       | Disabled | 0                      | Disable write to the key value registers                        |
|       |          |       | Enabled  | 1                      | Enable write to the key value registers                         |
| В     | RW       | READ  |          |                        | Read permission for key slot                                    |
|       |          |       | Disabled | 0                      | Disable read from key value registers                           |
|       |          |       | Enabled  | 1                      | Enable read from key value registers                            |
| С     | RW       | PUSH  |          |                        | Push permission for key slot                                    |
|       |          |       | Disabled | 0                      | Disable pushing of key value registers over secure APB, but     |
|       |          |       |          |                        | can be read if field READ is Enabled                            |
|       |          |       | Enabled  | 1                      | Enable pushing of key value registers over secure APB.          |
|       |          |       |          |                        | Register KEYSLOT.CONFIGn.DEST must contain a valid              |
|       |          |       |          |                        | destination address!                                            |
|       |          |       |          |                        |                                                                 |





# 5.4.3.1.11 KEYSLOT.KEY[n].VALUE[o] (n=0..127) (o=0..3)

Address offset:  $0x800 + (n \times 0x10) + (o \times 0x4)$ 

Define bits [31+o\*32:0+o\*32] of value assigned to KMU key slot.

**Note:** Writing/reading this register requires the KMU SELECTKEYSLOT register to be set to n+1.



# 5.4.4 AHB multilayer

AHB multilayer enables parallel access paths between multiple masters and slaves in a system. Access is resolved using priorities.

Each bus master is connected to a slave device through one or more interconnection matrixes. The bus masters are assigned priorities that are used to resolve access when two (or more) bus masters request access to the same slave device. The following applies when assigning priorities:

- If two (or more) bus masters request access to the same slave device, the master with the highest priority is granted access first.
- If a higher priority bus master transaction is on-going, bus masters with lower priority are stalled.
   Either until the higher priority master has completed its transaction, or the higher priority master at any point pauses during its transaction. During this pause, the lower priority master in queue is temporarily granted access to the slave device until the higher priority master resumes its activity.
- If a lower priority bus master transaction is on-going, and a master with higher priority requests access to the same slave device, the lower priority bus master is stalled after the current word access has been completed. The slave transaction will continue following the rules above.
- Bus masters that have the same priority are mutually exclusive, and cannot be used concurrently.

Some peripherals, like I2S, do not have a safe stalling mechanism (not able to pause incoming data and no internal data buffering). Being a low priority bus master might cause loss of data for such peripherals upon bus contention. To avoid AHB bus contention when using multiple bus masters, apply one of the following guidelines:

- Avoid situations where more than one bus master is accessing the same slave.
- If more than one bus master is accessing the same slave, make sure that the bus bandwidth is not exhausted.



# 5.4.4.1 AHB multilayer priorities

Each master connected to the AHB multilayer is assigned a default natural priority.

| Bus master name                    | Natural relative priority | In/Out |
|------------------------------------|---------------------------|--------|
| CPU                                | Highest priority          | I/O    |
| Network core                       |                           | I/O    |
| 12S                                |                           | I/O    |
| PDM                                |                           | 1      |
| UARTEO, SPIMO, SPISO, TWIMO, TWISO |                           | I/O    |
| UARTE1, SPIM1, SPIS1, TWIM1, TWIS1 |                           | I/O    |
| UARTE2, SPIM2, SPIS2, TWIM2, TWIS2 |                           | I/O    |
| UARTE3, SPIM3, SPIS3, TWIM3, TWIS3 |                           | 1/0    |
| SAADC                              |                           | 1      |
| PWM0                               |                           | 0      |
| PWM1                               |                           | 0      |
| PWM2                               |                           | 0      |
| PWM3                               |                           | 0      |
| SPIM4                              |                           | I/O    |
| NFCT                               |                           | I/O    |
| CC312                              |                           | I/O    |
| USBD                               |                           | I/O    |
| QSPI                               | Lowest priority           | I/O    |

Table 42: AHB bus masters



# 6 Network core

The network core contains a low-power microcontroller with embedded flash memory and an Arm Cortex-M33 processor.

The network core includes peripherals for efficient implementation of radio protocols such as Bluetooth Low Energy, 802.15.4, and proprietary 2.4 GHz. The following figure provides more information. Arrows with white heads indicate signals that share physical pins with other signals.

# 6.1 Block diagram

The following image shows the network core block diagram.





Figure 31: Network core block diagram

# 6.2 CPU

The Arm Cortex-M33 processor has a 32-bit instruction set (Thumb-2 technology) that implements a super set of 16- and 32-bit instructions to maximize code density and performance.



This processor implements several features that enable energy-efficient arithmetic and high-performance signal processing including:

- Hardware divide
- 8- and 16-bit single instruction multiple data (SIMD) instructions
- Memory Protection Unit (MPU)

The Arm Cortex Microcontroller Software Interface Standard (CMSIS) is implemented and available for the application processor.

Real-time execution is highly deterministic in thread mode, to and from sleep modes, and when handling events at configurable priority levels via the Nested Vectored Interrupt Controller (NVIC).

Executing code from internal or external flash will have a wait state penalty. The instruction cache can be enabled to minimize flash wait states when fetching instructions. For more information on cache, see NVMC — Non-volatile memory controller on page 334. CPU performance parameters including mode wait states, CPU current and efficiency, and processing power and efficiency based on the CoreMark benchmark can be found in Electrical specification on page 138.

# 6.2.1 Electrical specification

# 6.2.1.1 CPU performance

| Symbol                   | Description                                         | Min. | Тур. | Max. | Units     |
|--------------------------|-----------------------------------------------------|------|------|------|-----------|
| $W_{FLASH}$              | CPU wait states, running from flash, cache disabled | 0    |      | 4    |           |
| W <sub>FLASHCACHE</sub>  | CPU wait states, running from flash, cache enabled  | 0    |      | 5    |           |
| W <sub>RAM</sub>         | CPU wait states, running from RAM                   |      | 0    |      |           |
| CM <sub>FLASHCACHE</sub> | CoreMark, running from flash, cache enabled         |      | 244  |      | CoreMark  |
| $CM_{FLASH/MHz}$         | CoreMark per MHz, running from flash, cache enabled |      | 3.8  |      | CoreMark/ |
|                          |                                                     |      |      |      | MHz       |
| CM <sub>FLASH/mA</sub>   | CoreMark per mA, running from flash, cache enabled  |      | 101  |      | CoreMark/ |
|                          |                                                     |      |      |      | mA        |

# 6.2.2 CPU and support module configuration

The Arm Cortex-M33 processor has a number of CPU options and support modules implemented on the device.



| Option/Module        | Description                                   | Implemented                                             |
|----------------------|-----------------------------------------------|---------------------------------------------------------|
| Core options         |                                               |                                                         |
| PRIORITIES           | Priority bits                                 | 3                                                       |
| WIC                  | Wakeup Interrupt Controller                   | NO                                                      |
| Endianness           | Memory system endianness                      | Little endian                                           |
| DWT                  | Data Watchpoint and Trace                     | YES                                                     |
| Modules              |                                               |                                                         |
| MPU                  | Number of non-secure MPU regions              | 8                                                       |
|                      | Number of secure MPU regions                  | 0 (No Armv8-M Security Extensions)                      |
| SAU                  | Number of SAU regions                         | 0 (No Arm TrustZone for Armv8-M<br>Security Extensions) |
| FPU                  | Floating-point unit                           | NO                                                      |
| DSP                  | Digital Signal Processing Extension           | NO                                                      |
| Armv8-M<br>TrustZone | Arm TrustZone for Armv8-M Security Extensions | NO                                                      |
| CPIF                 | Coprocessor interface                         | NO                                                      |
| ETM                  | Embedded Trace Macrocell                      | NO                                                      |
| ITM                  | Instrumentation Trace Macrocell               | NO                                                      |
| МТВ                  | Micro Trace Buffer                            | NO                                                      |
| СТІ                  | Cross Trigger Interface                       | YES                                                     |
| BPU                  | Breakpoint Unit                               | YES                                                     |
| нтм                  | AHB Trace Macrocell                           | NO                                                      |

# 6.3 Memory

The network core contains flash memory and RAM that can be used for code and data storage.

The following figure shows how the CPU and peripherals with EasyDMA can access RAM via the AHB multilayer interconnect.

The network core can access application core resources (flash, RAM, and peripherals) when granted permission through the application's DCNF and SPU settings. A small portion of the application core RAM is dedicated to the exchange of messages between the application and network cores.





Figure 32: Memory layout

# 6.3.1 Peripheral instantiation

The following table describes the abbreviations used in the Instance, Secure mapping, and DMA security columns of the instantiation table.



| Abbreviation | Description                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| NS           | Non-secure - Peripheral is always accessible as a Non-Secure peripheral                                                                   |
| S            | Secure - Peripheral is always accessible as a Secure peripheral                                                                           |
| US           | User Selectable - A Secure or Non-secure attribute for the peripheral is defined in the SPU                                               |
| SPLIT        | Both Secure and Non-secure - The same resource is shared by both secure and non-secure code                                               |
| NA           | Not Applicable - Peripheral has no DMA capability                                                                                         |
| NSA          | NoSeparateAttribute - Peripheral with DMA and DMA transfer has the same security attribute as assigned to the peripheral                  |
| SA           | SeparateAttribute - Peripheral with DMA and DMA transfers can have a different security attribute than the one assigned to the peripheral |

Table 43: Instantiation table abbreviations

The Secure mapping column in the following table defines configuration capabilities for the Arm TrustZone for Armv8-M secure attribute. The DMA security column describes the DMA capabilities of the peripheral.

# 6.3.2 Instantiation

| ID | Base address             | Peripheral | Instance | Secure mapping | DMA socurity | Description                                 |
|----|--------------------------|------------|----------|----------------|--------------|---------------------------------------------|
| 0  | 0x41000000               | DCNF       | DCNF     | NS             | NA Security  | Domain configuration                        |
| 4  | 0x41000000               | VREQCTRL   | VREQCTRL | NS             | NA           | Voltage request control                     |
| 5  | 0x41004000<br>0x41005000 | CLOCK      | CLOCK    | NS             | NA           | Clock control                               |
|    | 0x41005000<br>0x41005000 | POWER      | POWER    |                | NA           | Power control                               |
| 5  |                          |            |          | NS             |              |                                             |
| 5  | 0x41005000               | RESET      | RESET    | NS             | NA           | Reset status                                |
| 6  | 0x41006000               | CTRLAPPERI | CTRLAP   | NS             | NA           | Control access port CPU side                |
| 8  | 0x41008000               | RADIO      | RADIO    | NS             | NA           | 2.4 GHz radio                               |
| 9  | 0x41009000               | RNG        | RNG      | NS             | NA           | Random number generator                     |
| 10 | 0x4100A000               | GPIOTE     | GPIOTE   | NS             | NA           | GPIO tasks and events                       |
| 11 | 0x4100B000               | WDT        | WDT      | NS             | NA           | Watchdog timer                              |
| 12 | 0x4100C000               | TIMER      | TIMER0   | NS             | NA           | Timer 0                                     |
| 13 | 0x4100D000               | ECB        | ECB      | NS             | NA           | AES electronic code book (ECB) mode block   |
|    |                          |            |          |                |              | encryption                                  |
| 14 | 0x4100E000               | AAR        | AAR      | NS             | NA           | Accelerated address resolver                |
| 14 | 0x4100E000               | CCM        | CCM      | NS             | NA           | AES counter with CBC-MAC (CCM) mode block   |
|    |                          |            |          |                |              | encryption                                  |
| 15 | 0x4100F000               | DPPIC      | DPPIC    | NS             | NA           | DPPI controller                             |
| 16 | 0x41010000               | TEMP       | TEMP     | NS             | NA           | Temperature sensor                          |
| 17 | 0x41011000               | RTC        | RTC0     | NS             | NA           | Real-time counter 0                         |
| 18 | 0x41012000               | IPC        | IPC      | NS             | NA           | Interprocessor communication                |
| 19 | 0x41013000               | SPIM       | SPIM0    | NS             | NA           | SPI master 0                                |
| 19 | 0x41013000               | SPIS       | SPIS0    | NS             | NA           | SPI slave 0                                 |
| 19 | 0x41013000               | TWIM       | TWIM0    | NS             | NA           | Two-wire interface master 0                 |
| 19 | 0x41013000               | TWIS       | TWIS0    | NS             | NA           | Two-wire interface slave 0                  |
| 19 | 0x41013000               | UARTE      | UARTE0   | NS             | NA           | Universal asynchronous receiver/transmitter |
| 20 | 0x41014000               | EGU        | EGU0     | NS             | NA           | Event generator unit 0                      |
| 22 | 0x41016000               | RTC        | RTC1     | NS             | NA           | Real-time counter 1                         |
| 24 | 0x41018000               | TIMER      | TIMER1   | NS             | NA           | Timer 1                                     |
| 25 | 0x41019000               | TIMER      | TIMER2   | NS             | NA           | Timer 2                                     |
|    |                          |            |          | -              |              | •                                           |



| ID  | Base address | Peripheral | Instance | Secure mapping | DMA security | Description                       |
|-----|--------------|------------|----------|----------------|--------------|-----------------------------------|
| 26  | 0x4101A000   | SWI        | SWI0     | NS             | NA           | Software interrupt 0              |
| 27  | 0x4101B000   | SWI        | SWI1     | NS             | NA           | Software interrupt 1              |
| 28  | 0x4101C000   | SWI        | SWI2     | NS             | NA           | Software interrupt 2              |
| 29  | 0x4101D000   | SWI        | SWI3     | NS             | NA           | Software interrupt 3              |
| 128 | 0x41080000   | ACL        | ACL      | NS             | NA           | Access control lists              |
| 128 | 0x41080000   | NVMC       | NVMC     | NS             | NA           | Non-Volatile Memory Controller    |
| 129 | 0x41081000   | VMC        | VMC      | NS             | NA           | Volatile memory controller        |
| 192 | 0x418C0500   | GPIO       | P0       | NS             | NA           | General purpose input and output  |
| 192 | 0x418C0800   | GPIO       | P1       | NS             | NA           | General purpose input and output  |
| N/A | 0x01FF0000   | FICR       | FICR     | NS             | NA           | Factory information configuration |
| N/A | 0x01FF8000   | UICR       | UICR     | NS             | NA           | User information configuration    |
| N/A | 0xE0042000   | СТІ        | СТІ      | NS             | NA           | Cross-trigger interface           |

Table 44: Instantiation table

# 6.4 Core components

# 6.4.1 FICR — Factory information configuration registers

Factory information configuration registers (FICR) are pre-programmed in factory and cannot be erased by the user. These registers contain chip-specific information and configuration.

# 6.4.1.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description         | Configuration |
|---------------------|------------|----------|----------------|--------------|---------------------|---------------|
| 0x01FF0000 NETWORK  | FICR       | FICR     | NS             | NA           | Factory information |               |
|                     |            |          |                |              | configuration       |               |

Table 45: Instances

| Register          | Offset | Security | Description                                                 |
|-------------------|--------|----------|-------------------------------------------------------------|
| INFO.CONFIGID     | 0x200  |          | Configuration identifier                                    |
| INFO.DEVICEID[n]  | 0x204  |          | Device identifier                                           |
| INFO.PART         | 0x20C  |          | Part code                                                   |
| INFO.VARIANT      | 0x210  |          | Part Variant, Hardware version and Production configuration |
| INFO.PACKAGE      | 0x214  |          | Package option                                              |
| INFO.RAM          | 0x218  |          | RAM variant                                                 |
| INFO.FLASH        | 0x21C  |          | Flash variant                                               |
| INFO.CODEPAGESIZE | 0x220  |          | Code memory page size in bytes                              |
| INFO.CODESIZE     | 0x224  |          | Code memory size                                            |
| INFO.DEVICETYPE   | 0x228  |          | Device type                                                 |
| ER[n]             | 0x280  |          | Encryption Root, word n                                     |
| IR[n]             | 0x290  |          | Identity Root, word n                                       |
| DEVICEADDRTYPE    | 0x2A0  |          | Device address type                                         |
| DEVICEADDR[n]     | 0x2A4  |          | Device address n                                            |
| TRIMCNF[n].ADDR   | 0x300  |          | Address                                                     |
| TRIMCNF[n].DATA   | 0x304  |          | Data                                                        |

Table 46: Register overview



#### 6.4.1.1.1 INFO.CONFIGID

Address offset: 0x200 Configuration identifier



# 6.4.1.1.2 INFO.DEVICEID[n] (n=0..1)

Address offset:  $0x204 + (n \times 0x4)$ 

Device identifier

| A R      | DEVICEID |       |      |      |      |       | 64     | bit u | niqu | ie de | evice | ide | ntifi | er   |      |      |   |     |   |   |   |     |       |
|----------|----------|-------|------|------|------|-------|--------|-------|------|-------|-------|-----|-------|------|------|------|---|-----|---|---|---|-----|-------|
|          |          |       |      |      |      |       |        |       |      |       |       |     |       |      |      |      |   |     |   |   |   |     |       |
| ID R/    |          |       |      |      |      |       |        |       |      |       |       |     |       |      |      |      |   |     |   |   |   |     |       |
| Reset 0x | FFFFFFF  | 1 1   | 1 1  | ۱ 1  | 1    | 1 1   | 1      | 1 1   | . 1  | 1     | 1 1   | 1   | 1 :   | 1 1  | 1 1  | . 1  | 1 | 1 1 | 1 | 1 | 1 | 1 1 | 1 1   |
| ID       |          | A A   | A A  | A A  | Α /  | ДД    | Α      | ΑА    | A    | Α /   | 4 A   | Α   | A A   | 4 A  | A A  | A    | Α | ΑА  | Α | Α | Α | А А | . A A |
| Bit numb | per      | 31 30 | 29 2 | 8 27 | 26 2 | 25 24 | 4 23 2 | 22 2  | 1 20 | 19 1  | .8 17 | 16  | 15 1  | 4 13 | 12 1 | 1 10 | 9 | 8 7 | 6 | 5 | 4 | 3 2 | 1 0   |

DEVICEID[0] contains the least significant bits of the device identifier. DEVICEID[1] contains the most significant bits of the device identifier.

## 6.4.1.1.3 INFO.PART

Address offset: 0x20C

Part code



#### 6.4.1.1.4 INFO.VARIANT

Address offset: 0x210

Part Variant, Hardware version and Production configuration



| Bit n | umber   |         |      | 31  | 30  | 29 | 28  | 27 2 | 26 2 | 25 | 24 | 23             | 22   | 21   | 20  | 19  | 18  | 17 | 16 | 15  | 14  | 13   | 12   | 11 1 | 10 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2  | 1 0 |
|-------|---------|---------|------|-----|-----|----|-----|------|------|----|----|----------------|------|------|-----|-----|-----|----|----|-----|-----|------|------|------|------|-----|---|---|---|---|---|----|-----|
| ID    |         |         |      | Α   | Α   | Α  | Α   | Α.   | Α    | Α  | Α  | Α              | Α    | Α    | Α   | Α   | Α   | Α  | Α  | Α   | Α   | Α    | Α    | Α.   | A A  | . Δ | A | Α | Α | Α | Α | Α. | A A |
| Rese  | t OxFFF | FFFFF   |      | 1   | 1   | 1  | 1   | 1    | 1    | 1  | 1  | 1              | 1    | 1    | 1   | 1   | 1   | 1  | 1  | 1   | 1   | 1    | 1    | 1    | 1 1  | . 1 | 1 | 1 | 1 | 1 | 1 | 1  | 1 1 |
| ID    |         |         |      |     |     |    |     |      |      |    |    |                |      |      |     |     |     |    |    |     |     |      |      |      |      |     |   |   |   |   |   |    |     |
| Α     | R       | VARIANT |      |     |     |    |     |      |      |    |    | Pai            | rt V | /ari | ant | , н | ard | wa | re | ver | sio | n ar | nd F | roc  | luct | ion |   |   |   |   |   |    |     |
|       |         |         |      |     |     |    |     |      |      |    |    | configuration, |      |      |     |     | enc | od | ed | as  | AS( | II   |      |      |      |     |   |   |   |   |   |    |     |
|       |         |         | QKAA | 0x5 | 514 | B4 | 141 |      |      |    |    | QK             | ΆΑ   |      |     |     |     |    |    |     |     |      |      |      |      |     |   |   |   |   |   |    |     |
|       |         |         | CLAA | 0x4 | 134 | C4 | 141 |      |      |    |    | CL             | ΔА   |      |     |     |     |    |    |     |     |      |      |      |      |     |   |   |   |   |   |    |     |
|       |         |         |      |     |     |    |     |      |      |    |    |                |      |      |     |     |     |    |    |     |     |      |      |      |      |     |   |   |   |   |   |    |     |

# 6.4.1.1.5 INFO.PACKAGE

Address offset: 0x214

Package option

| Bit number |         |         |    | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------|---------|---------|----|-------------------------|---------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| ID         |         |         |    | A A A A A A A           | A A A A A A A A A A A A A A A A A A A                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese       | t OxFFF | FFFFF   |    | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|            |         |         |    |                         |                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Α          | R       | PACKAGE |    |                         | Package option                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|            |         |         | QK | 0x2000                  | QKxx - 94-pin aQFN                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|            |         |         | CI | 02005                   | CLxx - WLCSP                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|            |         |         | CL | 0x2005                  | CLXX - WLCSP                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 6.4.1.1.6 INFO.RAM

Address offset: 0x218

RAM variant

| Bit number      |   |     |             | 31           | 30 | 29 2 | 28 2 | 7 26       | 25           | 5 24          | 1 23          | 3 2: | 2 21 | . 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 1 | .0 9 | 9 8 | 3 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | ı |
|-----------------|---|-----|-------------|--------------|----|------|------|------------|--------------|---------------|---------------|------|------|------|-----|----|----|----|----|----|----|----|------|------|-----|-----|---|---|---|---|---|-----|---|
| ID              |   |     |             | Α            | Α  | Α    | A A  | A A        | Α            | Α             | Α             | Δ    | A    | Α    | Α   | Α  | Α  | Α  | Α  | Α  | Α  | Α  | A .  | Δ ,  | Δ Α | A A | Α | Α | Α | Α | Α | A A | ı |
| Reset 0xFFFFFFF |   |     |             |              | 1  | 1    | 1 1  | l <b>1</b> | 1            | 1             | 1             | 1    | 1    | 1    | 1   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1    | 1 :  | 1 : | l 1 | 1 | 1 | 1 | 1 | 1 | 1 1 | ı |
| ID              |   |     |             |              |    |      |      |            |              |               |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
| Α               | R | RAM |             |              |    |      |      |            |              | RAM variant   |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K16         | 0x10<br>0x20 |    |      |      |            |              | 16 kByte RAM  |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K32         |              |    |      |      |            | 32 kByte RAM |               |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K64         | 0x40         |    |      |      |            | 64 kByte RAM |               |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K128        | 0x80         |    |      |      |            |              | 128 kByte RAM |               |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K256        | 0x100        |    |      |      |            |              |               | 25            | 56   | kBy  | te I | RAN | M  |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | K512        | 0x200        |    |      |      |            |              | 51            | 512 kByte RAM |      |      |      |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |
|                 |   |     | Unspecified | 0xFFFFFFF    |    |      |      |            |              | Uı            | nsr           | oeci | fie  | d    |     |    |    |    |    |    |    |    |      |      |     |     |   |   |   |   |   |     |   |

# 6.4.1.1.7 INFO.FLASH

Address offset: 0x21C

Flash variant



| Bit n | umber    |       |             | 31  | 30  | 29  | 28  | 27 2 | 26 2 | 5 2 | 24 2 | 3 2 | 22 2 | 1 2  | 20 1 | 9 1        | 8 17 | 7 16 | 5 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 7 | 7 6        | 5 5 | 4   | 3 | 2 | 1 0 |
|-------|----------|-------|-------------|-----|-----|-----|-----|------|------|-----|------|-----|------|------|------|------------|------|------|------|----|----|----|----|----|---|-----|------------|-----|-----|---|---|-----|
| ID    |          |       |             | Α   | Α   | Α   | Α   | Α    | Α /  | Δ,  | A A  | Δ.  | A A  | ۱ ۸  | Α Α  | \ <i>A</i> | A A  | Α    | Α    | Α  | Α  | Α  | Α  | Α  | A | Α Α | \ <i>A</i> | Δ Δ | ι A | Α | Α | A A |
| Rese  | t OxFFFI | FFFF  |             | 1   | 1   | 1   | 1   | 1    | 1 :  | 1 : | 1 1  | ı   | 1 :  | ι :  | 1 1  | ۱ 1        | l 1  | 1    | 1    | 1  | 1  | 1  | 1  | 1  | 1 | 1 1 | L 1        | 1 1 | . 1 | 1 | 1 | 1 1 |
| ID    |          |       |             |     |     |     |     |      |      |     |      |     |      |      |      |            |      |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
| Α     | R        | FLASH |             |     |     |     |     |      |      |     | F    | las | h v  | aria | ant  |            |      |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | K128        | 0x  | 80  |     |     |      |      |     | 1    | .28 | kB   | yte  | FL/  | ٩SH        | ł    |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | K256        | 0x  | 100 | )   |     |      |      |     | 2    | 56  | kB   | yte  | FLA  | ٩SH        | ł    |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | K512        | 0x  | 200 | )   |     |      |      |     | 5    | 12  | kB   | yte  | FL/  | ٩SH        | ł    |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | K1024       | 0x4 | 400 | )   |     |      |      |     | 1    | . M | lByt | e F  | LAS  | Н          |      |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | K2048       | 0x  | 800 | )   |     |      |      |     | 2    | M   | lByt | e F  | LAS  | Н          |      |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |
|       |          |       | Unspecified | 0x  | FFF | FFF | FFF |      |      |     | L    | Jns | pec  | ifie | ed   |            |      |      |      |    |    |    |    |    |   |     |            |     |     |   |   |     |

#### 6.4.1.1.8 INFO.CODEPAGESIZE

Address offset: 0x220

Code memory page size in bytes

| Bit n | umber   |              |       | 31  | 30  | 29 2 | 28 27 | 7 26 | 25 | 24 | 23 2 | 22 2 | 21 20 | 0 19 | 18 | 17   | 16 1 | 5 1  | 4 13 | 12 : | 11 1 | 0 9 | 8 | 7 | 6 | 5 | 4 3 | 2 | 1 0 |
|-------|---------|--------------|-------|-----|-----|------|-------|------|----|----|------|------|-------|------|----|------|------|------|------|------|------|-----|---|---|---|---|-----|---|-----|
| ID    |         |              |       | Α   | Α   | Α    | A A   | Α    | Α  | Α  | Α.   | A    | ΑД    | Α    | Α  | Α    | A A  | λ Δ  | A    | Α    | A A  | A A | Α | Α | Α | A | ΑД  | Α | A A |
| Rese  | t 0x000 | 00800        |       | 0   | 0   | 0    | 0 0   | 0    | 0  | 0  | 0    | 0    | 0 0   | 0    | 0  | 0    | 0 (  | 0    | 0    | 0    | 1 (  | 0   | 0 | 0 | 0 | 0 | 0 0 | 0 | 0 0 |
| ID    |         |              |       |     |     |      |       |      |    |    | Des  |      |       |      |    |      |      |      |      |      |      |     |   |   |   |   |     |   |     |
| Α     | R       | CODEPAGESIZE |       |     |     |      |       |      |    |    | Cod  | le r | nem   | ory  | ра | ge s | ze i | n by | /tes |      |      |     |   |   |   |   |     |   |     |
|       |         |              | K2048 | 0x8 | 300 | )    |       |      |    |    | 2 kE | 3yt  | е     |      |    |      |      |      |      |      |      |     |   |   |   |   |     |   |     |

#### 6.4.1.1.9 INFO.CODESIZE

Address offset: 0x224 Code memory size

| Bit number         | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------------------|----------------------|------------------------------------------------------------------|
| ID                 | A A A A A A          | A A A A A A A A A A A A A A A A A A A                            |
| Reset 0x00000080   | 0 0 0 0 0 0 0        | $\begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 $     |
| ID R/W Field Value |                      | Description                                                      |
| A R CODESIZE       |                      | Code memory size in number of pages                              |
|                    |                      | Total code space is: CODEPAGESIZE * CODESIZE bytes               |
| P128               | 128                  | 128 pages                                                        |

#### 6.4.1.1.10 INFO.DEVICETYPE

Address offset: 0x228

Device type

| Bit n | umber    |            |      | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------|------|------------------------|-----------------------------------------------------------------|
| ID    |          |            |      | A A A A A A A          | A A A A A A A A A A A A A A A A A A A                           |
| Rese  | et 0x000 | 00000      |      | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |            |      |                        |                                                                 |
| Α     | R        | DEVICETYPE |      |                        | Device type                                                     |
|       |          |            | Die  | 0x0000000              | Device is an physical DIE                                       |
|       |          |            | FPGA | 0xFFFFFFF              | Device is an FPGA                                               |





## 6.4.1.1.11 ER[n] (n=0..3)

Address offset:  $0x280 + (n \times 0x4)$ 

Encryption Root, word n

| ^     | В       | ER    |                     | Encryption Root, word n                                           |
|-------|---------|-------|---------------------|-------------------------------------------------------------------|
| ID    |         |       |                     |                                                                   |
| Rese  | t OxFFF | FFFFF | 1 1 1 1 1 1 1       | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                           |
| ID    |         |       | A A A A A A         | A A A A A A A A A A A A A A A A A A A                             |
| Bit n | umber   |       | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |

# 6.4.1.1.12 IR[n] (n=0..3)

Address offset:  $0x290 + (n \times 0x4)$ 

Identity Root, word n

| A R IR          |                     | Identity Root, word n                                              |
|-----------------|---------------------|--------------------------------------------------------------------|
| ID R/W Field    |                     |                                                                    |
| Reset 0xFFFFFFF | 1 1 1 1 1 1 1       | . 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                            |
| ID              | A A A A A A         | . A A A A A A A A A A A A A A A A A A A                            |
| Bit number      | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 6.4.1.1.13 DEVICEADDRTYPE

Address offset: 0x2A0

Device address type

| Bit n | umber   |                |        | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |        |                         | А                                                               |
| Rese  | t OxFFF | FFFFF          |        | 1 1 1 1 1 1 1 1         | . 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |         |                |        |                         | Description                                                     |
| Α     | R       | DEVICEADDRTYPE |        |                         | Device address type                                             |
|       |         |                | Public | 0                       | Public address                                                  |
|       |         |                | Random | 1                       | Random address                                                  |

## 6.4.1.1.14 DEVICEADDR[n] (n=0..1)

Address offset:  $0x2A4 + (n \times 0x4)$ 

Device address n

| Bit n | umber   |            | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------------------------------------------------------------------------------------|
| ID    |         |            | A A A A A A A A A A A A A A A A A A A                                                 |
| Rese  | t OxFFF | FFFFF      | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                               |
|       |         |            |                                                                                       |
| Α     | R       | DEVICEADDR | 48 bit device address                                                                 |
|       |         |            | DEVICEADDR[0] contains the least significant bits of                                  |
|       |         |            | the device address. DEVICEADDR[1] contains the most                                   |
|       |         |            | significant bits of the device address. Only bits [15:0] of                           |
|       |         |            | DEVICEADDR[1] are used.                                                               |



## 6.4.1.1.15 TRIMCNF[n].ADDR (n=0..31)

Address offset:  $0x300 + (n \times 0x8)$ 

**Address** 

| Δ     | R        | Address |                      | Address                                                         |
|-------|----------|---------|----------------------|-----------------------------------------------------------------|
| ID    |          |         |                      |                                                                 |
| Rese  | t OxFFFI | FFFF    | 1 1 1 1 1 1 1        |                                                                 |
| ID    |          |         | A A A A A A A        | A A A A A A A A A A A A A A A A A A A                           |
| Bit n | umber    |         | 31 30 29 28 27 26 25 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 6.4.1.1.16 TRIMCNF[n].DATA (n=0..31)

Address offset:  $0x304 + (n \times 0x8)$ 

Data

| Bit n | umber   |       | 31 | 30 2 | 9 28 | 8 27 | 26 | 25 | 24 | 23 : | 22 2 | 21 2 | 0 1 | 9 18       | 3 17 | 16 | 15 1 | 4 13 | 12 | 11 | 10 | 9 8 | 3 7 | 6 | 5 | 4 | 3 | 2  | 1 0 |
|-------|---------|-------|----|------|------|------|----|----|----|------|------|------|-----|------------|------|----|------|------|----|----|----|-----|-----|---|---|---|---|----|-----|
| ID    |         |       | Α  | Α /  | 4 Δ  | A    | Α  | Α  | Α  | Α    | Α    | A    | 4 Α | A          | Α    | Α  | Α /  | 4 A  | Α  | Α  | Α  | A A | A A | Α | Α | Α | Α | Α. | А А |
| Rese  | t OxFFF | FFFFF | 1  | 1    | 1 1  | 1    | 1  | 1  | 1  | 1    | 1    | 1    | 1 1 | l <b>1</b> | 1    | 1  | 1 :  | l 1  | 1  | 1  | 1  | 1 : | l 1 | 1 | 1 | 1 | 1 | 1  | 1 1 |
| ID    |         |       |    |      |      |      |    |    |    | Des  |      |      |     |            |      |    |      |      |    |    |    |     |     |   |   |   |   |    |     |
| Α     | R       | Data  |    |      |      |      |    |    |    | Dat  | a    |      |     |            |      |    |      |      |    |    |    |     |     |   |   |   |   |    |     |

## 6.4.2 UICR — User information configuration registers

The user information configuration registers (UICRs) are non-volatile memory (NVM) registers for configuring user specific settings.

For information on writing registers, see NVMC — Non-volatile memory controller on page 334 and Memory on page 139.

## 6.4.2.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description      | Configuration |
|---------------------|------------|----------|----------------|--------------|------------------|---------------|
| 0x01FF8000 NETWORK  | UICR       | UICR     | NS             | NA           | User information |               |
|                     |            |          |                |              | configuration    |               |

Table 47: Instances

| APPROTECT 0x000 Access port protection  ERASEPROTECT 0x004 Erase protection  NRFFW[n] 0x200 Reserved for Nordic firmware design | Register     | Offset | Security | Description                         |
|---------------------------------------------------------------------------------------------------------------------------------|--------------|--------|----------|-------------------------------------|
|                                                                                                                                 | APPROTECT    | 0x000  |          | Access port protection              |
| NRFFW[n] 0x200 Reserved for Nordic firmware design                                                                              | ERASEPROTECT | 0x004  |          | Erase protection                    |
|                                                                                                                                 | NRFFW[n]     | 0x200  |          | Reserved for Nordic firmware design |
| CUSTOMER[n] 0x300 Reserved for customer                                                                                         | CUSTOMER[n]  | 0x300  |          | Reserved for customer               |

Table 48: Register overview

#### **6.4.2.1.1 APPROTECT**

Address offset: 0x000
Access port protection



| Bit n | umber   |       |             | 31  | 30 2 | 29 28 | 3 27 | 26 2 | 25 2 | 4 2: | 3 22  | 21   | 20 1  | 9 18  | 17    | 16   | 15 1 | 4 13  | 3 12 | 11:   | 10 9  | 8    | 7    | 6    | 5   | 4   | 3 2 | 1 | 0 |
|-------|---------|-------|-------------|-----|------|-------|------|------|------|------|-------|------|-------|-------|-------|------|------|-------|------|-------|-------|------|------|------|-----|-----|-----|---|---|
| ID    |         |       |             | Α   | Α.   | A A   | A    | A    | A A  | 4 Δ  | A     | Α    | A A   | A A   | Α     | Α    | Α.   | A A   | Α    | Α     | A A   | A A  | Α    | Α    | Α   | Α , | 4 A | A | Α |
| Rese  | t 0x000 | 00000 |             | 0   | 0    | 0 0   | 0    | 0    | 0 (  | 0    | 0     | 0    | 0 0   | 0     | 0     | 0    | 0    | 0 0   | 0    | 0     | 0 (   | 0    | 0    | 0    | 0   | 0 ( | 0 0 | 0 | 0 |
| ID    |         |       |             |     |      |       |      |      |      |      |       |      |       |       |       |      |      |       |      |       |       |      |      |      |     |     |     |   |   |
| Α     | RW      | PALL  |             |     |      |       |      |      |      | В    | lock  | s de | ebug  | ger   | reac  | l/w  | rite | acc   | ess  | to al | I CF  | U re | gis  | ters | an  | d   |     |   |   |
|       |         |       |             |     |      |       |      |      |      | m    | nem   | ory  | map   | ped   | ado   | dres | sses |       |      |       |       |      |      |      |     |     |     |   |   |
|       |         |       |             |     |      |       |      |      |      | U    | sing  | g an | y val | ue e  | xce   | pt L | Jnp  | rote  | cte  | d wil | l lea | d to | th   | e    |     |     |     |   |   |
|       |         |       |             |     |      |       |      |      |      | р    | rote  | ctio | n be  | ing   | ena   | ble  | d.   |       |      |       |       |      |      |      |     |     |     |   |   |
|       |         |       |             |     |      |       |      |      |      | В    | its v | vith | valu  | e '1' | ' car | ı be | e wr | itter | ı to | '0'.  | Bits  | with | ı va | llue | '0' |     |     |   |   |
|       |         |       |             |     |      |       |      |      |      | Ca   | anno  | ot b | e wr  | itter | ı to  | '1'. |      |       |      |       |       |      |      |      |     |     |     |   |   |
|       |         |       | Unprotected | 0x! | 50F/ | 450F  | Α    |      |      | U    | npr   | ote  | ted   |       |       |      |      |       |      |       |       |      |      |      |     |     |     |   |   |
|       |         |       | Protected   | 0x0 | 0000 | 0000  | 00   |      |      | Р    | rote  | cte  | d     |       |       |      |      |       |      |       |       |      |      |      |     |     |     |   |   |

#### 6.4.2.1.2 ERASEPROTECT

Address offset: 0x004

Erase protection

| Bit n | umber   |       |             | 31  | 30  | 29 : | 28 : | 27 2 | 6 25 | 5 24 | 23  | 22 2  | 21 2 | 20 1  | 9 1        | 8 17 | 16   | 15   | 14  | 13 : | 12 1 | 1 10 | 9    | 8    | 7   | 6        | 5 | 4 3 | 2 | 1 0 |
|-------|---------|-------|-------------|-----|-----|------|------|------|------|------|-----|-------|------|-------|------------|------|------|------|-----|------|------|------|------|------|-----|----------|---|-----|---|-----|
| ID    |         |       |             | Α   | Α   | Α    | Α    | A A  | 4 A  | Α    | Α   | Α,    | A    | A A   | \ <i>A</i> | A A  | Α    | Α    | Α   | Α    | A A  | Δ Δ  | A    | Α    | Α   | Α        | Α | A A | A | A A |
| Rese  | t 0x000 | 00000 |             | 0   | 0   | 0    | 0    | 0 (  | 0    | 0    | 0   | 0     | 0    | 0 (   | ) (        | 0    | 0    | 0    | 0   | 0    | 0 (  | 0    | 0    | 0    | 0   | 0        | 0 | 0 ( | 0 | 0 0 |
| ID    |         |       |             |     |     |      |      |      |      |      |     |       |      |       |            |      |      |      |     |      |      |      |      |      |     |          |   |     |   |     |
| Α     | RW      | PALL  |             |     |     |      |      |      |      |      | Blo | cks   | N۷   | /MC   | ER         | ASE  | ALL  | . an | d C | TRL  | AP I | ERA  | SEA  | LL   |     |          |   |     |   |     |
|       |         |       |             |     |     |      |      |      |      |      | fur | octic | na   | lity. |            |      |      |      |     |      |      |      |      |      |     |          |   |     |   |     |
|       |         |       |             |     |     |      |      |      |      |      | Us  | ing a | any  | / val | ue         | exce | ept  | Unp  | oro | tect | ed v | vill | lead | l to | the | <u>.</u> |   |     |   |     |
|       |         |       |             |     |     |      |      |      |      |      | pro | otec  | tio  | n be  | eing       | ena  | able | ed.  |     |      |      |      |      |      |     |          |   |     |   |     |
|       |         |       | Unprotected | 0xF | FF  | FFF  | FF   |      |      |      | Un  | prot  | tec  | ted   |            |      |      |      |     |      |      |      |      |      |     |          |   |     |   |     |
|       |         |       | Protected   | 0x0 | 000 | 000  | 000  | )    |      |      | Pro | otec  | ted  | ł     |            |      |      |      |     |      |      |      |      |      |     |          |   |     |   |     |

## 6.4.2.1.3 NRFFW[n] (n=0..31)

Address offset:  $0x200 + (n \times 0x4)$ 

Reserved for Nordic firmware design

| ID   |          |       | A A A A A A   | A A A A A A A A A A A A A A A A A A A   |
|------|----------|-------|---------------|-----------------------------------------|
| Rese | t OxFFFI | FFFFF | 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |
| ID   |          |       |               |                                         |
|      |          |       |               | Reserved for Nordic firmware design     |

## 6.4.2.1.4 CUSTOMER[n] (n=0..31)

Address offset:  $0x300 + (n \times 0x4)$ 

Reserved for customer

| Bit n | umber   |          | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------|---------------------------------------------------------------------------------------|
| ID    |         |          | A A A A A A A A A A A A A A A A A A A                                                 |
| Rese  | t OxFFF | FFFFF    | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                               |
| ID    |         |          | Value Description                                                                     |
| Α     | RW      | CUSTOMER | Reserved for customer                                                                 |



#### 6.4.3 AHB multilayer

AHB multilayer enables parallel access paths between multiple masters and slaves in a system. Access is resolved using priorities.

Each bus master is connected to a slave device through one or more interconnection matrixes. The bus masters are assigned priorities that are used to resolve access when two (or more) bus masters request access to the same slave device. The following applies when assigning priorities:

- If two (or more) bus masters request access to the same slave device, the master with the highest priority is granted access first.
- Bus masters with lower priority are stalled until the higher priority master has completed its transaction.
- If the higher priority master pauses at any point during its transaction, the lower priority master in queue is temporarily granted access to the slave device until the higher priority master resumes its activity.
- Bus masters that have the same priority are mutually exclusive, and cannot be used concurrently.

Some peripherals, like RADIO, do not have a safe stalling mechanism (not able to pause incoming data and no internal data buffering). Being a low priority bus master might cause loss of data for such peripherals upon bus contention. To avoid AHB bus contention when using multiple bus masters, apply one of the following guidelines:

- Avoid situations where more than one bus master is accessing the same slave.
- If more than one bus master is accessing the same slave, make sure that the bus bandwidth is not exhausted.

#### 6.4.3.1 AHB multilayer priorities

Each master connected to the AHB multilayer is assigned a default natural priority.

| Bus master name                | Natural relative priority | In/Out | Description                          |
|--------------------------------|---------------------------|--------|--------------------------------------|
| CPU                            | Highest priority          | I/O    |                                      |
| RADIO                          |                           | 1/0    |                                      |
| CCM/ECB/AAR                    |                           | I/O    | Same priority and mutually exclusive |
| UARTEO/SPIMO/SPISO/TWIMO/TWISO | Lowest priority           | 1/0    | Same priority and mutually exclusive |

Table 49: AHB bus masters



# 7 Peripherals

nRF5340 is made up of two cores, each with their own peripherals.

The application core peripherals are found in Instantiation on page 110 and the network core peripherals are found in Instantiation on page 141. The application core peripherals are accessible from the network core, but the network core peripherals are not accessible from the application core. For further details, see Memory on page 19.

Some peripheral instances have differing configurations, such as some TIMER instances which have more capture and compare channels implemented than others. These differences are noted in the Configuration column of the peripheral's instantiation table.

# 7.1 Peripheral interface

Peripherals are controlled by the CPU through configuration registers, as well as task and event registers. Task registers are inputs, enabling the CPU and other peripherals to initiate a functionality. Event registers are outputs, enabling a peripheral to trigger tasks in other peripherals and/or the CPU by tying events to CPU interrupts.





Figure 33: Peripheral interface

The distributed programmable peripheral interconnect (DPPI) feature enables peripherals to connect events to tasks without CPU intervention. For more information on DPPI and the DPPI channels, see DPPI — Distributed programmable peripheral interconnect on page 203.

# 7.1.1 Peripheral ID

Every peripheral is assigned a fixed block of 0x1000 bytes of address space, which is equal to 1024 x 32 bit registers.

See Peripherals on page 150 for more information about which peripherals are available and where they are located in the address map.

There is a direct relationship between peripheral ID and base address. For example, a peripheral with base address 0x40000000 is assigned ID=0, a peripheral with base address 0x40001000 is assigned ID=1, and a peripheral with base address 0x4001F000 is assigned ID=31.

Peripherals may share the same ID, which may impose one or more of the following limitations:

- Shared registers or common resources
- · Limited availability due to mutually exclusive operation; only one peripheral in use at a time
- Enforced peripheral behavior when switching between peripherals (disable the first peripheral before enabling the second)

NORDIC SEMICONDUCTOR

## 7.1.2 Peripherals with shared ID

In general (with the exception of ID 0), peripherals sharing an ID and base address may not be used simultaneously. Only one peripheral can be enabled at a given ID.

When switching between two peripherals sharing an ID, the following should be performed to prevent unwanted behavior:

- **1.** Disable the previously used peripheral.
- 2. Disable any publish/subscribe connection to the DPPI system for the peripheral that is being disabled.
- **3.** Clear all bits in the INTEN register, i.e. INTENCLR = 0xFFFFFFFF.
- **4.** Explicitly configure the peripheral being enabled. Do not rely on inherited configuration from the disabled peripheral.
- **5.** Enable the now configured peripheral.

For a list of which peripherals that share an ID see Peripherals on page 150.

## 7.1.3 Peripheral registers

Most peripherals feature an ENABLE register. Unless otherwise specified, the peripheral registers must be configured before enabling the peripheral.

PSEL registers need to be set before a peripheral is enabled or started. Updating PSEL registers while the peripheral is running has no effect. To connect a peripheral to a different GPIO, the following must be performed:

- 1. Disable the peripheral.
- 2. Update the PSEL register.
- **3.** Re-enable the peripheral.

It takes four CPU cycles between the PSEL register update and the connection between a peripheral and a GPIO becoming effective.

**Note:** The peripheral must be enabled before tasks and events can be used.

Most of the register values are lost during System OFF or when a reset is triggered. Some registers will retain their values in System OFF or for some specific reset sources. These registers are marked as retained in the register description for a given peripheral. For more information on their behavior, see chapter RESET — Reset control on page 65.

#### 7.1.4 Bit set and clear

Registers with multiple single-bit bit fields may implement the set-and-clear pattern. This pattern enables firmware to set and clear individual bits in a register without having to perform a read-modify-write operation on the main register.

This pattern is implemented using three consecutive addresses in the register map, where the main register is followed by dedicated SET and CLR registers (in that exact order).

In the main register, the SET register sets individual bits and the CLR register clears them. Writing 1 to a bit in the SET or CLR register will set or clear the same bit in the main register respectively. Writing 0 to a bit in the SET or CLR register has no effect. Reading the SET or CLR register returns the value of the main register.

**Note:** The main register may not be visible and therefore not directly accessible in all cases.



#### 7.1.5 Tasks

Tasks are used to trigger actions in a peripheral, such as to start a particular behavior. A peripheral can implement multiple tasks with each task having a separate register in that peripheral's task register group.

A task is triggered when firmware writes 1 to the task register, or when the peripheral itself or another peripheral toggles the corresponding task signal. See the figure Peripheral interface on page 151.

#### 7.1.6 Events

Events are used to notify peripherals and the CPU about events that have happened, for example a state change in a peripheral. A peripheral may generate multiple events, where each event has a separate register in that peripheral's event register group.

An event is generated when the peripheral itself toggles the corresponding event signal, and the event register is updated to reflect that the event has been generated, see figure Peripheral interface on page 151. An event register is cleared when a 0 is written to it by firmware. Events can be generated by the peripheral even when the event register is set to 1.

#### 7.1.7 Publish and subscribe

Events and tasks from different peripherals can be connected together through the DPPI system using the PUBLISH and SUBSCRIBE registers in each peripheral. See Peripheral interface on page 151. An event can be published onto a DPPI channel by configuring the event's PUBLISH register. Similarly, a task can subscribe to a DPPI channel by configuring the task's SUBSCRIBE register.

See DPPI — Distributed programmable peripheral interconnect on page 203 for details.

#### 7.1.8 Shortcuts

A shortcut is a direct connection between an event and a task within the same peripheral. If a shortcut is enabled, the associated task is automatically triggered when its associated event is generated.

Using shortcuts is equivalent to making the connection outside the peripheral and through the DPPI. However, the propagation delay when using shortcuts is usually shorter than the propagation delay through the DPPI.

Shortcuts are predefined, which means that their connections cannot be configured by firmware. Each shortcut can be individually enabled or disabled through the shortcut register, one bit per shortcut, giving a maximum of 32 shortcuts for each peripheral.

## 7.1.9 Interrupts

All peripherals support interrupts which are generated by events.

A peripheral only occupies one interrupt, and the interrupt number follows the peripheral ID. For example, the peripheral with ID=4 is connected to interrupt number 4 in the nested vectored interrupt controller (NVIC).

Using registers INTEN, INTENSET, and INTENCLR, every event generated by a peripheral can be configured to generate that peripheral's interrupt. Multiple events can be enabled to generate interrupts simultaneously. To resolve the correct interrupt source, the event registers in the event group of peripheral registers will indicate the source.

Some peripherals implement only INTENSET and INTENCLR registers, and the INTEN register is not available on those peripherals. See the individual peripheral chapters for details. In all cases, reading back the INTENSET or INTENCLR register returns the same information as in INTEN.

Each event implemented in the peripheral is associated with a specific bit position in the INTEN, INTENSET, and INTENCLR registers.



The relationship between tasks, events, shortcuts, and interrupts is illustrated in figure Peripheral interface on page 151.

#### 7.1.9.1 Interrupt clearing and disabling

Interrupts should always be cleared by writing 0 to the corresponding EVENT register.

Until cleared, interrupts will immediately be re-triggered and cause software interrupt service routines to be executed repeatedly.

Because the clearing of the EVENT register may take a number of CPU clock cycles, the program should perform a read from the EVENT register that has been cleared before exiting the interrupt service routine. This will ensure that the EVENT clearing has taken place before the interrupt service routine is exited. Care should be taken to ensure that the compiler does not remove the read operation as an optimization.

Similarly, when disabling an interrupt inside an interrupt service routine, the program should perform a read from the INTEN or INTENCLR registers to ensure that the interrupt is disabled before exiting the interrupt service routine.

## 7.1.10 Secure/non-secure peripherals

For some peripherals, the security configuration can change from secure to non-secure, or vice versa. Care must be taken when changing the security configuration of a peripheral, to prevent security information leakage and ensure correct operation.

The following sequence should be followed, where applicable, when configuring and changing the security settings of a peripheral in the SPU — System protection unit on page 590.

- 1. Stop peripheral operation.
- 2. Disable the peripheral.
- 3. Remove pin connections.
- 4. Disable DPPI connections.
- 5. Clear sensitive registers (e.g. writing back default values).
- **6.** Change peripheral security setting in the SPU System protection unit on page 590.
- 7. Re-enable the peripheral.

# 7.2 EasyDMA

EasyDMA is a module implemented by some peripherals to gain direct access to Data RAM.

EasyDMA is an AHB bus master similar to CPU and is connected to the AHB multilayer interconnect for direct access to Data RAM. EasyDMA cannot access flash memory.

A peripheral can implement multiple EasyDMA instances to provide dedicated channels. For example, for reading and writing of data between the peripheral and RAM. This concept is illustrated in the following figure.





Figure 34: EasyDMA example

An EasyDMA channel is implemented in the following way, but some variations may occur:

```
READERBUFFER_SIZE 5
WRITERBUFFER_SIZE 6

uint8_t readerBuffer[READERBUFFER_SIZE] __at__ 0x20000000;
uint8_t writerBuffer[WRITERBUFFER_SIZE] __at__ 0x20000005;

// Configuring the READER channel
MYPERIPHERAL->READER.MAXCNT = READERBUFFER_SIZE;
MYPERIPHERAL->READER.PTR = &readerBuffer;

// Configure the WRITER channel
MYPERIPHERAL->WRITER.MAXCNT = WRITEERBUFFER_SIZE;
MYPERIPHERAL->WRITER.PTR = &writerBuffer;
```

This example shows a peripheral called MYPERIPHERAL that implements two EasyDMA channels - one for reading called READER, and one for writing called WRITER. When the peripheral is started, it is assumed that the peripheral will perform the following tasks:

- 1. Read 5 bytes from the readerBuffer located in RAM at address 0x20000000.
- 2. Process the data.
- 3. Write no more than 6 bytes back to the writerBuffer located in RAM at address 0x20000005.

The memory layout of these buffers is illustrated in EasyDMA memory layout on page 155.

| 0x20000000 | readerBuffer[0] | readerBuffer[1] | readerBuffer[2] | readerBuffer[3] |
|------------|-----------------|-----------------|-----------------|-----------------|
| 0x20000004 | readerBuffer[4] | writerBuffer[0] | writerBuffer[1] | writerBuffer[2] |
| 0x20000008 | writerBuffer[3] | writerBuffer[4] | writerBuffer[5] |                 |

Figure 35: EasyDMA memory layout

The WRITER.MAXCNT register should not be specified larger than the actual size of the buffer (writerBuffer). Otherwise, the channel would overflow the writerBuffer.

Once an EasyDMA transfer is completed, the AMOUNT register can be read by the CPU to see how many bytes were transferred. For example, CPU can read MYPERIPHERAL->WRITER.AMOUNT register to see how many bytes WRITER wrote to RAM.



**Note:** The PTR register of a READER or WRITER must point to a valid memory region before use. The reset value of a PTR register is not guaranteed to point to valid memory. See Memory on page 19 for more information about the different memory regions and EasyDMA connectivity.

## 7.2.1 EasyDMA error handling

Some errors may occur during DMA handling.

If READER.PTR or WRITER.PTR is not pointing to a valid memory region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

If several AHB bus masters try to access the same AHB slave at the same time, AHB bus congestion might occur. An EasyDMA channel is an AHB master. Depending on the peripheral, the peripheral may either stall and wait for access to be granted, or lose data.

## 7.2.2 EasyDMA array list

EasyDMA is able to operate in Array List mode.

The Array List mode is implemented in channels where the LIST register is available.

The array list does not provide a mechanism to explicitly specify where the next item in the list is located. Instead, it assumes that the list is organized as a linear array where items are located one after the other in RAM.

The EasyDMA Array List can be implemented by using the data structure ArrayList\_type as illustrated in the code example below using a READER EasyDMA channel as an example:

```
#define BUFFER_SIZE 4

typedef struct ArrayList
{
   uint8_t buffer[BUFFER_SIZE];
} ArrayList_type;

ArrayList_type ReaderList[3] __at__ 0x20000000;

MYPERIPHERAL->READER.MAXCNT = BUFFER_SIZE;
MYPERIPHERAL->READER.PTR = &ReaderList;
MYPERIPHERAL->READER.LIST = MYPERIPHERAL_READER_LIST_ArrayList;
```

The data structure only includes a buffer with size equal to the size of READER.MAXCNT register. EasyDMA uses the READER.MAXCNT register to determine when the buffer is full.

READER.PTR = &ReaderList

 0x20000000 : ReaderList[0]
 buffer[0]
 buffer[1]
 buffer[2]
 buffer[3]

 0x200000004 : ReaderList[1]
 buffer[0]
 buffer[1]
 buffer[2]
 buffer[3]

 0x200000008 : ReaderList[2]
 buffer[0]
 buffer[1]
 buffer[2]
 buffer[3]

Figure 36: EasyDMA array list



## 7.3 ACL — Access control lists

The Access control lists (ACL) peripheral is designed to assign and enforce access permissions to different regions of the on-chip flash memory map.

Flash memory regions can be assigned individual ACL permission schemes. The following registers are involved:

- PERM register, where the permissions are configured.
- ADDR register, where the word-aligned start address for the flash page is defined.
- SIZE register, where the size of the region the permissions are applied to is determined.

**Note:** The size of the region in bytes is restricted to a multiple of the flash page size, and the maximum region size is limited to the flash size. See Memory on page 19 for more information.



Figure 37: Protected regions of on-chip flash memory

There are four defined ACL permission schemes, each with different combinations of read/write permissions, as shown in the following table.



| Read | Write | Protection description                                                  |
|------|-------|-------------------------------------------------------------------------|
| 0    | 0     | No protection. Entire region can be executed, read, written, or erased. |
| 0    | 1     | Region can be executed and read, but not written or erased.             |
| 1    | 0     | Region can be written and erased, but not executed or read.             |
| 1    | 1     | Region is locked for all access until next reset.                       |

Table 50: Permission schemes

**Note:** If a permission violation to a protected region is detected by the ACL peripheral, the request is blocked and a Bus Fault exception is triggered.

Access control to a configured region is enforced by the hardware two CPU clock cycles after the ADDR, SIZE, and PERM registers for an ACL instance have been successfully written. The protection is only enforced if a valid start address of the flash page boundary is written into the ADDR register, and the values of the SIZE and PERM registers are not zero.

The ADDR, SIZE, and PERM registers can only be written once. All ACL configuration registers are cleared on reset (by resetting the device from any reset source), which is also the only way of clearing the configuration registers. To ensure that the desired permission schemes are always enforced by the ACL peripheral, the device boot sequence must perform the necessary configuration.

Debugger read access to a read-protected region will be Read-As-Zero (RAZ), while debugger write access to a write-protected region will be Write-Ignored (WI).

## 7.3.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description          | Configuration             |
|---------------------|------------|----------|----------------|--------------|----------------------|---------------------------|
| 0x41080000 NETWORK  | ACL        | ACL      | NS             | NA           | Access control lists | This ACL can only protect |
|                     |            |          |                |              |                      | network core's local      |
|                     |            |          |                |              |                      | memory.                   |

Table 51: Instances

| Register       | Offset | Security | Description                                                                                  |        |
|----------------|--------|----------|----------------------------------------------------------------------------------------------|--------|
| ACL[n].ADDR    | 0x800  |          | Start address of region to protect. The start address must be word-aligned.                  |        |
| ACL[n].SIZE    | 0x804  |          | Size of region to protect counting from address ACL[n].ADDR. Writing a '0' has no effect.    |        |
| ACL[n].PERM    | 0x808  |          | Access permissions for region n as defined by start address ACL[n].ADDR and size ACL[n].SIZE |        |
| ACL[n].UNUSED0 | 0x80C  |          |                                                                                              | Reserv |

Table 52: Register overview

## 7.3.1.1 ACL[n].ADDR (n=0..7)

Address offset:  $0x800 + (n \times 0x10)$ 

Start address of region to protect. The start address must be word-aligned.

Note: This register can only be written once.





#### 7.3.1.2 ACL[n].SIZE (n=0..7)

Address offset:  $0x804 + (n \times 0x10)$ 

Size of region to protect counting from address ACL[n].ADDR. Writing a '0' has no effect.

**Note:** This register can only be written once.



#### 7.3.1.3 ACL[n].PERM (n=0..7)

Address offset:  $0x808 + (n \times 0x10)$ 

Access permissions for region n as defined by start address ACL[n].ADDR and size ACL[n].SIZE

Note: This register can only be written once.



# 7.4 AAR — Accelerated address resolver

Accelerated address resolver is a cryptographic support function for implementing the Resolvable Private Address Resolution procedure described in *Bluetooth Core Specification*. Resolvable Private Address generation should be achieved using ECB and is not supported by AAR.

The procedure allows two devices that share a secret key to generate and resolve a hash based on their device address. The AAR block enables real-time address resolution on incoming packets when configured as described in this chapter. This allows real-time packet filtering (whitelisting) using a list of known shared keys (Identity Resolving Keys (IRK) in Bluetooth.



#### 7.4.1 Shared resources

AAR shares the same AES module as the ECB and CCM peripherals. ECB will always have the lowest priority. If there is a sharing conflict during encryption, the ECB operation will be aborted and an ERRORECB event will be generated in the ECB peripheral.

Additionally, AAR shares registers and other resources with the peripherals that have the same ID as AAR. See Peripherals with shared ID on page 152 for more information.

#### 7.4.2 EasyDMA

AAR implements EasyDMA for reading and writing to RAM. EasyDMA will have finished accessing RAM when the END, RESOLVED, and NOTRESOLVED events are generated.

If the IRKPTR on page 166, ADDRPTR on page 166, and the SCRATCHPTR on page 166 is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

## 7.4.3 Resolving a resolvable address

A private resolvable address is composed of six bytes according to the Bluetooth Core Specification.



Figure 38: Resolvable address

To resolve an address, the register ADDRPTR on page 166 must point to the start of the packet. The resolver is started by triggering the START task. A RESOLVED event is generated when AAR manages to resolve the address using one of the Identity Resolving Keys (IRK) found in the IRK data structure. AAR will use the IRK specified in the register IRKO to IRK15 starting from IRKO. The register NIRK on page 166 specifies how many IRKs should be used. The AAR module will generate a NOTRESOLVED event if it is not able to resolve the address using the specified list of IRKs.

AAR will go through the list of available IRKs in the IRK data structure and for each IRK try to resolve the address according to the Resolvable Private Address Resolution Procedure described in the *Bluetooth Core specification*. The time it takes to resolve an address varies due to the location in the list of the resolvable address. The resolution time will also be affected by RAM accesses performed by other peripherals and the CPU. See the Electrical specifications for more information about resolution time.

AAR only compares the received address to those programmed in the module without checking the address type.

AAR will stop as soon as it has managed to resolve the address, or after trying to resolve the address using NIRK number of IRKs from the IRK data structure. AAR will generate an END event after it has stopped.



Figure 39: Address resolution with packet preloaded into RAM



# 7.4.4 Example

The following example shows how to chain RADIO packet reception with address resolution using AAR.

AAR may be started as soon as the 6 bytes required by AAR have been received by RADIO and stored in RAM. The ADDRPTR pointer must point to the start of packet.



Figure 40: Address resolution with packet loaded into RAM by RADIO

#### 7.4.5 IRK data structure

The IRK data structure is located in RAM at the memory location specified by the IRKPTR register.

| Property | Address offset | Description              |
|----------|----------------|--------------------------|
| IRKO     | 0              | IRK number 0 (16 bytes)  |
| IRK1     | 16             | IRK number 1 (16 bytes)  |
|          |                |                          |
| IRK15    | 240            | IRK number 15 (16 bytes) |

Table 53: IRK data structure overview

# 7.4.6 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description         | Configuration |
|---------------------|------------|----------|----------------|--------------|---------------------|---------------|
| 0x4100E000 NETWORK  | AAR        | AAR      | NS             | NA           | Accelerated address |               |
|                     |            |          |                |              | resolver            |               |

Table 54: Instances

| Register            | Offset | Security | Description                                                                 |
|---------------------|--------|----------|-----------------------------------------------------------------------------|
| TASKS_START         | 0x000  |          | Start resolving addresses based on IRKs specified in the IRK data structure |
| TASKS_STOP          | 0x008  |          | Stop resolving addresses                                                    |
| SUBSCRIBE_START     | 0x080  |          | Subscribe configuration for task START                                      |
| SUBSCRIBE_STOP      | 0x088  |          | Subscribe configuration for task STOP                                       |
| EVENTS_END          | 0x100  |          | Address resolution procedure complete                                       |
| EVENTS_RESOLVED     | 0x104  |          | Address resolved                                                            |
| EVENTS_NOTRESOLVED  | 0x108  |          | Address not resolved                                                        |
| PUBLISH_END         | 0x180  |          | Publish configuration for event END                                         |
| PUBLISH_RESOLVED    | 0x184  |          | Publish configuration for event RESOLVED                                    |
| PUBLISH_NOTRESOLVED | 0x188  |          | Publish configuration for event NOTRESOLVED                                 |
| INTENSET            | 0x304  |          | Enable interrupt                                                            |
| INTENCLR            | 0x308  |          | Disable interrupt                                                           |
| STATUS              | 0x400  |          | Resolution status                                                           |



| Register   | Offset | Security | Description                                     |
|------------|--------|----------|-------------------------------------------------|
| ENABLE     | 0x500  |          | Enable AAR                                      |
| NIRK       | 0x504  |          | Number of IRKs                                  |
| IRKPTR     | 0x508  |          | Pointer to IRK data structure                   |
| ADDRPTR    | 0x510  |          | Pointer to the resolvable address               |
| SCRATCHPTR | 0x514  |          | Pointer to data area used for temporary storage |

*Table 55: Register overview* 

## 7.4.6.1 TASKS\_START

Address offset: 0x000

Start resolving addresses based on IRKs specified in the IRK data structure

| Bit n | umber   |             |         | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------|---------|------------------|-----------------------------------------------------------------------|
| ID    |         |             |         |                  | A                                                                     |
| Rese  | t 0x000 | 00000       |         | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |         |             |         |                  | Description                                                           |
| Α     | W       | TASKS_START |         |                  | Start resolving addresses based on IRKs specified in the IRK          |
|       |         |             |         |                  | data structure                                                        |
|       |         |             | Trigger | 1                | Trigger task                                                          |

## 7.4.6.2 TASKS\_STOP

Address offset: 0x008
Stop resolving addresses

| Bit n | umber   |            |         | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------|---------------------|---------------------------------------------------------------------|
| ID    |         |            |         |                     | A                                                                   |
| Rese  | t 0x000 | 00000      |         | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |            |         |                     | Description                                                         |
| Α     | W       | TASKS_STOP |         |                     | Stop resolving addresses                                            |
|       |         |            | Trigger | 1                   | Trigger task                                                        |

## 7.4.6.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ( |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | АААААА                                                        |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task START will subscribe to                |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable subscription                                          |
|       |         |       | Enabled  | 1                       | Enable subscription                                           |

## 7.4.6.4 SUBSCRIBE\_STOP

Address offset: 0x088

Subscribe configuration for task STOP





## **7.4.6.5 EVENTS\_END**

Address offset: 0x100

Address resolution procedure complete

| Bit n | umber   |            |              | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|--------------|------------------|-----------------------------------------------------------------------|
| ID    |         |            |              |                  | A                                                                     |
| Rese  | t 0x000 | 00000      |              | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |         |            |              |                  |                                                                       |
| Α     | RW      | EVENTS_END |              |                  | Address resolution procedure complete                                 |
|       |         |            | NotGenerated | 0                | Event not generated                                                   |
|       |         |            | Generated    | 1                | Event generated                                                       |

## 7.4.6.6 EVENTS\_RESOLVED

Address offset: 0x104

Address resolved



#### 7.4.6.7 EVENTS NOTRESOLVED

Address offset: 0x108 Address not resolved



#### 7.4.6.8 PUBLISH\_END

Address offset: 0x180

Publish configuration for event END





## 7.4.6.9 PUBLISH\_RESOLVED

Address offset: 0x184

Publish configuration for event RESOLVED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event RESOLVED will publish to.               |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

## 7.4.6.10 PUBLISH\_NOTRESOLVED

Address offset: 0x188

Publish configuration for event NOTRESOLVED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         | Description                                                   |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event NOTRESOLVED will publish to.          |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 1                       | Enable publishing                                             |

#### 7.4.6.11 INTENSET

Address offset: 0x304

Enable interrupt







| Bit number            | 31 30 29 28 27 20 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|-------------------|-----------------------------------------------------------------------|
| ID                    |                   | СВА                                                                   |
| Reset 0x00000000      | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID R/W Field Value ID |                   | Description                                                           |
| Disabled              | 0                 | Read: Disabled                                                        |
| Enabled               | 1                 | Read: Enabled                                                         |
| C RW NOTRESOLVED      |                   | Write '1' to enable interrupt for event NOTRESOLVED                   |
| Set                   | 1                 | Enable                                                                |
| Disabled              | 0                 | Read: Disabled                                                        |
| Enabled               | 1                 | Read: Enabled                                                         |

## 7.4.6.12 INTENCLR

Address offset: 0x308

Disable interrupt

| Reset   0x0000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit r | umber    |             |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|-------------|----------|-------------------------|-----------------------------------------------------------------|
| ID R/W Field Value ID Value Description  A RW END                                                                                                                                                                                                                                                                                                                                                                                                                                  | ID    |          |             |          |                         | СВА                                                             |
| A RW END  Clear 1 Disable  Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  B RW RESOLVED  Clear 1 Disable  Clear 1 Disable  Write '1' to disable interrupt for event RESOLVED  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disable  Enabled 1 Read: Enabled  C RW NOTRESOLVED  Clear 1 Disable  Enabled 1 Read: Enabled  C RW NOTRESOLVED  Clear 1 Disable  Disable nterrupt for event NOTRESOLVED  Clear 1 Disable  Clear 1 Disable | Rese  | et 0x000 | 00000       |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  B RW RESOLVED Clear 1 Disable Disabled 0 Read: Disable Clear 1 Disable Enabled 1 Read: Enabled  Clear 1 Disable Write '1' to disable interrupt for event RESOLVED  Read: Disabled  Enabled 1 Read: Enabled  C RW NOTRESOLVED Clear 1 Disable Disabled 0 Read: Disable interrupt for event NOTRESOLVED  Clear 1 Disable Disabled 0 Read: Disabled                                                                | ID    |          |             |          |                         |                                                                 |
| Disabled 0 Read: Disabled Enabled 1 Read: Enabled  B RW RESOLVED Write '1' to disable interrupt for event RESOLVED  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  C RW NOTRESOLVED  Clear 1 Disable Enabled 1 Read: Enabled  Clear 1 Disable O Read: Disable interrupt for event NOTRESOLVED  Read: Disable interrupt for event NOTRESOLVED  Read: Disabled  O Read: Disabled                                                                                 | Α     | RW       | END         |          |                         | Write '1' to disable interrupt for event END                    |
| B RW RESOLVED Write '1' to disable interrupt for event RESOLVED  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  C RW NOTRESOLVED  Clear 1 Disabled Disabled 1 Read: Enabled  C RW NOTRESOLVED  Clear 1 Disable Disabled 0 Read: Disable                                                                                                                                                                                                                        |       |          |             | Clear    | 1                       | Disable                                                         |
| B RW RESOLVED  Clear Disable Disable Disabled Enabled  Clear Disabled Enabled  Clear Disabled Disabled Disabled Disabled Disabled Disabled Disabled  Read: Enabled  Write '1' to disable interrupt for event NOTRESOLVED  Write '1' to disable interrupt for event NOTRESOLVED  Clear Disabled Disabled  Read: Disabled                                                                                                                                                            |       |          |             | Disabled | 0                       | Read: Disabled                                                  |
| Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  C RW NOTRESOLVED Clear 1 Disable Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                      |       |          |             | Enabled  | 1                       | Read: Enabled                                                   |
| Disabled 0 Read: Disabled Enabled 1 Read: Enabled  C RW NOTRESOLVED Write '1' to disable interrupt for event NOTRESOLVED  Clear 1 Disable Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                | В     | RW       | RESOLVED    |          |                         | Write '1' to disable interrupt for event RESOLVED               |
| Enabled 1 Read: Enabled  C RW NOTRESOLVED Write '1' to disable interrupt for event NOTRESOLVED  Clear 1 Disable  Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                         |       |          |             | Clear    | 1                       | Disable                                                         |
| C RW NOTRESOLVED  Clear 1 Disable  Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                       |       |          |             | Disabled | 0                       | Read: Disabled                                                  |
| Clear 1 Disable Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |          |             | Enabled  | 1                       | Read: Enabled                                                   |
| Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                          | С     | RW       | NOTRESOLVED |          |                         | Write '1' to disable interrupt for event NOTRESOLVED            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |          |             | Clear    | 1                       | Disable                                                         |
| Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |          |             | Disabled | 0                       | Read: Disabled                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |          |             | Enabled  | 1                       | Read: Enabled                                                   |

## 7.4.6.13 STATUS

Address offset: 0x400

**Resolution status** 

| A F     | R     | STATUS | [01 | 15]  |        |       |      | Т    | he I | RK t | that | was   | use | d las | t tir | ne a | n ac | ldres | s w | as re | sol | /ed |   |   |            |     |
|---------|-------|--------|-----|------|--------|-------|------|------|------|------|------|-------|-----|-------|-------|------|------|-------|-----|-------|-----|-----|---|---|------------|-----|
| ID F    |       |        |     |      |        |       |      |      |      |      |      |       |     |       |       |      |      |       |     |       |     |     |   |   |            |     |
| Reset 0 | 0x000 | 00000  | 0 0 | ) 0  | 0      | 0 0   | 0    | 0 (  | 0    | 0    | 0    | 0 0   | 0   | 0     | 0 0   | 0    | 0    | 0 0   | 0   | 0 (   | 0   | 0   | 0 | 0 | 0          | 0   |
| ID      |       |        |     |      |        |       |      |      |      |      |      |       |     |       |       |      |      |       |     |       |     |     |   | A | <b>А</b> А | . A |
| Bit nun | nber  |        | 313 | 0 29 | 9 28 2 | 27 26 | 25 2 | 24 2 | 3 22 | 2 21 | 20 1 | 19 18 | 17  | 16 1  | .5 14 | 13   | 12 1 | .1 10 | 9   | 8 7   | ' 6 | 5   | 4 | 3 | 2 1        | 0   |

## 7.4.6.14 ENABLE

Address offset: 0x500

**Enable AAR** 





#### 7.4.6.15 NIRK

Address offset: 0x504

Number of IRKs

|       |          |       |     |      |      |      |      |     | stı  | ruct | ure  |       |      |      |      |      |       |       |       |     |     |     |     |   |   |    |     |
|-------|----------|-------|-----|------|------|------|------|-----|------|------|------|-------|------|------|------|------|-------|-------|-------|-----|-----|-----|-----|---|---|----|-----|
| Α     | RW       | NIRK  | [11 | 6]   |      |      |      |     | Νι   | umb  | er c | of Id | enti | ty R | oot  | Key  | s ava | ailab | le ir | the | IRK | da  | ta  |   |   |    |     |
| ID    |          |       |     |      |      |      |      |     |      |      |      |       |      |      |      |      |       |       |       |     |     |     |     |   |   |    |     |
| Rese  | et 0x000 | 00001 | 0 ( | ) 0  | 0    | 0    | 0 (  | 0 0 | 0    | 0    | 0    | 0 (   | 0    | 0    | 0 (  | 0    | 0     | 0     | 0     | 0   | 0 ( | 0 ( | 0   | 0 | 0 | 0  | 0 1 |
| ID    |          |       |     |      |      |      |      |     |      |      |      |       |      |      |      |      |       |       |       |     |     |     |     | Α | Α | Α. | 4 A |
| Bit r | umber    |       | 313 | 0 29 | 9 28 | 3 27 | 26 2 | 5 2 | 4 23 | 3 22 | 21 2 | 20 1  | 9 18 | 17   | 16 1 | 5 14 | 13    | 12 1  | 1 10  | 9   | 8   | 7 6 | 5 5 | 4 | 3 | 2  | 1 0 |

#### 7.4.6.16 IRKPTR

Address offset: 0x508

Pointer to IRK data structure



#### 7.4.6.17 ADDRPTR

Address offset: 0x510

Pointer to the resolvable address

| Bit n | umber   |         | 31 | 30 | 29 | 28 2 | 27 2 | 26 2 | 25 2 | 4 2 | 3 22 | 2 2 1 | 20   | 19   | 18 1 | 7 1 | 5 15 | 14  | 13  | 12 1 | 111  | 0 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2   | 1 0        |
|-------|---------|---------|----|----|----|------|------|------|------|-----|------|-------|------|------|------|-----|------|-----|-----|------|------|-----|-----|---|---|---|---|---|-----|------------|
| ID    |         |         | Α  | Α  | Α  | Α    | Α.   | Α.   | A ,  | ١.  | 4 А  | A     | Α    | Α    | A A  | . Δ | Α    | Α   | Α   | A    | A A  | Δ Δ | ι A | Α | Α | Α | Α | Α | Α / | <b>А</b> А |
| Rese  | t 0x000 | 00000   | 0  | 0  | 0  | 0    | 0    | 0    | 0 (  | )   | 0 0  | 0     | 0    | 0    | 0 0  | 0   | 0    | 0   | 0   | 0    | 0 (  | 0   | 0   | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0        |
| ID    |         |         |    |    |    |      |      |      |      |     |      |       |      |      |      |     |      |     |     |      |      |     |     |   |   |   |   |   |     |            |
| Α     | RW      | ADDRPTR |    |    |    |      |      |      |      | F   | oin  | er    | to t | he r | esol | vab | le a | ddr | ess | (6-  | byte | es) |     |   |   |   |   |   |     |            |

#### **7.4.6.18 SCRATCHPTR**

Address offset: 0x514

Pointer to data area used for temporary storage



| Bit n | umber   |            | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------------------------------------------------------------------------------------|
| ID    |         |            | A A A A A A A A A A A A A A A A A A A                                                 |
| Rese  | t 0x000 | 00000      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| ID    |         |            | Value Description                                                                     |
| Α     | RW      | SCRATCHPTR | Pointer to a scratch data area used for temporary storage                             |
|       |         |            | during resolution. A space of minimum 3 bytes must be                                 |

reserved.

## 7.4.7 Electrical specification

## 7.4.7.1 AAR Electrical Specification

| Symbol             | Description                                                   | Min. | Тур. | Max. | Units |
|--------------------|---------------------------------------------------------------|------|------|------|-------|
| t <sub>AAR</sub>   | Address resolution time per IRK. Total time for several IRKs  |      |      | 6.1  | μs    |
|                    | is given as (1 $\mu s$ + n * t_AAR), where n is the number of |      |      |      |       |
|                    | IRKs. (Given priority to the actual destination RAM block).   |      |      |      |       |
| t <sub>AAR,8</sub> | Time for address resolution of 8 IRKs. (Given priority to the |      |      | 49   | μs    |
|                    | actual destination RAM block).                                |      |      |      |       |

# 7.5 CCM — AES CCM mode encryption

Counter with cipher block chaining - message authentication code (CCM) mode is an authenticated encryption algorithm designed to provide both authentication and confidentiality during data transfer.

AES CCM combines counter (CTR) mode encryption and cipher block chaining - message authentication code (CBC-MAC) authentication. The CCM terminology message authentication code (MAC) is called message integrity check (MIC) in *Bluetooth* terminology, and also in this document.

The CCM block generates an encrypted keystream that is applied to input data using the XOR operation and generates the four byte MIC field in one operation. CCM and RADIO can be configured to work synchronously. CCM will encrypt in time for transmission and decrypt after receiving bytes into memory from RADIO. All operations can complete within the packet RX or TX time. CCM on this device is implemented according to *Bluetooth* requirements and the algorithm as defined in IETF RFC3610, and depends on the AES-128 block cipher. A description of the CCM algorithm can also be found in NIST Special Publication 800-38C. The *Bluetooth* specification describes the configuration of counter mode blocks and encryption blocks to implement compliant encryption for Bluetooth Low Energy.

The CCM block uses EasyDMA to load key counter mode blocks (including the nonce required), and to read/write plain text and cipher text.

Three operations are supported:

- Keystream generation
- Packet encryption
- Packet decryption

All operations are done in compliance with the *Bluetooth* specification.<sup>7</sup>

The following figure illustrates keystream generation followed by encryption or decryption. The shortcut is optional.

NORDIC\*

<sup>&</sup>lt;sup>7</sup> Bluetooth AES CCM 128-bit block encryption, see Bluetooth Core specification version 4.0.



Figure 41: Keystream generation

#### 7.5.1 Shared resources

CCM shares the same AES module as the ECB and AAR peripherals. ECB will always have the lowest priority. If there is a sharing conflict during encryption, the ECB operation will be aborted and an ERRORECB event will be generated in ECB.

Additionally, CCM shares registers and other resources with other peripherals that have the same ID as CCM. See Peripherals with shared ID on page 152 for more information.

## 7.5.2 Keystream generation

A new keystream needs to be generated before a new packet encryption or packet decryption operation can start.

A keystream is generated by triggering the KSGEN task. An ENDKSGEN event is generated after the keystream has been generated.

Keystream generation, packet encryption, and packet decryption operations utilize the configuration specified in the data structure pointed to by CNFPTR on page 180. It is necessary to configure this pointer and its underlying data structure, and register MODE on page 179 before the KSGEN task is triggered.

The keystream will be stored in CCM's temporary memory area, specified by the SCRATCHPTR on page 181, where it will be used in subsequent encryption and decryption operations.

For default length packets (MODE.LENGTH = Default), the size of the generated keystream is 27 bytes. When using extended length packets (MODE.LENGTH = Extended), register MAXPACKETSIZE on page 181 specifies the length of the keystream to be generated. The length of the generated keystream must be greater than or equal to the length of the subsequent packet payload to be encrypted or decrypted. The maximum length of the keystream in extended mode is 251 bytes, which means that the maximum packet payload size is 251 bytes.

If a shortcut is used between ENDKSGEN event and CRYPT task, pointers INPTR on page 180 and OUTPTR on page 180 must also be configured before the KSGEN task is triggered.

# 7.5.3 Encryption

CCM is able to read an unencrypted packet, encrypt it, and append a four byte MIC field to the packet.

During packet encryption, CCM performs the following:

- Reads the unencrypted packet located in RAM address specified in the INPTR pointer
- Encrypts the packet
- Appends a four byte long Message Integrity Check (MIC) field to the packet

Encryption is started by triggering the CRYPT task with register MODE on page 179 set to Encryption. An ENDCRYPT event is generated when packet encryption is completed.

CCM will also modify the length field of the packet to adjust for the appended MIC field. It adds four bytes to the length and stores the resulting packet in RAM at the address specified in pointer OUTPTR on page 180, as illustrated in the figure below.





Figure 42: Encryption

Empty packets (length field is set to 0) will not be encrypted, but instead moved unmodified through CCM.

CCM supports different widths of the length field in the data structure for encrypted packets. This is configured in register MODE on page 179.

#### 7.5.4 Decryption

CCM is able to read an encrypted packet, decrypt it, authenticate the MIC field, and generate an appropriate MIC status.

During packet decryption, CCM performs the following:

- · Reads the encrypted packet located in RAM at the address specified in the INPTR pointer
- Decrypts the packet
- · Authenticates the packet's MIC field
- Generates the appropriate MIC status

The packet header (S0) and payload are included in the MIC authentication. Bits in the packet header can be masked away by configuring register HEADERMASK on page 182.

Decryption is started by triggering the CRYPT task, by setting the register MODE on page 179 to Decryption. An ENDCRYPT event will be generated when packet decryption is completed.

CCM modifies the length field of the packet to adjust for the MIC field. It subtracts four bytes from the length and stores the decrypted packet in RAM at the address specified in the OUTPTR on page 180 pointer.

CCM is only able to decrypt packet payloads that are at least five bytes long (one byte or more encrypted payload (EPL) and four bytes of MIC). CCM will therefore generate a MIC error for packets where the length field is set to 1, 2, 3, or 4.

Empty packets (length field is set to 0) will not be decrypted but instead moved unmodified through CCM. These packets will always pass the MIC check.

CCM supports different widths of the LENGTH field in the data structure for decrypted packets. This is configured in register MODE on page 179.



Figure 43: Decryption

The CCM is only able to decrypt packet payloads that are at least 5 bytes long, 1 byte or more encrypted payload (EPL) and 4 bytes of MIC. The CCM will therefore generate a MIC error for packets where the



length field is set to 1, 2, 3 or 4. Empty packets (length field is set to 0) will not be decrypted, but instead moved unmodified through CCM. These packets will always pass the MIC check.

CCM supports different widths of the length field in the data structure for decrypted packets. This is configured in register MODE on page 179.

#### 7.5.5 AES CCM and RADIO concurrent operation

The CCM peripheral is able to encrypt/decrypt data synchronously to data being transmitted or received by RADIO.

In order for CCM to run synchronously with the radio, the data rate setting in register MODE on page 179 needs to match the radio data rate. The settings in this register apply whenever either the KSGEN or CRYPT tasks are triggered.

The data rate setting of register MODE on page 179 can also be overridden on-the-fly during an ongoing encrypt/decrypt operation by the contents of register RATEOVERRIDE on page 181. The data rate setting in this register applies whenever the RATEOVERRIDE task is triggered. This feature can be useful in cases where the radio data rate is changed during an ongoing packet transaction.

## 7.5.6 Encrypting packets on-the-fly in radio transmit mode

When CCM encrypts a packet on-the-fly while RADIO is transmitting it, RADIO must read the encrypted packet from the same memory location that CCM is writing to.

The OUTPTR on page 180 pointer in CCM must point to the same memory location as the PACKETPTR pointer in RADIO, as illustrated in the following figure.



Figure 44: Configuration of on-the-fly encryption

In order to match RADIO's timing, the KSGEN task must be triggered early enough to allow the keystream generation to complete before packet encryption begins.

For short packets (MODE.LENGTH = Default), the KSGEN task must be triggered before or at the same time as the START task in RADIO is triggered. In addition, the shortcut between the ENDKSGEN event and the CRYPT task must be enabled. This use-case is illustrated in On-the-fly encryption of short packets (MODE.LENGTH = Default), using a PPI connection on page 171. It uses a PPI connection between the READY event in RADIO and the KSGEN task in CCM.

For long packets (MODE.LENGTH = Extended), the keystream generation needs to start earlier, such as when the TXEN task in RADIO is triggered.

Refer to Timing specification on page 182 for information about the time needed for generating a keystream.





Figure 45: On-the-fly encryption of short packets (MODE.LENGTH = Default), using a PPI connection

For long packets (MODE.LENGTH = Extended), the keystream generation will need to be started even earlier, for example at the time when the TXEN task in the radio is triggered.

**Note:** See Timing specification on page 182 for information about the time needed for generating a keystream.

## 7.5.7 Decrypting packets on-the-fly in RADIO receive mode

When CCM decrypts a packet on-the-fly while RADIO is receiving it, CCM must read the encrypted packet from the same memory location that RADIO is writing to.

The pointer INPTR on page 180 in CCM must therefore point to the same memory location as the PACKETPTR pointer in RADIO.



Figure 46: Configuration of on-the-fly decryption

In order to match RADIO's timing, the KSGEN task must be triggered early enough to allow the keystream generation to complete before the decryption of the packet starts.

For short packets (MODE.LENGTH = Default), the KSGEN task must be triggered no later than when the START task in RADIO is triggered. In addition, the CRYPT task must not be triggered earlier than when the ADDRESS event is generated by RADIO. If the CRYPT task is triggered exactly at the same time as the ADDRESS event is generated by RADIO, CCM will guarantee that the decryption is completed no later than when the END event in RADIO is generated. This use case, using a PPI connection between the ADDRESS event in RADIO and the CRYPT task in CCM, is illustrated in figure below.





Figure 47: On-the-fly decryption of short packets (MODE.LENGTH = Default), using a PPI connection

The KSGEN task is triggered from the READY event in RADIO, through a PPI connection.

For long packets (MODE.LENGTH = Extended) the keystream generation will need to start even earlier, such as when the RXEN task in RADIO is triggered.

Refer to Timing specification on page 182 for information about the time needed for generating a keystream.

#### 7.5.8 CCM data structure

The CCM data structure is located in data RAM, at the memory location specified by the CNFPTR pointer register.

| Property | Address offset | Description                                                                                 |
|----------|----------------|---------------------------------------------------------------------------------------------|
| KEY      | 0              | 16-byte AES key.                                                                            |
| PKTCTR   | 16             | Octet0 (least significant octet (LSO)) of packet. counter                                   |
|          | 17             | Octet1 of packet counter.                                                                   |
|          | 18             | Octet2 of packet counter.                                                                   |
|          | 19             | Octet3 of packet counter.                                                                   |
|          | 20             | Bit 6 – bit 0: Octet4 (7 most significant bits of packet counter, with bit 6 being the most |
|          |                | significant bit). Bit 7: Ignored.                                                           |
|          | 21             | Ignored.                                                                                    |
|          | 22             | Ignored.                                                                                    |
|          | 23             | Ignored.                                                                                    |
|          | 24             | Bit 0: Direction bit. Bit 7 – bit 1: Zero padded.                                           |
| IV       | 25             | 8-byte initialization vector (IV). Octet0 (LSO) of IV, Octet1 of IV, , Octet7 (MSO) of IV.  |

Table 56: CCM data structure overview

The NONCE vector (as specified by the *Bluetooth* Core Specification) will be generated by hardware based on the information specified in the CCM data structure.

| Property | Address offset | Description                            |
|----------|----------------|----------------------------------------|
| HEADER   | 0              | Packet header                          |
| LENGTH   | 1              | Number of bytes in unencrypted payload |
| RFU      | 2              | Reserved for future use                |
| PAYLOAD  | 3              | Unencrypted payload                    |

Table 57: Data structure for unencrypted packet



| Property | Address offset     | Description                                                                                                                                  |
|----------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| HEADER   | 0                  | Packet header                                                                                                                                |
| LENGTH   | 1                  | Number of bytes in encrypted payload including length of MIC  LENGTH will be 0 for empty packets since the MIC is not added to empty packets |
| RFU      | 2                  | Reserved for future use                                                                                                                      |
| KI O     | 2                  | Nesel veu foi future use                                                                                                                     |
| PAYLOAD  | 3                  | Encrypted payload                                                                                                                            |
| MIC      | 3 + payload length | ENCRYPT: 4 bytes encrypted MIC                                                                                                               |

MIC is not added to empty packets

Table 58: Data structure for encrypted packet

## 7.5.9 EasyDMA and ERROR event

The CCM implements an EasyDMA mechanism for reading from and writing to RAM.

When the CPU and EasyDMA enabled peripherals access the same RAM block at the same time, increased bus collisions might disrupt on-the-fly encryption. In this case, the ERROR event will be generated.

EasyDMA stops accessing RAM when the ENDKSGEN and ENDCRYPT events are generated.

If the CNFPTR, SCRATCHPTR, INPTR and the OUTPTR are not pointing to the data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

# 7.5.10 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description           | Configuration |
|---------------------|------------|----------|----------------|--------------|-----------------------|---------------|
| 0x4100E000 NETWORK  | CCM        | CCM      | NS             | NA           | AES counter with CBC- |               |
|                     |            |          |                |              | MAC (CCM) mode block  |               |
|                     |            |          |                |              | encryption            |               |

Table 59: Instances

| Register               | Offset | Security | Description                                                                       |        |
|------------------------|--------|----------|-----------------------------------------------------------------------------------|--------|
| TASKS_KSGEN            | 0x000  |          | Start generation of keystream. This operation will stop by itself when completed. |        |
| TASKS_CRYPT            | 0x004  |          | Start encryption/decryption. This operation will stop by itself when completed.   |        |
| TASKS_STOP             | 0x008  |          | Stop encryption/decryption                                                        |        |
| TASKS_RATEOVERRIDE     | 0x00C  |          | Override DATARATE setting in MODE register with the contents of the RATEOVERRIDE  |        |
|                        |        |          | register for any ongoing encryption/decryption                                    |        |
| SUBSCRIBE_KSGEN        | 0x080  |          | Subscribe configuration for task KSGEN                                            |        |
| SUBSCRIBE_CRYPT        | 0x084  |          | Subscribe configuration for task CRYPT                                            |        |
| SUBSCRIBE_STOP         | 0x088  |          | Subscribe configuration for task STOP                                             |        |
| SUBSCRIBE_RATEOVERRIDE | 0x08C  |          | Subscribe configuration for task RATEOVERRIDE                                     |        |
| EVENTS_ENDKSGEN        | 0x100  |          | Keystream generation complete                                                     |        |
| EVENTS_ENDCRYPT        | 0x104  |          | Encrypt/decrypt complete                                                          |        |
| EVENTS_ERROR           | 0x108  |          | CCM error event                                                                   | Deprec |
| PUBLISH_ENDKSGEN       | 0x180  |          | Publish configuration for event ENDKSGEN                                          |        |
| PUBLISH_ENDCRYPT       | 0x184  |          | Publish configuration for event ENDCRYPT                                          |        |
| PUBLISH_ERROR          | 0x188  |          | Publish configuration for event ERROR                                             | Deprec |
| SHORTS                 | 0x200  |          | Shortcuts between local events and tasks                                          |        |
| INTENSET               | 0x304  |          | Enable interrupt                                                                  |        |
| INTENCLR               | 0x308  |          | Disable interrupt                                                                 |        |
| MICSTATUS              | 0x400  |          | MIC check result                                                                  |        |
| ENABLE                 | 0x500  |          | Enable                                                                            |        |
| MODE                   | 0x504  |          | Operation mode                                                                    |        |



| Register      | Offset | Security | Description                                                        |
|---------------|--------|----------|--------------------------------------------------------------------|
| CNFPTR        | 0x508  |          | Pointer to data structure holding the AES key and the NONCE vector |
| INPTR         | 0x50C  |          | Input pointer                                                      |
| OUTPTR        | 0x510  |          | Output pointer                                                     |
| SCRATCHPTR    | 0x514  |          | Pointer to data area used for temporary storage                    |
| MAXPACKETSIZE | 0x518  |          | Length of keystream generated when MODE.LENGTH = Extended          |
| RATEOVERRIDE  | 0x51C  |          | Data rate override setting.                                        |
| HEADERMASK    | 0x520  |          | Header (S0) mask.                                                  |

Table 60: Register overview

#### 7.5.10.1 TASKS\_KSGEN

Address offset: 0x000

Start generation of keystream. This operation will stop by itself when completed.

| Bit n | umber    |             |         | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------|---------|----------------|------------------------------------------------------------------------|
| ID    |          |             |         |                | А                                                                      |
| Rese  | et 0x000 | 00000       |         | 0 0 0 0 0      | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                              |
| ID    |          |             |         |                | Description                                                            |
| Α     | W        | TASKS_KSGEN |         |                | Start generation of keystream. This operation will stop by             |
|       |          |             |         |                | itself when completed.                                                 |
|       |          |             | Trigger | 1              | Trigger task                                                           |

## 7.5.10.2 TASKS\_CRYPT

Address offset: 0x004

Start encryption/decryption. This operation will stop by itself when completed.



## 7.5.10.3 TASKS\_STOP

Address offset: 0x008

Stop encryption/decryption



#### 7.5.10.4 TASKS RATEOVERRIDE

Address offset: 0x00C





Override DATARATE setting in MODE register with the contents of the RATEOVERRIDE register for any ongoing encryption/decryption



#### 7.5.10.5 SUBSCRIBE\_KSGEN

Address offset: 0x080

Subscribe configuration for task KSGEN



#### 7.5.10.6 SUBSCRIBE CRYPT

Address offset: 0x084

Subscribe configuration for task CRYPT



#### 7.5.10.7 SUBSCRIBE STOP

Address offset: 0x088

Subscribe configuration for task STOP





## 7.5.10.8 SUBSCRIBE\_RATEOVERRIDE

Address offset: 0x08C

Subscribe configuration for task RATEOVERRIDE

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task RATEOVERRIDE will subscribe to           |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

#### 7.5.10.9 EVENTS ENDKSGEN

Address offset: 0x100

Keystream generation complete

| Bit n | umber   |                 |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                 |              |                         | A                                                               |
| Rese  | t 0x000 | 00000           |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                 |              |                         |                                                                 |
| Α     | RW      | EVENTS_ENDKSGEN |              |                         | Keystream generation complete                                   |
|       |         |                 | NotGenerated | 0                       | Event not generated                                             |
|       |         |                 | Generated    | 1                       | Event generated                                                 |

#### 7.5.10.10 EVENTS\_ENDCRYPT

Address offset: 0x104

Encrypt/decrypt complete



## 7.5.10.11 EVENTS\_ERROR (Deprecated)

Address offset: 0x108



#### CCM error event



#### 7.5.10.12 PUBLISH ENDKSGEN

Address offset: 0x180

Publish configuration for event ENDKSGEN



#### 7.5.10.13 PUBLISH\_ENDCRYPT

Address offset: 0x184

Publish configuration for event ENDCRYPT



## 7.5.10.14 PUBLISH\_ERROR (Deprecated)

Address offset: 0x188

Publish configuration for event ERROR





## 7.5.10.15 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber   |                |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |          |                         | A                                                               |
| Rese  | t 0x000 | 00000          |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |          |                         |                                                                 |
| Α     | RW      | ENDKSGEN_CRYPT |          |                         | Shortcut between event ENDKSGEN and task CRYPT                  |
|       |         |                | Disabled | 0                       | Disable shortcut                                                |
|       |         |                | Enabled  | 1                       | Enable shortcut                                                 |

## 7.5.10.16 INTENSET

Address offset: 0x304

Enable interrupt

| Bit r | umber    |          |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |          |          |                        | СВА                                                             |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |          |          |                        | Description                                                     |
| Α     | RW       | ENDKSGEN |          |                        | Write '1' to enable interrupt for event ENDKSGEN                |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |
| В     | RW       | ENDCRYPT |          |                        | Write '1' to enable interrupt for event ENDCRYPT                |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW       | ERROR    |          |                        | Write '1' to enable interrupt for event ERROR Deprecated        |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |

## 7.5.10.17 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |          |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |  |
|-------|----------|----------|----------|-------------------------|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| ID    |          |          |          |                         | СВА                                                             |  |  |  |  |  |  |  |  |  |  |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |  |  |  |  |  |  |  |
| ID    |          |          |          |                         |                                                                 |  |  |  |  |  |  |  |  |  |  |
| Α     | RW       | ENDKSGEN |          |                         | Write '1' to disable interrupt for event ENDKSGEN               |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Clear    | 1                       | Disable                                                         |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |  |  |  |  |  |  |  |
| В     | RW       | ENDCRYPT |          |                         | Write '1' to disable interrupt for event ENDCRYPT               |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Clear    | 1                       | Disable                                                         |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |  |  |  |  |  |  |  |  |  |  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |  |  |  |  |  |  |  |



| Bit n | umber   |       |                   | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0   |
|-------|---------|-------|-------------------|-------------------------|-------------------------------------------------------------------|
| ID    |         |       |                   |                         | СВА                                                               |
| Rese  | t 0x000 | 00000 |                   | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                           |
| ID    |         |       |                   |                         | Description                                                       |
| _     | DIA     |       |                   |                         | -                                                                 |
| C     | RW      | ERROR |                   |                         | Write '1' to disable interrupt for event ERROR Deprecated         |
| C     | KVV     | ERROR | Clear             | 1                       | Write '1' to disable interrupt for event ERROR Deprecated Disable |
| C     | KVV     | ERROR | Clear<br>Disabled | 1 0                     | ·                                                                 |

## 7.5.10.18 MICSTATUS

Address offset: 0x400

MIC check result

| Bit n | umber   |           |             | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|-------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |           |             |                         | А                                                               |
| Rese  | t 0x000 | 00000     |             | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |           |             |                         | Description                                                     |
| Α     | R       | MICSTATUS |             |                         | The result of the MIC check performed during the previous       |
|       |         |           |             |                         | decryption operation                                            |
|       |         |           | CheckFailed | 0                       | MIC check failed                                                |
|       |         |           | CheckPassed | 1                       | MIC check passed                                                |

#### 7.5.10.19 ENABLE

Address offset: 0x500

Enable

| Bit n | umber   |        | 31 30 29 28 | 3 27 26 2 | 5 24 2 | 3 22 2 | 1 20 1 | 19 18  | 17 1 | 6 15 | 14 13 | 3 12 | 11 1 | 0 9 | 8 | 7 6 | 5   | 4 | 3 | 2 : | 1 0 |     |
|-------|---------|--------|-------------|-----------|--------|--------|--------|--------|------|------|-------|------|------|-----|---|-----|-----|---|---|-----|-----|-----|
| ID    |         |        |             |           |        |        |        |        |      |      |       |      |      |     |   |     |     |   |   |     | Å   | 4 А |
| Rese  | t 0x000 | 00000  |             | 0 0 0 0   | 0 0 0  | 0 0 0  | 0 0    | 0      | 0 0  | 0 (  | 0 0   | 0 0  | 0    | 0 0 | 0 | 0   | 0 ( | 0 | 0 | 0   | 0 ( | 0 0 |
| ID    |         |        |             |           |        |        |        |        |      |      |       |      |      |     |   |     |     |   |   |     |     |     |
| Α     | RW      | ENABLE |             |           |        | Е      | nable  | or dis | able | CCM  | 1     |      |      |     |   |     |     |   |   |     |     |     |
|       |         |        | Disabled    | 0         |        | D      | isable |        |      |      |       |      |      |     |   |     |     |   |   |     |     |     |
|       |         |        | Enabled     | 2         |        | E      | nable  |        |      |      |       |      |      |     |   |     |     |   |   |     |     |     |

## 7.5.10.20 MODE

Address offset: 0x504

Operation mode

| Bit n | umber    |          |            | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|------------|---------------------|--------------------------------------------------------------------|
| ID    |          |          |            |                     | C B B A                                                            |
| Rese  | et 0x000 | 00001    |            | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID    |          |          |            |                     | Description                                                        |
| Α     | RW       | MODE     |            |                     | The mode of operation to be used. Settings in this register        |
|       |          |          |            |                     | apply whenever either the KSGEN task or the CRYPT task is          |
|       |          |          |            |                     | triggered.                                                         |
|       |          |          | Encryption | 0                   | AES CCM packet encryption mode                                     |
|       |          |          | Decryption | 1                   | AES CCM packet decryption mode                                     |
| В     | RW       | DATARATE |            |                     | Radio data rate that the CCM shall run synchronous with            |
|       |          |          | 1Mbit      | 0                   | 1 Mbps                                                             |





| Bit number  |        |          | 31 30 29 | 9 28 2 | 7 26 2 | 5 24 | 23 22  | 21 2  | 20 19 | 9 18   | 17 16  | 5 15  | 14 1  | 13 12 | 11 1   | 0 9  | 8     | 7    | 6 5 | 4 | 3   | 2 1 | 0 |
|-------------|--------|----------|----------|--------|--------|------|--------|-------|-------|--------|--------|-------|-------|-------|--------|------|-------|------|-----|---|-----|-----|---|
| ID          |        |          |          | С      | E      |      |        |       |       | ВВ     |        |       |       |       |        |      |       |      |     |   | Α   |     |   |
| Reset 0x000 |        | 0 0 0    | 0 0      | 0 0    | 0 0    | 0 0  | 0      | 0 0   | 0     | 0 0    | 0      | 0     | 0 0   | 0 (   | 0      | 0    | 0     | 0 0  | 0   | 0 | 0 0 | 1   |   |
|             |        |          |          |        |        |      |        |       |       |        |        |       |       |       |        |      |       |      |     |   |     |     |   |
|             |        | 2Mbit    | 1        |        |        |      | 2 Mbp  | os    |       |        |        |       |       |       |        |      |       |      |     |   |     |     |   |
|             |        | 125Kbps  | 2        |        |        |      | 125 kl | bps   |       |        |        |       |       |       |        |      |       |      |     |   |     |     |   |
|             |        | 500Kbps  | 3        |        |        |      | 500 kl | bps   |       |        |        |       |       |       |        |      |       |      |     |   |     |     |   |
| C RW        | LENGTH |          |          |        |        |      | Packe  | t ler | ngth  | conf   | figura | ation | 1     |       |        |      |       |      |     |   |     |     |   |
|             |        | Default  | 0        |        |        |      | Defau  | lt le | ength | ı. Eff | ectiv  | e ler | ngth  | of L  | ENG    | H fi | eld i | n    |     |   |     |     |   |
|             |        |          |          |        |        |      | encry  | pted  | d/de  | cryp   | ted p  | acke  | et is | 5 bit | s. A   | keys | trea  | n f  | or  |   |     |     |   |
|             |        |          |          |        |        |      | packe  | t pa  | yloa  | ds u   | p to   | 27 b  | ytes  | will  | be g   | ener | ated  |      |     |   |     |     |   |
|             |        | Extended | 1        |        |        |      | Exten  | ded   | leng  | gth. I | Effect | tive  | leng  | th o  | LEN    | GTH  | field | l in |     |   |     |     |   |
|             |        |          |          |        |        |      | encry  | pted  | d/de  | cryp   | ted p  | acke  | et is | 8 bit | s. A   | keys | trea  | n f  | or  |   |     |     |   |
|             |        |          |          |        |        |      | packe  | t pa  | yloa  | ds u   | p to   | MAX   | PAC   | CKETS | SIZE I | yte  | wil   | be   |     |   |     |     |   |
|             |        |          |          |        |        |      | gener  | ated  | d.    |        |        |       |       |       |        |      |       |      |     |   |     |     |   |

#### 7.5.10.21 CNFPTR

Address offset: 0x508

Pointer to data structure holding the AES key and the NONCE vector

| Bit number |                  |        |  | 31 | 30 | 29 | 28 | 27 2 | 26 2 | 25 2 | 24 2 | 3 2                                                | 2 2: | 1 20 | 19 | 18   | 17 : | 16 1 | 5 14 | 113 | 12  | 11   | 10  | 9 8  | 7    | 6  | 5 | 4  | 3 2 | 2 1 | 0 |
|------------|------------------|--------|--|----|----|----|----|------|------|------|------|----------------------------------------------------|------|------|----|------|------|------|------|-----|-----|------|-----|------|------|----|---|----|-----|-----|---|
| ID         | ID               |        |  | Α  | Α  | Α  | Α  | Α    | Α    | A ,  | A A  | Δ Α                                                | Δ Δ  | A    | Α  | Α    | Α    | A A  | Δ Δ  | A   | Α   | Α    | Α   | ΑД   | A    | Α  | Α | Α. | A A | A A | Α |
| Rese       | Reset 0x00000000 |        |  | 0  | 0  | 0  | 0  | 0    | 0    | 0 (  | 0 (  | 0 (                                                | 0    | 0    | 0  | 0    | 0    | 0 (  | 0    | 0   | 0   | 0    | 0   | 0 0  | 0    | 0  | 0 | 0  | 0 ( | 0   | 0 |
| ID         |                  |        |  |    |    |    |    |      |      |      |      |                                                    |      |      |    |      |      |      |      |     |     |      |     |      |      |    |   |    |     |     |   |
| Α          | RW               | CNFPTR |  |    |    |    |    |      |      |      | P    | oin                                                | iter | to t | he | data | a st | ruct | ure  | hol | din | g th | e A | ES k | ey a | nd |   |    |     |     |   |
|            |                  |        |  |    |    |    |    |      |      |      |      | the CCM NONCE vector (see table CCM data structure |      |      |    |      |      |      |      |     |     |      |     |      |      |    |   |    |     |     |   |
|            |                  |        |  |    |    |    |    |      |      |      |      | overview)                                          |      |      |    |      |      |      |      |     |     |      |     |      |      |    |   |    |     |     |   |

#### 7.5.10.22 INPTR

Address offset: 0x50C

Input pointer



#### 7.5.10.23 OUTPTR

Address offset: 0x510

Output pointer





#### 7.5.10.24 SCRATCHPTR

Address offset: 0x514

Pointer to data area used for temporary storage



#### 7.5.10.25 MAXPACKETSIZE

Address offset: 0x518

Length of keystream generated when MODE.LENGTH = Extended



#### 7.5.10.26 RATEOVERRIDE

Address offset: 0x51C

Data rate override setting.

Override value to be used instead of the setting of MODE.DATARATE. This override value applies when the RATEOVERRIDE task is triggered.





#### **7.5.10.27 HEADERMASK**

Address offset: 0x520

Header (S0) mask.

Bitmask for packet header (S0) before MIC generation/authentication.



## 7.5.11 Electrical specification

#### 7.5.11.1 Timing specification

| Symbol            | Description                                          | Min. | Тур. | Max. | Units |
|-------------------|------------------------------------------------------|------|------|------|-------|
| t <sub>kgen</sub> | Time needed for keystream generation (given priority |      |      | 50   | μs    |
|                   | access to destination RAM block)                     |      |      |      |       |

# 7.6 COMP — Comparator

The comparator (COMP) compares an input voltage (VIN+) against a second input voltage (VIN-). VIN+ can be derived from an analog input pin (AIN0-AIN7). VIN- can be derived from multiple sources depending on the operation mode of the comparator.

The main features of COMP are the following:

- Input range from 0 V to VDD
- Single-ended mode
  - Fully flexible hysteresis using a 64-level reference ladder
- Differential mode
  - · Configurable hysteresis
- Reference inputs (VREF):
  - VDD
  - External reference from AINO to AIN7 (between 0 V and VDD)
  - Internal references 1.2 V, 1.8 V, and 2.4 V
- Three speed/power consumption modes:
  - Low-power
  - Normal
  - High-speed
- Single-pin capacitive sensor support
- · Event generation on output changes
  - UP event on VIN- > VIN+
  - DOWN event on VIN- < VIN+
  - · CROSS event on VIN+ and VIN- crossing
  - · READY event on core and internal reference (if used) ready





Figure 48: Comparator overview

Once enabled (using the ENABLE register), the comparator is started by triggering the START task and stopped by triggering the STOP task. The comparator will generate a READY event to indicate when it is ready for use and the output is correct. The delay between START and READY is t<sub>INT\_REF,START</sub> if an internal reference is selected, or t <sub>COMP,START</sub> if an external reference is used. When the COMP module is started, events will be generated every time VIN+ crosses VIN-.

#### **Operation modes**

The comparator can be configured to operate in two main operation modes: differential mode and single-ended mode. See the MODE register for more information. In both operation modes, the comparator can operate in different speed and power consumption modes (low-power, normal and high-speed). High-speed mode will consume more power compared to low-power mode, and low-power mode will result in slower response time compared to high-speed mode.

Use the PSEL register to select any of the AINO-AIN7 pins as VIN+ input, regardless of the operation mode selected for the comparator. The source of VIN- depends on which of the following operation mode are used:

- Differential mode Derived directly from AINO to AIN7
- Single-ended mode Derived from VREF. VREF can be derived from VDD, AINO-AIN7 or internal 1.2 V, 1.8 V and 2.4 V references.

The selected analog pins will be acquired by the comparator once it is enabled.

An optional hysteresis on VIN+ and VIN- can be enabled when the module is used in differential mode through the HYST register. In single-ended mode, VUP and VDOWN thresholds can be set to implement a hysteresis using the reference ladder (see Comparator in single-ended mode on page 186). This hysteresis is in the order of magnitude of V<sub>DIFFHYST</sub>, and shall prevent noise on the signal to create unwanted events. See Hysteresis example where VIN+ starts below VUP on page 187 for an illustration of the effect of an active hysteresis on a noisy input signal.

An upward crossing will generate an UP event and a downward crossing will generate a DOWN event. The CROSS event will be generated every time there is a crossing, independent of direction.

The immediate value of the comparator can be sampled to RESULT register by triggering the SAMPLE task.



#### **ISOURCE**

An optional configurable current can be applied on the AINx pad currently selected for VIN+, as illustrated in the following figure. The AINx pad is configured in register PSEL on page 194 and the current source in register ISOURCE on page 196.



Figure 49: Using the configurable current source

Enabling ISOURCE creates a feedback path around the comparator, forming a relaxation oscillator. The circuit will sink current from VIN+ when the comparator output is high, and source current into VIN+ when the comparator output is low. The frequency of the oscillator is dependent on the capacitance at the analog input pin, the reference voltages, and the value of the current source. When using ISOURCE, a capacitive sensor can to be attached between the analog input pin and ground. With a selected current of 10  $\mu$ A, VUP-VDOWN equal to 1 V, and an external capacity of typically 10 pF, the resulting oscillation frequency is around 500 kHz.

The frequency of the oscillator can be calculated using the following equation:

```
f_OSC = I_SOURCE / (2C · (VUP-VDOWN) )
```

**Note:** The current source can be enabled in any of the comparator modes.

#### 7.6.1 Shared resources

The COMP shares analog resources with other analog peripherals.

While it is possible to use the SAADC at the same time as the COMP, selecting the same analog input pin for both peripherals is not supported.

Additionally, COMP shares registers and other resources with other peripherals that have the same ID as the COMP. See Peripherals with shared ID on page 152 for more information.

The COMP peripheral shall not be disabled (by writing to the ENABLE register) before the peripheral has been stopped. Failing to do so may result in unpredictable behavior.

NORDIC SEMICONDUCTOR

#### 7.6.2 Differential mode

In differential mode, the reference input VIN- is derived directly from one of the AINx pins.

Before enabling the comparator via the ENABLE register, the following registers must be configured for the differential mode:

- PSEL
- MODE
- EXTREFSEL



Figure 50: Comparator in differential mode

**Note:** Depending on the device, not all the analog inputs may be available for each MUX. See definitions for PSEL and EXTREFSEL for more information about which analog pins are available on a particular device.

When the HYST register is turned on during this mode, the output of the comparator and associated events do the following:

- Change from ABOVE to BELOW when VIN+ drops below VIN- (VDIFFHYST/2)
- Change from BELOW to ABOVE when VIN+ raises above VIN- + (VDIFFHYST/2)

This behavior is illustrated in the following figure.



Figure 51: Hysteresis enabled in differential mode



## 7.6.3 Single-ended mode

In single-ended mode, VIN- is derived from the reference ladder.

Before enabling the comparator via the ENABLE register, the following registers must be configured for the single-ended mode:

- PSEL
- MODE
- REFSEL
- EXTREFSEL
- TH

The reference ladder uses the reference voltage (VREF) to derive two new voltage references, VUP and VDOWN. VUP and VDOWN are configured using THUP and THDOWN respectively in the TH register. VREF can be derived from any of the available reference sources, configured using the EXTREFSEL and REFSEL registers as shown in the following figure. When AREF is selected in the REFSEL register, the EXTREFSEL register is used to select one of the AINO-AIN7 analog input pins as reference input. The selected analog pins will be acquired by the comparator once it is enabled.



Figure 52: Comparator in single-ended mode

**Note:** Depending on the device, not all the analog inputs may be available for each MUX. See definitions for PSEL and EXTREFSEL for more information about which analog pins are available on a particular device.

When the comparator core detects that VIN+ > VIN-, i.e. ABOVE as per the RESULT register, VIN- will switch to VDOWN. When VIN+ falls below VIN- again, VIN- will be switched back to VUP. By specifying VUP larger than VDOWN, a hysteresis can be generated as illustrated in the following figures.

Writing to HYST has no effect in single-ended mode, and the content of this register is ignored.





Figure 53: Hysteresis example where VIN+ starts below VUP



Figure 54: Hysteresis example where VIN+ starts above VUP

# 7.6.4 Registers

| Base address Domain       | Peripheral | Instance  | Secure mapping | DMA security | Description | Configuration |
|---------------------------|------------|-----------|----------------|--------------|-------------|---------------|
| 0x5001A000<br>APPLICATION | L COMP     | COMP : S  | US             | NA           | Comparator  |               |
| 0x4001A000                | N COIVIP   | COMP : NS | 03             | INA          | Comparator  |               |

Table 61: Instances



| Register         | Offset | Security | Description                                   |
|------------------|--------|----------|-----------------------------------------------|
| TASKS_START      | 0x000  |          | Start comparator                              |
| TASKS_STOP       | 0x004  |          | Stop comparator                               |
| TASKS_SAMPLE     | 0x008  |          | Sample comparator value                       |
| SUBSCRIBE_START  | 0x080  |          | Subscribe configuration for task START        |
| SUBSCRIBE_STOP   | 0x084  |          | Subscribe configuration for task STOP         |
| SUBSCRIBE_SAMPLE | 0x088  |          | Subscribe configuration for task SAMPLE       |
| EVENTS_READY     | 0x100  |          | COMP is ready and output is valid             |
| EVENTS_DOWN      | 0x104  |          | Downward crossing                             |
| EVENTS_UP        | 0x108  |          | Upward crossing                               |
| EVENTS_CROSS     | 0x10C  |          | Downward or upward crossing                   |
| PUBLISH_READY    | 0x180  |          | Publish configuration for event READY         |
| PUBLISH_DOWN     | 0x184  |          | Publish configuration for event DOWN          |
| PUBLISH_UP       | 0x188  |          | Publish configuration for event UP            |
| PUBLISH_CROSS    | 0x18C  |          | Publish configuration for event CROSS         |
| SHORTS           | 0x200  |          | Shortcuts between local events and tasks      |
| INTEN            | 0x300  |          | Enable or disable interrupt                   |
| INTENSET         | 0x304  |          | Enable interrupt                              |
| INTENCLR         | 0x308  |          | Disable interrupt                             |
| RESULT           | 0x400  |          | Compare result                                |
| ENABLE           | 0x500  |          | COMP enable                                   |
| PSEL             | 0x504  |          | Pin select                                    |
| REFSEL           | 0x508  |          | Reference source select for single-ended mode |
| EXTREFSEL        | 0x50C  |          | External reference select                     |
| TH               | 0x530  |          | Threshold configuration for hysteresis unit   |
| MODE             | 0x534  |          | Mode configuration                            |
| HYST             | 0x538  |          | Comparator hysteresis enable                  |
| ISOURCE          | 0x53C  |          | Current source select on analog input         |

Table 62: Register overview

## 7.6.4.1 TASKS\_START

Address offset: 0x000

Start comparator



## 7.6.4.2 TASKS\_STOP

Address offset: 0x004

Stop comparator





## 7.6.4.3 TASKS\_SAMPLE

Address offset: 0x008
Sample comparator value

| Bit n | umber    |              |         | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|---------|------------------|------------------------------------------------------------------------|
| ID    |          |              |         |                  | A                                                                      |
| Rese  | et 0x000 | 00000        |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |          |              |         |                  |                                                                        |
| Α     | W        | TASKS_SAMPLE |         |                  | Sample comparator value                                                |
|       |          |              | Trigger | 1                | Trigger task                                                           |

## 7.6.4.4 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



#### 7.6.4.5 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP

| Bit n | number   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|-----|
| ID    |          |       |          | В                       | A A A A A A                                                 | А А |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID    |          |       |          |                         |                                                             |     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to               |     |
| В     | RW       | EN    |          |                         |                                                             |     |
|       |          |       | Disabled | 0                       | Disable subscription                                        |     |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |     |

189

## 7.6.4.6 SUBSCRIBE\_SAMPLE

Address offset: 0x088

Subscribe configuration for task SAMPLE



| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task SAMPLE will subscribe to               |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable subscription                                          |
|       |         |       | Enabled  | 1                       | Enable subscription                                           |

# 7.6.4.7 EVENTS\_READY

Address offset: 0x100

COMP is ready and output is valid

| Bit n | umber   |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                        | А                                                               |
| Rese  | t 0x000 | 000000       |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                        | Description                                                     |
| Α     | RW      | EVENTS_READY |              |                        | COMP is ready and output is valid                               |
|       |         |              | NotGenerated | 0                      | Event not generated                                             |
|       |         |              | Generated    | 1                      | Event generated                                                 |

## 7.6.4.8 EVENTS\_DOWN

Address offset: 0x104

Downward crossing

| Bit n | umber    |             |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |             |              |                         | A                                                               |
| Rese  | et 0x000 | 00000       |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |             |              |                         |                                                                 |
| Α     | RW       | EVENTS_DOWN |              |                         | Downward crossing                                               |
|       |          |             | NotGenerated | 0                       | Event not generated                                             |
|       |          |             | Generated    | 1                       | Event generated                                                 |

## 7.6.4.9 EVENTS\_UP

Address offset: 0x108

Upward crossing

| Bit n | umber   |           |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |           |              |                        | A                                                               |
| Rese  | t 0x000 | 00000     |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |           |              |                        |                                                                 |
| Α     | RW      | EVENTS_UP |              |                        | Upward crossing                                                 |
|       |         |           | NotGenerated | 0                      | Event not generated                                             |
|       |         |           | Generated    | 1                      | Event generated                                                 |

## 7.6.4.10 EVENTS\_CROSS

Address offset: 0x10C

Downward or upward crossing





## 7.6.4.11 PUBLISH\_READY

Address offset: 0x180

Publish configuration for event READY

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event READY will publish to.                |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |

## 7.6.4.12 PUBLISH\_DOWN

Address offset: 0x184

Publish configuration for event DOWN

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------|-------|
| ID    |         |       |          | В                       | A A A A A                                                 | 4 A A |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   | 0 0 0 |
| ID    |         |       |          |                         |                                                           |       |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event DOWN will publish to.             |       |
| В     | RW      | EN    |          |                         |                                                           |       |
|       |         |       | Disabled | 0                       | Disable publishing                                        |       |
|       |         |       | Enabled  | 1                       | Enable publishing                                         |       |

## 7.6.4.13 PUBLISH\_UP

Address offset: 0x188

Publish configuration for event UP





## 7.6.4.14 PUBLISH\_CROSS

Address offset: 0x18C

Publish configuration for event CROSS



#### 7.6.4.15 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit r | umber    |              |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |              |          |                         | E D C B A                                                       |
| Rese  | et 0x000 | 00000        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |          |                         |                                                                 |
| Α     | RW       | READY_SAMPLE |          |                         | Shortcut between event READY and task SAMPLE                    |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| В     | RW       | READY_STOP   |          |                         | Shortcut between event READY and task STOP                      |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| С     | RW       | DOWN_STOP    |          |                         | Shortcut between event DOWN and task STOP                       |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| D     | RW       | UP_STOP      |          |                         | Shortcut between event UP and task STOP                         |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| Ε     | RW       | CROSS_STOP   |          |                         | Shortcut between event CROSS and task STOP                      |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |

#### 7.6.4.16 INTEN

Address offset: 0x300

Enable or disable interrupt





| Bit number       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID               |          |                         | D C B A                                                         |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field     |          |                         | Description                                                     |
|                  | Disabled | 0                       | Disable                                                         |
|                  | Enabled  | 1                       | Enable                                                          |
| C RW UP          |          |                         | Enable or disable interrupt for event UP                        |
|                  | Disabled | 0                       | Disable                                                         |
|                  | Enabled  | 1                       | Enable                                                          |
| D RW CROSS       |          |                         | Enable or disable interrupt for event CROSS                     |
|                  | Disabled | 0                       | Disable                                                         |
|                  | Enabled  | 1                       | Enable                                                          |

## 7.6.4.17 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------------|----------------------------------------------------------------------------|
| ID    |          |       |          |                         | D C B A                                                                    |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
|       |          |       |          |                         | Description                                                                |
| Α     | RW       | READY |          |                         | Write '1' to enable interrupt for event READY                              |
|       |          |       | Set      | 1                       | Enable                                                                     |
|       |          |       | Disabled | 0                       | Read: Disabled                                                             |
|       |          |       | Enabled  | 1                       | Read: Enabled                                                              |
| В     | RW       | DOWN  |          |                         | Write '1' to enable interrupt for event DOWN                               |
|       |          |       | Set      | 1                       | Enable                                                                     |
|       |          |       | Disabled | 0                       | Read: Disabled                                                             |
|       |          |       | Enabled  | 1                       | Read: Enabled                                                              |
| С     | RW       | UP    |          |                         | Write '1' to enable interrupt for event UP                                 |
|       |          |       | Set      | 1                       | Enable                                                                     |
|       |          |       | Disabled | 0                       | Read: Disabled                                                             |
|       |          |       | Enabled  | 1                       | Read: Enabled                                                              |
| D     | RW       | CROSS |          |                         | Write '1' to enable interrupt for event CROSS                              |
|       |          |       | Set      | 1                       | Enable                                                                     |
|       |          |       | Disabled | 0                       | Read: Disabled                                                             |
|       |          |       | Enabled  | 1                       | Read: Enabled                                                              |

## 7.6.4.18 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit number |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------|--------|----------|-------------------------|-----------------------------------------------------------------|
| ID         |        |          |                         | D C B A                                                         |
| Reset 0x00 | 000000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W     |        |          |                         |                                                                 |
| A RW       | READY  |          |                         | Write '1' to disable interrupt for event READY                  |
|            |        | Clear    | 1                       | Disable                                                         |
|            |        | Disabled | 0                       | Read: Disabled                                                  |
|            |        | Enabled  | 1                       | Read: Enabled                                                   |
| B RW       | DOWN   |          |                         | Write '1' to disable interrupt for event DOWN                   |





| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|----------------------------------------------------------------------------|
| ID    |         |       |          |                         | D C B A                                                                    |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
| ID    |         |       |          |                         | Description                                                                |
|       |         |       | Clear    | 1                       | Disable                                                                    |
|       |         |       | Disabled | 0                       | Read: Disabled                                                             |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                              |
| С     | RW      | UP    |          |                         | Write '1' to disable interrupt for event UP                                |
|       |         |       | Clear    | 1                       | Disable                                                                    |
|       |         |       | Disabled | 0                       | Read: Disabled                                                             |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                              |
| D     | RW      | CROSS |          |                         | Write '1' to disable interrupt for event CROSS                             |
|       |         |       | Clear    | 1                       | Disable                                                                    |
|       |         |       | Disabled | 0                       | Read: Disabled                                                             |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                              |
|       |         |       |          |                         |                                                                            |

#### 7.6.4.19 RESULT

Address offset: 0x400

Compare result

| Bit n | umber   |        |       | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------|-------|-------------------------|-----------------------------------------------------------------|
| ID    |         |        |       |                         | А                                                               |
| Rese  | t 0x000 | 00000  |       | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |        |       |                         |                                                                 |
| Α     | R       | RESULT |       |                         | Result of last compare. Decision point SAMPLE task.             |
|       |         |        | Below | 0                       | Input voltage is below the threshold (VIN+ < VIN-)              |
|       |         |        | Above | 1                       | Input voltage is above the threshold (VIN+ > VIN-)              |

## 7.6.4.20 ENABLE

Address offset: 0x500

COMP enable

| Bit n | umber    |        |          | 31 30 29 28 | 8 27 2 | 26 25 2 | 24 23 22 | 21 20  | 19 1  | 18 17 | 7 16 1 | 5 14 | 13 1 | 2 11 | 10 9 | 8 | 7 | 6 | 5 4 | 4 3 | 2 | 1 0 |
|-------|----------|--------|----------|-------------|--------|---------|----------|--------|-------|-------|--------|------|------|------|------|---|---|---|-----|-----|---|-----|
| ID    |          |        |          |             |        |         |          |        |       |       |        |      |      |      |      |   |   |   |     |     |   | A A |
| Rese  | et 0x000 | 00000  |          | 0 0 0 0     | 0 0    | 0 0     | 0 0 0    | 0 0    | 0     | 0 0   | 0 (    | 0 0  | 0 0  | 0    | 0 0  | 0 | 0 | 0 | 0 ( | 0 0 | 0 | 0 0 |
| ID    |          |        |          |             |        |         |          |        |       |       |        |      |      |      |      |   |   |   |     |     |   |     |
| Α     | RW       | ENABLE |          |             |        |         | Enabl    | e or c | lisab | le Co | ОМР    |      |      |      |      |   |   |   |     |     |   |     |
|       |          |        | Disabled | 0           |        |         | Disab    | le     |       |       |        |      |      |      |      |   |   |   |     |     |   |     |
|       |          |        | Enabled  | 2           |        |         | Enabl    | e      |       |       |        |      |      |      |      |   |   |   |     |     |   |     |

### 7.6.4.21 PSEL

Address offset: 0x504

Pin select







#### 7.6.4.22 REFSEL

Address offset: 0x508

Reference source select for single-ended mode

| Bit r | umber    |        |        | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|--------|------------------------|-----------------------------------------------------------------|
| ID    |          |        |        |                        | ААА                                                             |
| Rese  | et 0x000 | 00004  |        | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |        |        |                        |                                                                 |
| Α     | RW       | REFSEL |        |                        | Reference select                                                |
|       |          |        | Int1V2 | 0                      | VREF = internal 1.2 V reference (VDD >= 1.7 V)                  |
|       |          |        | Int1V8 | 1                      | VREF = internal 1.8 V reference (VDD >= VREF + 0.2 V)           |
|       |          |        | Int2V4 | 2                      | VREF = internal 2.4 V reference (VDD >= VREF + 0.2 V)           |
|       |          |        | VDD    | 4                      | VREF = VDD                                                      |
|       |          |        | ARef   | 5                      | VREF = AREF                                                     |

#### 7.6.4.23 EXTREFSEL

Address offset: 0x50C External reference select



#### 7.6.4.24 TH

Address offset: 0x530

Threshold configuration for hysteresis unit



| Bit n | umber   |        | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------|-------------------|-----------------------------------------------------------------------|
| ID    |         |        |                   | B B B B B B A A A A A                                                 |
| Rese  | t 0x000 | 00000  | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |         |        |                   |                                                                       |
| Α     | RW      | THDOWN | [63:0]            | VDOWN = (THDOWN+1)/64*VREF                                            |
| В     | RW      | THUP   | [63:0]            | VUP = (THUP+1)/64*VREF                                                |

#### 7.6.4.25 MODE

Address offset: 0x534

Mode configuration

| Bit n | umber   |       |        | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|--------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |        |                         | В АА                                                            |
| Rese  | t 0x000 | 00000 |        | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |        |                         | Description                                                     |
| Α     | RW      | SP    |        |                         | Speed and power modes                                           |
|       |         |       | Low    | 0                       | Low-power mode                                                  |
|       |         |       | Normal | 1                       | Normal mode                                                     |
|       |         |       | High   | 2                       | High-speed mode                                                 |
| В     | RW      | MAIN  |        |                         | Main operation modes                                            |
|       |         |       | SE     | 0                       | Single-ended mode                                               |
|       |         |       | Diff   | 1                       | Differential mode                                               |

#### 7.6.4.26 HYST

Address offset: 0x538

Comparator hysteresis enable



#### 7.6.4.27 ISOURCE

Address offset: 0x53C

Current source select on analog input







# 7.6.5 Electrical specification

## 7.6.5.1 COMP Electrical Specification

| Symbol                     | Description                                          | Min. | Тур. | Max. | Units |
|----------------------------|------------------------------------------------------|------|------|------|-------|
| t <sub>PROPDLY,LP</sub>    | Propagation delay, Low-power mode <sup>8</sup>       |      | 0.6  |      | μs    |
| t <sub>PROPDLY,N</sub>     | Propagation delay, Normal mode <sup>8</sup>          |      | 0.2  |      | μs    |
| t <sub>PROPDLY,HS</sub>    | Propagation delay, High-speed mode <sup>8</sup>      |      | 0.1  |      | μs    |
| V <sub>DIFFHYST</sub>      | Optional hysteresis applied to differential input    | 26   | 35   | 55   | mV    |
| $V_{VDD\text{-}VREF}$      | Required difference between VDD and a selected VREF, | 0.3  |      |      | V     |
|                            | VDD > VREF                                           |      |      |      |       |
| t <sub>INT_REF,START</sub> | Startup time for the internal bandgap reference      |      | 50   | 80   | μs    |
| E <sub>INT_REF</sub>       | Internal bandgap reference error                     | -1.8 | 0    | 0.5  | %     |
| V <sub>INPUTOFFSET</sub>   | Input offset                                         | -10  |      | 10   | mV    |
| t <sub>COMP,START</sub>    | Startup time for the comparator core                 |      | 3    |      | μs    |

## 7.6.5.2 COMP Current Source (ISOURCE) Specification

Configurable current provided by the current source, excluding variations over temperature and voltage, at 3 V and 25°C. For other voltages and temperatures, the accuracy as specified by I<sub>SOURCE,ACC</sub> must be added to the min and max values.

| Symbol                  | Description                                          | Min. | Тур. | Max. | Units |
|-------------------------|------------------------------------------------------|------|------|------|-------|
| I <sub>SOURCE,A</sub>   | Current when register ISOURCE=Ien2mA5                | 1.6  | 2.4  | 3.3  | μΑ    |
| I <sub>SOURCE,B</sub>   | Current when register ISOURCE=Ien5mA                 | 3.2  | 4.9  | 6.5  | μΑ    |
| I <sub>SOURCE,C</sub>   | Current when register ISOURCE=Ien10mA                | 6.0  | 9.8  | 13.0 | μΑ    |
| I <sub>SOURCE,ACC</sub> | Current source accuracy over temperature and voltage |      | ±5%  |      | %     |

# 7.7 CRYPTOCELL — Arm TrustZone CryptoCell 312

Arm TrustZone CryptoCell 312 (CRYPTOCELL) is a security subsystem providing root of trust (RoT) and cryptographic services for a device.



 $<sup>^{\</sup>rm 8}\,$  Propagation delay is with 10 mV overdrive.



Figure 55: CRYPTOCELL block diagram

The following cryptographic features are provided:

- True random number generator (TRNG) compliant with NIST 800-90B, AIS-31, and FIPS 140-2
- Pseudorandom number generator (PRNG) using underlying AES engine compliant with NIST 800-90A
- RSA public key cryptography
  - Up to 3072-bit key size
  - PKCS#1 v2.1/v1.5
  - Optional CRT support
- Elliptic curve cryptography (ECC)
  - NIST FIPS 186-4 recommended prime field curves using pseudorandom parameters, up to 521 bits:
    - P-192
    - P-224
    - P-256
    - P-384
    - P-521
  - SEC 2 recommended prime field curves using pseudorandom parameters, up to 521 bits:
    - secp160r1
    - secp192r1
    - secp224r1
    - secp256r1
    - secp384r1
    - secp521r1

NORDIC SEMICONDUCTOR

- Koblitz prime field curves using fixed parameters, up to 256 bits:
  - secp160k1
  - secp192k1
  - secp224k1
  - secp256k1
- Edwards/Montgomery curves:
  - Ed25519
  - Curve25519
- ECDH/ECDSA support
- Secure remote password protocol (SRP) with up to 3072-bit operations
- · Hashing functions
  - SHA-1
  - SHA-2 up to 256 bits
  - Keyed-hash message authentication code (HMAC)
- · AES symmetric encryption
  - General purpose AES engine (encrypt/decrypt, sign/verify)
  - Supported key size 128 and 256 bits
  - Supported encryption modes: ECB, CBC, CMAC/CBC-MAC, CTR, CCM/CCM\*, GCM
- ChaCha20/Poly1305 symmetric encryption
  - Supported key size 128 and 256 bits
  - Authenticated encryption with associated data (AEAD) mode

## 7.7.1 Usage

The CRYPTOCELL state is controlled via a register interface. The CRYPTOCELL cryptographic functions are accessible through a software library provided in the device SDK.

To enable CRYPTOCELL, use register ENABLE on page 201.

**Note:** To prevent the device from reaching the System ON All Idle state, enable the CRYPTOCELL subsystem.

## 7.7.2 Direct memory access (DMA)

CRYPTOCELL features direct access memory (DMA) to allow cryptographic operations on memory mapped regions without involving the CPU.

The maximum DMA transaction size is limited to  $2^{16}$ -1 bytes. See Memory on page 19 for information about memory that is accessible through the CRYPTOCELL DMA.

The CRYPTOCELL DMA can configure the security setting used for bus transactions.

Any data stored in a memory type not accessible by the CRYPTOCELL DMA engine must be copied to a memory type accessible by the direct memory before it can be processed by the CRYPTOCELL subsystem.

#### 7.7.3 Standards

Arm TrustZone CryptoCell 312 (CRYPTOCELL) is compliant with the protocol specifications and standards shown in the following table.



| Algorithm family | Identification code    | Document title                                                                                                                   |
|------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| TRNG             | NIST SP 800-90B        | Recommendation for the Entropy Sources Used for Random Bit Generation                                                            |
|                  | AIS-31                 | A proposal for: Functionality classes and evaluation methodology for physical random number generators                           |
|                  | FIPS 140-2             | Security Requirements for Cryptographic Modules                                                                                  |
| PRNG             | NIST SP 800-90A        | Recommendation for Random Number Generation Using Deterministic Random Bit Generators                                            |
| Stream cipher    | Chacha                 | ChaCha, a variant of Salsa20, Daniel J. Bernstein, January 28th 2008                                                             |
| MAC              | Poly1305               | The Poly1305-AES message-authentication code, Daniel J. Bernstein                                                                |
|                  |                        | Cryptography in NaCl, Daniel J. Bernstein                                                                                        |
| Key agreement    | SRP                    | The Secure Remote Password Protocol, Thomas Wu, November 11th 1997                                                               |
| Key derivation   | NIST SP 800-108        | Recommendation for Key Derivation Using Pseudorandom Functions. Compliant with section 5.1                                       |
| AES              | FIPS-197               | Advanced Encryption Standard (AES). Compliant with 128-bit and 256-bit key size only                                             |
|                  | NIST SP 800-38A        | Recommendation for Block Cipher Modes of Operation - Methods and Techniques. Compliant with                                      |
|                  |                        | sections 6.1, 6.2, 6.4, and 6.5.                                                                                                 |
|                  | NIST SP 800-38B        | Recommendation for Block Cipher Modes of Operation: The CMAC Mode for Authentication                                             |
|                  | NIST SP 800-38C        | Recommendation for Block Cipher Modes of Operation: The CCM Mode for Authentication and                                          |
|                  |                        | Confidentiality                                                                                                                  |
|                  | ISO/IEC 9797-1         | AES CBC-MAC per ISO/IEC 9797-1 MAC algorithm 1                                                                                   |
|                  | IEEE 802.15.4-2011     | IEEE Standard for Local and metropolitan area networks - Part 15.4: Low-Rate Wireless Personal Area                              |
|                  |                        | Networks (LR-WPANs), Annex B.4: Specification of generic CCM* mode of operation                                                  |
| Hash             | FIPS 180-3             | Secure Hash Standard (SHA1, SHA-224, SHA-256)                                                                                    |
|                  | RFC2104                | HMAC: Keyed-Hashing for Message Authentication                                                                                   |
| RSA              | PKCS#1                 | Public-Key Cryptography Standards (PKCS) #1: RSA Cryptography Specifications v1.5/2.1                                            |
| Diffie-Hellman   | ANSI X9.42             | Public Key Cryptography for the Financial Services Industry: Agreement of Symmetric Keys Using Discrete                          |
|                  |                        | Logarithm Cryptography                                                                                                           |
|                  | PKCS#3                 | Diffie-Hellman Key-Agreement Standard                                                                                            |
| ECC              | ANSI X9.63             | Public Key Cryptography for the Financial Services Industry - Key Agreement and Key Transport Using  Elliptic Curve Cryptography |
|                  | IEEE 1363              | Standard Specifications for Public-Key Cryptography                                                                              |
|                  | ANSI X9.62             | Public Key Cryptography For The Financial Services Industry: The Elliptic Curve Digital Signature Algorithm                      |
|                  | 7.11.57.7.57.52        | (ECDSA)                                                                                                                          |
|                  | Ed25519                | Edwards-curve, Ed25519: high-speed high-security signatures, Daniel J. Bernstein, Niels Duif, Tanja Lange,                       |
|                  |                        | Peter Schwabe, and Bo-Yin Yang                                                                                                   |
|                  | Curve25519             | Montgomery curve, Curve25519: new Diffie-Hellman speed records, Daniel J. Bernstein                                              |
|                  | FIPS 186-4             | Digital Signature Standard (DSS). Compliant with sections 5.1, 6.2, 6.3, 6.4, B.1.2, B.2.2, B.3.6, B.4.2, C.3.1                  |
|                  |                        | C.3.3, C.3.5, C.9, and D.1.2.                                                                                                    |
|                  | SEC 2                  | Recommended Elliptic Curve Domain Parameters, Certicom Research                                                                  |
|                  | NIST SP 800-56A rev. 2 | Recommendation for Pair-Wise Key Establishment Schemes Using Discrete Logarithm Cryptography                                     |

Table 63: CRYPTOCELL cryptography standards

# 7.7.4 Registers

| Base address Domain    | Peripheral | Instance   | Secure mapping | DMA security | Description          | Configuration |
|------------------------|------------|------------|----------------|--------------|----------------------|---------------|
| 0x50844000 APPLICATION | CRYPTOCELL | CRYPTOCELL | S              | NSA          | CryptoCell subsystem |               |
|                        |            |            |                |              | control interface    |               |

Table 64: Instances

| Register | Offset | Security | Description                  |
|----------|--------|----------|------------------------------|
| ENABLE   | 0x500  |          | Enable CRYPTOCELL subsystem. |

Table 65: Register overview



#### 7.7.4.1 ENABLE

Address offset: 0x500

Enable CRYPTOCELL subsystem.



# 7.8 DCNF — Domain configuration

The domain configuration (DCNF) module provides a way to identify the CPU by its CPU ID in the device (CPUID). It also provides protection of the AHB multilayer interconnect (AMLI).

To provide for the AMLI protection, the DCNF contains configuration registers that can be used to block some paths from the AHB masters to their respective AHB slaves in the AMLI.

For an illustration of how the AHB masters and slaves are connected through the AMLI, see Memory on page 19.

#### 7.8.1 Protection

The DCNF protection involves blocking of paths from AHB masters in an external core to the AHB slaves in the local core's AMLI. This way, the local core's internal resources can be blocked from being accessed by an external core. A set of configuration registers is used to control this behavior.

See Memory on page 19 to get an overview of the AMLI.

The DCNF configuration registers that enable the DCNF protection are the following:

- EXTPERI[n].PROTECT
- EXTRAM[n].PROTECT
- EXTCODE[n].PROTECT

An attempt to access the blocked resources will trigger a BusFault or a HardFault exception, depending on the value of the BUSFAULTENA bit in the Arm Cortex-M33 SHCSR (system handler control and state register), described in the Arm Cortex-M33 Devices Generic User Guide.

#### RAM protection

The protection of RAM regions is configured through the SLAVE-bits of the corresponding master ports' register EXTRAM[n].PROTECT.

#### **Peripheral protection**

The protection of peripheral memory regions is configured through the SLAVE-bits of the corresponding master ports' register EXTPERI[n].PROTECT.



#### **Code protection**

The protection of code memory regions is configured through the SLAVE-bits of the corresponding master ports' register EXTCODE[0].PROTECT.

# 7.8.2 Registers

| Base address | Domain      | Peripheral | Instance | Secure mapping | DMA security | Description          | Configuration             |
|--------------|-------------|------------|----------|----------------|--------------|----------------------|---------------------------|
| 0x50000000   | APPLICATION | DCNE       | DCNF:S   | US             | NA           | Domain configuration | CPUID value is 0x00000000 |
| 0x40000000   | AFFLICATION | DCIVI      | DCNF: NS | 03             | NA.          | Domain comiguration  | Croid value is 0x00000000 |
| 0x41000000   | NETWORK     | DCNF       | DCNF     | NS             | NA           | Domain configuration | Registers                 |
|              |             |            |          |                |              |                      | EXTPERI[n].PROTECT,       |
|              |             |            |          |                |              |                      | EXTRAM[n].PROTECT, and    |
|              |             |            |          |                |              |                      | EXTCODE[n].PROTECT not    |
|              |             |            |          |                |              |                      | available for the network |
|              |             |            |          |                |              |                      | core.                     |
|              |             |            |          |                |              |                      | CPUID value is 0x00000001 |

Table 66: Instances

| Register           | Offset | Security | Description                                                         |
|--------------------|--------|----------|---------------------------------------------------------------------|
| CPUID              | 0x420  |          | CPU ID of this subsystem                                            |
| EXTPERI[n].PROTECT | 0x440  |          | Control access for master connected to AMLI master port EXTPERI[n]  |
| EXTRAM[n].PROTECT  | 0x460  |          | Control access from master connected to AMLI master port EXTRAM[n]  |
| EXTCODE[n].PROTECT | 0x480  |          | Control access from master connected to AMLI master port EXTCODE[n] |

Table 67: Register overview

#### 7.8.2.1 CPUID

Address offset: 0x420 CPU ID of this subsystem



## 7.8.2.2 EXTPERI[n].PROTECT (n=0..0)

Address offset:  $0x440 + (n \times 0x4)$ 

Control access for master connected to AMLI master port EXTPERI[n]





## 7.8.2.3 EXTRAM[n].PROTECT (n=0..0)

Address offset:  $0x460 + (n \times 0x4)$ 

Control access from master connected to AMLI master port EXTRAM[n]



#### 7.8.2.4 EXTCODE[n].PROTECT (n=0..0)

Address offset:  $0x480 + (n \times 0x4)$ 

Control access from master connected to AMLI master port EXTCODE[n]



# 7.9 DPPI — Distributed programmable peripheral interconnect

The distributed programmable peripheral interconnect (DPPI) enables peripherals to interact autonomously with each other by using tasks and events, without any intervention from the CPU. DPPI allows precise synchronization between peripherals when real-time application constraints exist, and eliminates the need for CPU involvement to implement behavior which can be predefined using the DPPI.

**Note:** For more information on tasks, events, publish/subscribe, interrupts, and other concepts, see Peripheral interface on page 150.

The DPPI has the following features:

- · Peripheral tasks can subscribe to channels
- Peripheral events can be published on channels
- Publish/subscribe pattern enabling multiple connection options that include the following:
  - One-to-one
  - · One-to-many
  - Many-to-one
  - Many-to-many

The DPPI consists of several PPIBus modules, which are connected to a fixed number of DPPI channels and a DPPI controller (DPPIC).





Figure 56: DPPI overview

## 7.9.1 Subscribing to and publishing on channels

The PPIBus can route peripheral events onto the channels (publishing), or route events from the channels into peripheral tasks (subscribing).

All peripherals include the following:

- One subscribe register per task
- One publish register per event

Publish and subscribe registers use a channel index field to determine the channel to which the event is published or tasks subscribed. In addition, there is an enable bit for the subscribe and publish registers that needs to be enabled before the subscription or publishing takes effect.

Writing non-existing channel index (CHIDX) numbers into a peripheral's publish or subscribe registers will yield unexpected results.

One event can trigger multiple tasks by subscribing different tasks to the same channel. Similarly, one task can be triggered by multiple events by publishing different events to the same channel. For advanced use cases, multiple events and multiple tasks can connect to the same channel forming a many-to-many connection. If multiple events are published on the same channel at the same time, the events are merged and only one event is routed through the DPPI.

How peripheral events are routed onto different channels based on publish registers is illustrated in the following figure.





Figure 57: DPPI events flow

The following figure illustrates how peripheral tasks are triggered from different channels based on subscribe registers.





Figure 58: DPPI tasks flow

## 7.9.2 DPPI controller (DPPIC)

Enabling and disabling of channels globally is handled through DPPIC. Connection (connect/disconnect) between a channel and a peripheral is handled locally by the PPIBus.

There are two ways of enabling and disabling global channels using DPPIC:

- Enable or disable channels individually using registers CHEN, CHENSET, and CHENCLR.
- Enable or disable channels in channel groups using the groups' tasks ENABLE and DISABLE. It needs to be defined which channels belong to which channel groups before these tasks are triggered.

**Note:** ENABLE tasks are prioritized over DISABLE tasks. When a channel belongs to two or more groups, for example group m and n, and the tasks CHG[m].EN and CHG[n].DIS occur simultaneously (m and n can be equal or different), the CHG[m].EN task on that channel is prioritized.

DPPIC tasks (for example CHG[0].EN) can be triggered through DPPI like any other task, which means they can be linked to a DPPI channel through the subscribe registers.

In order to write to CHG[x], the corresponding CHG[x].EN and CHG[x].DIS subscribe registers must be disabled. Writes to CHG[x] are ignored if any of the two subscribe registers are enabled.

# 7.9.3 Connection examples

DPPI offers several connection options. Examples are given for how to create one-to-one and many-to-many connections.



#### One-to-one connection

This example shows how to create a one-to-one connection between TIMER compare register and SAADC start task.

The channel configuration is set up first. TIMERO will publish its COMPAREO event on channel 0, and SAADC will subscribe its START task to events on the same channel. After that, the channel is enabled through the DPPIC.

#### Many-to-many connection

The example shows how to create a many-to-many connection, showcasing the DPPIC's channel group functionality.

A channel group that includes only channel 0 is set up first. Then the GPIOTE and TIMERO configure their INO and COMPAREO events respectively to be published on channel 0, while the SAADC configures its START task to subscribe to events on channel 0. Through DPPIC, the CHGO DISABLE task is configured to subscribe to events on channel 0. After an event is received on channel 0 it will be disabled. Finally, channel 0 is enabled using the DPPIC task to enable a channel group.

# 7.9.4 Special considerations for a system implementing TrustZone for Cortex-M processors

DPPI is implemented with split security, meaning it handles both secure and non-secure accesses. In a system implementing the TrustZone for Cortex-M technology, DPPI channels can be defined as secure or non-secure using the SPU.

A peripheral configured as non-secure will only be able to subscribe to or publish on non-secure DPPI channels. A peripheral configured as secure will be able to access all DPPI channels. DPPI handles both secure and non-secure accesses, but behaves differently depending on the access type:

• A non-secure peripheral access can only configure and control the DPPI channels defined as non-secure in the SPU.DPPI.PERM[] register(s)



A secure peripheral access can control all the DPPI channels, independently of the SPU.DPPI.PERM[]
register(s)

A group of channels can be created, making it possible to simultaneously enable or disable all channels within the group. The security attribute of a group of channels (secure or non-secure) is defined as follows:

- If all channels (enabled or not) within a group are non-secure, then the group is considered non-secure
- If at least one of the channels (enabled or not) within the group is secure, then the group is considered secure

A non-secure access to a DPPI register, or a bit field, controlling a channel marked as secure in SPU.DPPI[].PERM register(s) will be ignored. Write accesses will have no effect, and read accesses will always return a zero value.

No exceptions are triggered when non-secure accesses target a register or a bit field controlling a secure channel. For example, if the bit  $\pm$  is set in the SPU.DPPI[0].PERM register (declaring DPPI channel i as secure), then:

- Non-secure write accesses to registers CHEN, CHENSET, and CHENCLR cannot write bit  $\pm$  of these registers
- Non-secure write accesses to TASK\_CHG[j].EN and TASK\_CHG[j].DIS registers are ignored if the channel group j contains at least one channel defined as secure (it can be the channel i itself or any channel declared as secure)
- Non-secure read accesses to registers CHEN, CHENSET, and CHENCLR always read 0 for the bit at position  $\mathtt{i}$

For the channel configuration registers (CHG[]), access from non-secure code is only possible if the included channels are all non-secure, whether the channels are enabled or not. If a CHG[g] register included one or more secure channel(s), then the group g is considered as secure, and only secure transfers can read to or write from CHG[g]. A non-secure write access is ignored, and a non-secure read access returns 0.

The DPPI can subscribe to secure and non-secure channels through the SUBSCRIBE\_CHG[] registers, in order to trigger the task for enabling or disabling groups of channels. An event from a secure channel will be ignored if the group subscribing to this channel is non-secure. A secure group can subscribe to a non-secure channel or a secure channel.

## 7.9.5 Registers

| Base address Domain       | Peripheral | Instance   | Secure mapping | DMA security | Description       | Configuration        |
|---------------------------|------------|------------|----------------|--------------|-------------------|----------------------|
| 0x50017000<br>APPLICATION | N DPPIC    | DPPIC : S  | SPLIT          | NA           | DPPI controller   | 32 DPPI channels     |
| 0x40017000                | . 51110    | DPPIC : NS | 31 211         | 100          | Di i i controllei | 32 Di l'I Gildinicio |
| 0x4100F000 NETWORK        | DPPIC      | DPPIC      | NS             | NA           | DPPI controller   | 32 DPPI channels     |

Table 68: Instances



| Register             | Offset | Security | Description                                                                 |
|----------------------|--------|----------|-----------------------------------------------------------------------------|
| TASKS_CHG[n].EN      | 0x000  |          | Enable channel group n                                                      |
| TASKS_CHG[n].DIS     | 0x004  |          | Disable channel group n                                                     |
| SUBSCRIBE_CHG[n].EN  | 0x080  |          | Subscribe configuration for task CHG[n].EN                                  |
| SUBSCRIBE_CHG[n].DIS | 0x084  |          | Subscribe configuration for task CHG[n].DIS                                 |
| CHEN                 | 0x500  |          | Channel enable register                                                     |
| CHENSET              | 0x504  |          | Channel enable set register                                                 |
| CHENCLR              | 0x508  |          | Channel enable clear register                                               |
| CHG[n]               | 0x800  |          | Channel group n                                                             |
|                      |        |          | Note: Writes to this register are ignored if either SUBSCRIBE_CHG[n]. EN or |
|                      |        |          | SUBSCRIBE_CHG[n].DIS is enabled                                             |

Table 69: Register overview

## 7.9.5.1 TASKS\_CHG[n].EN (n=0..5)

Address offset:  $0x000 + (n \times 0x8)$ 

Enable channel group n



## 7.9.5.2 TASKS\_CHG[n].DIS (n=0..5)

Address offset:  $0x004 + (n \times 0x8)$ 

Disable channel group n



## 7.9.5.3 SUBSCRIBE\_CHG[n].EN (n=0..5)

Address offset:  $0x080 + (n \times 0x8)$ 

Subscribe configuration for task CHG[n].EN





## 7.9.5.4 SUBSCRIBE\_CHG[n].DIS (n=0..5)

Address offset:  $0x084 + (n \times 0x8)$ 

Subscribe configuration for task CHG[n].DIS



#### 7.9.5.5 CHEN

Address offset: 0x500 Channel enable register

| Bit n | umber   |               |          | 31 30 29 28 | 27 26 25 2 | 4 23 22 | 21 20  | 19 1  | 18 17 | ' 16 1 | 5 14 1 | 3 12 | 11 1 | 0 9        | 8 | 7 | 6 5 | 5 4 | 3 | 2 | 1 0 |
|-------|---------|---------------|----------|-------------|------------|---------|--------|-------|-------|--------|--------|------|------|------------|---|---|-----|-----|---|---|-----|
| ID    |         |               |          | f e d c     | b a Z '    | Y X W   | V U    | Т     | S R   | Q P    | 0      | N M  | L    | <b>(</b> J | 1 | Н | G F | E   | D | С | 3 A |
| Rese  | t 0x000 | 00000         |          | 0 0 0 0     | 0 0 0      | 0 0     | 0 0    | 0     | 0 0   | 0 0    | 0      | 0 0  | 0    | 0          | 0 | 0 | 0 0 | 0   | 0 | 0 | 0 0 |
| ID    |         |               |          |             |            |         |        |       |       |        |        |      |      |            |   |   |     |     |   |   |     |
| A-f   | RW      | CH[i] (i=031) |          |             |            | Enabl   | e or d | lisab | le ch | annel  | i      |      |      |            |   |   |     |     |   |   |     |
|       |         |               | Disabled | 0           |            | Disab   | le cha | nnel  | ı     |        |        |      |      |            |   |   |     |     |   |   |     |
|       |         |               | Enabled  | 1           |            | Enabl   | e chai | nnel  |       |        |        |      |      |            |   |   |     |     |   |   |     |

#### 7.9.5.6 CHENSET

Address offset: 0x504

Channel enable set register

Note: Read: Reads value of CH[i] field in CHEN register

| Bit n | umber   |               |          | 31 | L 30 | 29 | 28 2 | 27 2 | 6 25 | 24 | 23 | 22   | 21 2 | 20 1 | 9 1  | 8 17  | 7 16 | 15   | 14 : | .3 1  | 2 11 | l 10 | 9    | 8   | 7   | 6 5 | 5 4 | 3 | 2 | 1 0 |
|-------|---------|---------------|----------|----|------|----|------|------|------|----|----|------|------|------|------|-------|------|------|------|-------|------|------|------|-----|-----|-----|-----|---|---|-----|
| ID    |         |               |          | f  | е    | d  | С    | b a  | a Z  | Υ  | Χ  | W    | V    | U .  | T S  | s R   | Q    | Р    | 0    | N N   | 1 L  | K    | J    |     | Н   | G F | E   | D | С | в А |
| Rese  | t 0x000 | 00000         |          | 0  | 0    | 0  | 0    | 0 (  | 0    | 0  | 0  | 0    | 0    | 0 (  | 0 (  | 0     | 0    | 0    | 0    | 0 0   | 0    | 0    | 0    | 0   | 0   | 0 0 | 0   | 0 | 0 | 0 0 |
| ID    |         |               |          |    |      |    |      |      |      |    |    |      |      |      |      |       |      |      |      |       |      |      |      |     |     |     |     |   |   |     |
| A-f   | RW      | CH[i] (i=031) |          |    |      |    |      |      |      |    | Ch | ann  | el i | ena  | able | e set | reg  | iste | r. V | /riti | ng ( | ) ha | s no | eff | ect |     |     |   |   |     |
|       |         |               | Disabled | 0  |      |    |      |      |      |    | Re | ad:  | Cha  | ann  | el d | isab  | led  |      |      |       |      |      |      |     |     |     |     |   |   |     |
|       |         |               | Enabled  | 1  |      |    |      |      |      |    | Re | ad:  | Cha  | ann  | el e | nab   | led  |      |      |       |      |      |      |     |     |     |     |   |   |     |
|       |         |               | Set      | 1  |      |    |      |      |      |    | Wı | ite: | En   | able | e ch | ann   | iel  |      |      |       |      |      |      |     |     |     |     |   |   |     |

#### 7.9.5.7 CHENCLR

Address offset: 0x508

Channel enable clear register

Note: Read: Reads value of CH[i] field in CHEN register





#### 7.9.5.8 CHG[n] (n=0..5)

Address offset:  $0x800 + (n \times 0x4)$ 

Channel group n

Note: Writes to this register are ignored if either SUBSCRIBE\_CHG[n].EN or SUBSCRIBE\_CHG[n].DIS is enabled

| Bit nu | ımber |               |          | 31 30 29 28 | 3 27 26 | 25 2 | 24 23 2 | 2 21  | 20 1  | 9 18  | 17   | 16 15 | 5 14 | 13 1: | 2 11 | 10 | 9 8 | 3 7 | 6 | 5 | 4   | 3 2 | 1 | 0 |
|--------|-------|---------------|----------|-------------|---------|------|---------|-------|-------|-------|------|-------|------|-------|------|----|-----|-----|---|---|-----|-----|---|---|
| ID     |       |               |          | f e d c     | b a     | Z    | ΥXV     | N V   | U -   | ГЅ    | R    | Q P   | 0    | N N   | 1 L  | K  | J   | Н   | G | F | E I | ОС  | В | Α |
| Reset  | 0x000 | 00000         |          | 0 0 0 0     | 0 0     | 0    | 0 0 (   | 0 0   | 0 (   | 0 0   | 0    | 0 0   | 0    | 0 0   | 0    | 0  | 0 ( | 0   | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID     |       |               |          |             |         |      |         |       |       |       |      |       |      |       |      |    |     |     |   |   |     |     |   |   |
| A-f    | RW    | CH[i] (i=031) |          |             |         |      | Incl    | ude c | or ex | clude | e ch | anne  | el i |       |      |    |     |     |   |   |     |     |   |   |
|        |       |               | Excluded | 0           |         |      | Excl    | ude   |       |       |      |       |      |       |      |    |     |     |   |   |     |     |   |   |
|        |       |               | Included | 1           |         |      | Incl    | ude   |       |       |      |       |      |       |      |    |     |     |   |   |     |     |   |   |

# 7.10 ECB — AES electronic codebook mode encryption

The AES electronic codebook mode encryption (ECB) can be used for a range of cryptographic functions like hash generation, digital signatures, and keystream generation for data encryption/decryption. The ECB encryption block supports 128 bit AES encryption (encryption only, not decryption).

AES ECB operates with EasyDMA access to system Data RAM for in-place operations on cleartext and ciphertext during encryption. ECB uses the same AES core as the CCM and AAR blocks and is an asynchronous operation which may not complete if the AES core is busy.

#### **AES ECB features:**

- 128 bit AES encryption
- Supports standard AES ECB block encryption
- Memory pointer support
- · DMA data transfer

AES ECB performs a 128 bit AES block encrypt. At the STARTECB task, data and key is loaded into the algorithm by EasyDMA. When output data has been written back to memory, the ENDECB event is triggered.

AES ECB can be stopped by triggering the STOPECB task.

#### 7.10.1 Shared resources

The ECB, CCM, and AAR share the same AES module. The ECB will always have lowest priority and if there is a sharing conflict during encryption, the ECB operation will be aborted and an ERRORECB event will be generated.



## 7.10.2 EasyDMA

The ECB implements an EasyDMA mechanism for reading and writing to the Data RAM. This DMA cannot access the program memory or any other parts of the memory area except RAM.

If the ECBDATAPTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

The EasyDMA will have finished accessing the Data RAM when the ENDECB or ERRORECB is generated.

#### 7.10.3 ECB data structure

Input to the block encrypt and output from the block encrypt are stored in the same data structure. ECBDATAPTR should point to this data structure before STARTECB is initiated.

| Property   | Address offset | Description                         |
|------------|----------------|-------------------------------------|
| KEY        | 0              | 16 byte AES key                     |
| CLEARTEXT  | 16             | 16 byte AES cleartext input block   |
| CIPHERTEXT | 32             | 16 byte AES ciphertext output block |

Table 70: ECB data structure overview

## 7.10.4 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description           | Configuration |
|---------------------|------------|----------|----------------|--------------|-----------------------|---------------|
| 0x4100D000 NETWORK  | ECB        | ECB      | NS             | NA           | AES electronic code   |               |
|                     |            |          |                |              | book (ECB) mode block |               |
|                     |            |          |                |              | encryption            |               |

Table 71: Instances

| Register           | Offset | Security | Description                                                            |
|--------------------|--------|----------|------------------------------------------------------------------------|
| TASKS_STARTECB     | 0x000  |          | Start ECB block encrypt                                                |
| TASKS_STOPECB      | 0x004  |          | Abort a possible executing ECB operation                               |
| SUBSCRIBE_STARTECB | 0x080  |          | Subscribe configuration for task STARTECB                              |
| SUBSCRIBE_STOPECB  | 0x084  |          | Subscribe configuration for task STOPECB                               |
| EVENTS_ENDECB      | 0x100  |          | ECB block encrypt complete                                             |
| EVENTS_ERRORECB    | 0x104  |          | ECB block encrypt aborted because of a STOPECB task or due to an error |
| PUBLISH_ENDECB     | 0x180  |          | Publish configuration for event ENDECB                                 |
| PUBLISH_ERRORECB   | 0x184  |          | Publish configuration for event ERRORECB                               |
| INTENSET           | 0x304  |          | Enable interrupt                                                       |
| INTENCLR           | 0x308  |          | Disable interrupt                                                      |
| ECBDATAPTR         | 0x504  |          | ECB block encrypt memory pointers                                      |

Table 72: Register overview

#### 7.10.4.1 TASKS\_STARTECB

Address offset: 0x000 Start ECB block encrypt

If a crypto operation is already running in the AES core, the STARTECB task will not start a new encryption and an ERRORECB event will be triggered





#### 7.10.4.2 TASKS STOPECB

Address offset: 0x004

Abort a possible executing ECB operation

If a running ECB operation is aborted by STOPECB, the ERRORECB event is triggered.



## 7.10.4.3 SUBSCRIBE\_STARTECB

Address offset: 0x080

Subscribe configuration for task STARTECB

If a crypto operation is already running in the AES core, the STARTECB task will not start a new encryption and an ERRORECB event will be triggered



#### 7.10.4.4 SUBSCRIBE STOPECB

Address offset: 0x084

Subscribe configuration for task STOPECB

If a running ECB operation is aborted by STOPECB, the ERRORECB event is triggered.





### 7.10.4.5 EVENTS ENDECB

Address offset: 0x100

ECB block encrypt complete



## 7.10.4.6 EVENTS\_ERRORECB

Address offset: 0x104

ECB block encrypt aborted because of a STOPECB task or due to an error



#### 7.10.4.7 PUBLISH\_ENDECB

Address offset: 0x180

Publish configuration for event ENDECB





# 7.10.4.8 PUBLISH\_ERRORECB

Address offset: 0x184

Publish configuration for event ERRORECB

| Bit n            | 3it number                                   |                 | 31 30 29 28 27 26 25 24                 | 1 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                                   |
|------------------|----------------------------------------------|-----------------|-----------------------------------------|-----------------------------------------------------------------|---------------------------------------------------|
| ID               | <u>.                                    </u> |                 | В                                       | A A A A A A A                                                   |                                                   |
| Reset 0x00000000 |                                              | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                 |                                                   |
| ID               |                                              |                 |                                         |                                                                 | Description                                       |
| Α                | RW                                           | CHIDX           |                                         | [2550]                                                          | DPPI channel that event ERRORECB will publish to. |
| В                | RW                                           | EN              |                                         |                                                                 |                                                   |
|                  |                                              |                 | Disabled                                | 0                                                               | Disable publishing                                |
|                  |                                              |                 | Enabled                                 | 1                                                               | Enable publishing                                 |

#### 7.10.4.9 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | Bit number       |          |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|----------|----------|-------------------------|-----------------------------------------------------------------|--|--|--|
| ID    |                  |          |          |                         | B A                                                             |  |  |  |
| Rese  | Reset 0x00000000 |          |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |
| ID    |                  |          |          |                         |                                                                 |  |  |  |
| Α     | RW               | ENDECB   |          |                         | Write '1' to enable interrupt for event ENDECB                  |  |  |  |
|       |                  |          | Set      | 1                       | Enable                                                          |  |  |  |
|       |                  |          | Disabled | 0                       | Read: Disabled                                                  |  |  |  |
|       |                  |          | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |
| В     | RW               | ERRORECB |          |                         | Write '1' to enable interrupt for event ERRORECB                |  |  |  |
|       |                  |          | Set      | 1                       | Enable                                                          |  |  |  |
|       |                  |          | Disabled | 0                       | Read: Disabled                                                  |  |  |  |
|       |                  |          | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |

#### 7.10.4.10 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | Bit number       |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|--------|----------|-------------------------|-----------------------------------------------------------------|--|--|--|
| ID    | ID               |        |          |                         | ВА                                                              |  |  |  |
| Rese  | Reset 0x00000000 |        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |  |  |  |
| ID    |                  |        |          |                         |                                                                 |  |  |  |
| Α     | RW               | ENDECB |          |                         | Write '1' to disable interrupt for event ENDECB                 |  |  |  |
|       |                  |        | Clear    | 1                       | Disable                                                         |  |  |  |
|       |                  |        | Disabled | 0                       | Read: Disabled                                                  |  |  |  |
|       |                  |        | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |
| В     | B RW ERRORECB    |        |          |                         | Write '1' to disable interrupt for event ERRORECB               |  |  |  |
|       |                  |        | Clear    | 1                       | Disable                                                         |  |  |  |
|       |                  |        | Disabled | 0                       | Read: Disabled                                                  |  |  |  |
|       |                  |        | Enabled  | 1                       | Read: Enabled                                                   |  |  |  |



#### 7.10.4.11 ECBDATAPTR

Address offset: 0x504

ECB block encrypt memory pointers



## 7.10.5 Electrical specification

#### 7.10.5.1 ECB Electrical Specification

| Symbol           | Description                             | Min. | Тур. | Max. | Units |
|------------------|-----------------------------------------|------|------|------|-------|
| t <sub>ECB</sub> | Run time per 16 byte block in all modes |      |      | 6.2  | μs    |

# 7.11 EGU — Event generator unit

Event generator unit (EGU) provides support for interlayer signaling. This means providing support for atomic triggering of both CPU execution and hardware tasks, from both firmware (by CPU) and hardware (by PPI). This feature can, for instance, be used for triggering CPU execution at a lower priority execution from a higher priority execution, or to handle a peripheral's interrupt service routine (ISR) execution at a lower priority for some of its events. However, triggering any priority from any priority is possible.

Listed here are the main EGU features:

- Software-enabled interrupt triggering
- Separate interrupt vectors for every EGU instance
- Up to 16 separate event flags per interrupt for multiplexing

Each instance of EGU implements a set of tasks which can individually be triggered to generate the corresponding event, for example, the corresponding event for TASKS\_TRIGGER[n] is EVENTS\_TRIGGERED[n]. See Instances on page 217 for a list of EGU instances.



# 7.11.1 Registers

| Base address Domain    | Peripheral | Instance  | Secure mapping | DMA security | Description            | Configuration |
|------------------------|------------|-----------|----------------|--------------|------------------------|---------------|
| 0x5001B000<br>APPLICAT | ION EGII   | EGU0: S   | US             | NA           | Event generator unit 0 |               |
| 0x4001B000             | 1014 200   | EGU0 : NS | 03             | NA.          | Event generator unit o |               |
| 0x5001C000<br>APPLICAT | ION ECLI   | EGU1:S    | US             | NA           | Event generator unit 1 |               |
| 0x4001C000             | ION EGO    | EGU1 : NS | 03             | NA           | Event generator unit 1 |               |
| 0x5001D000<br>APPLICAT | ION EGII   | EGU2 : S  | US             | NA           | Event generator unit 2 |               |
| 0x4001D000             | ION EGO    | EGU2 : NS | 03             | NA .         | Event generator unit 2 |               |
| 0x5001E000 APPLICAT    | ION EGII   | EGU3:S    | US             | NA           | Event generator unit 3 |               |
| 0x4001E000             | ION EGO    | EGU3 : NS | 03             | NA .         | Event generator unit 3 |               |
| 0x5001F000<br>APPLICAT | ION EGII   | EGU4:S    | US             | NA           | Event generator unit 4 |               |
| 0x4001F000             | ION EGO    | EGU4 : NS | 03             | NA .         | Event generator unit 4 |               |
| 0x50020000 APPLICAT    | ION EGII   | EGU5 : S  | US             | NA           | Event generator unit 5 |               |
| 0x40020000             | IOIV LOO   | EGU5 : NS | 03             | NO.          | Event generator unit 3 |               |
| 0x41014000 NETWOR      | K EGU      | EGU0      | NS             | NA           | Event generator unit 0 |               |

Table 73: Instances

| Register             | Offset | Security | Description                                                              |
|----------------------|--------|----------|--------------------------------------------------------------------------|
| TASKS_TRIGGER[n]     | 0x000  |          | Trigger n for triggering the corresponding TRIGGERED[n] event            |
| SUBSCRIBE_TRIGGER[n] | 0x080  |          | Subscribe configuration for task TRIGGER[n]                              |
| EVENTS_TRIGGERED[n]  | 0x100  |          | Event number n generated by triggering the corresponding TRIGGER[n] task |
| PUBLISH_TRIGGERED[n] | 0x180  |          | Publish configuration for event TRIGGERED[n]                             |
| INTEN                | 0x300  |          | Enable or disable interrupt                                              |
| INTENSET             | 0x304  |          | Enable interrupt                                                         |
| INTENCLR             | 0x308  |          | Disable interrupt                                                        |

Table 74: Register overview

## 7.11.1.1 TASKS\_TRIGGER[n] (n=0..15)

Address offset:  $0x000 + (n \times 0x4)$ 

Trigger n for triggering the corresponding TRIGGERED[n] event



## 7.11.1.2 SUBSCRIBE\_TRIGGER[n] (n=0..15)

Address offset:  $0x080 + (n \times 0x4)$ 

Subscribe configuration for task TRIGGER[n]





## 7.11.1.3 EVENTS\_TRIGGERED[n] (n=0..15)

Address offset:  $0x100 + (n \times 0x4)$ 

Event number n generated by triggering the corresponding TRIGGER[n] task



### 7.11.1.4 PUBLISH\_TRIGGERED[n] (n=0..15)

Address offset:  $0x180 + (n \times 0x4)$ 

Publish configuration for event TRIGGERED[n]

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                      | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                        |                                                                 |
| Α     | RW      | CHIDX |          | [255 0]                | DDDI share all that accept TDICCEDED[s] will such lish to       |
|       | LVA     | CHIDX |          | [2550]                 | DPPI channel that event TRIGGERED[n] will publish to.           |
| В     | RW      | EN    |          | [2550]                 | DPPI channel that event TRIGGERED[n] will publish to.           |
| В     |         |       | Disabled | 0                      | Disable publishing                                              |

### 7.11.1.5 INTEN

Address offset: 0x300

Enable or disable interrupt





#### **7.11.1.6 INTENSET**

Address offset: 0x304

**Enable interrupt** 



#### **7.11.1.7 INTENCLR**

Address offset: 0x308

Disable interrupt



## 7.11.2 Electrical specification

### 7.11.2.1 EGU Electrical Specification

| Symbol               | Description                                              | Min. | Тур. | Max. | Units  |
|----------------------|----------------------------------------------------------|------|------|------|--------|
| t <sub>EGU,EVT</sub> | Latency between setting an EGU event flag and the system |      | 1    |      | cycles |
|                      | setting an interrupt                                     |      |      |      |        |

# 7.12 FPU — Floating point unit (FPU) exceptions

The Arm Cortex-M33 has FPU signals that indicate mathematical errors that cause floating-point exceptions.

The FPU signals are routed to the following event registers:

FPUIOC: INVALIDOPERATION

• FPUIDC: DENORMALINPUT

FPUOFC: OVERFLOW

FPUUFC: UNDERFLOW

FPUDZC: DIVIDEBYZERO

• FPUIXC: INEXACT



To clear the FPU exception source, write a 0 to the Arm Cortex-M33 FPSCR (floating-point status control register), as described in the *Arm Cortex-M33 Devices Generic User Guide*.

# 7.12.1 Registers

| Base address Domain       | Peripheral | Instance | Secure mapping | DMA security | Description         | Configuration |
|---------------------------|------------|----------|----------------|--------------|---------------------|---------------|
| 0x50000000<br>APPLICATION | I EDII     | FPU:S    | US             | NA           | Floating Point unit |               |
| 0x40000000                | N FFU      | FPU: NS  | 03             | NA           | interrupt control   |               |

Table 75: Instances

| Register                | Offset | Security | Description                                                                          |
|-------------------------|--------|----------|--------------------------------------------------------------------------------------|
| EVENTS_INVALIDOPERATION | 0x100  |          | An FPUIOC exception triggered by an invalid operation has occurred in the FPU        |
| EVENTS_DIVIDEBYZERO     | 0x104  |          | An FPUDZC exception triggered by a floating-point divide-by-zero operation has       |
|                         |        |          | occurred in the FPU                                                                  |
| EVENTS_OVERFLOW         | 0x108  |          | An FPUOFC exception triggered by a floating-point overflow has occurred in the FPU   |
| EVENTS_UNDERFLOW        | 0x10C  |          | An FPUUFC exception triggered by a floating-point underflow has occurred in the FPU  |
| EVENTS_INEXACT          | 0x110  |          | An FPUIXC exception triggered by an inexact floating-point operation has occurred in |
|                         |        |          | the FPU                                                                              |
| EVENTS_DENORMALINPUT    | 0x114  |          | An FPUIDC exception triggered by a denormal floating-point input has occurred in the |
|                         |        |          | FPU                                                                                  |
| INTEN                   | 0x300  |          | Enable or disable interrupt                                                          |
| INTENSET                | 0x304  |          | Enable interrupt                                                                     |
| INTENCLR                | 0x308  |          | Disable interrupt                                                                    |

Table 76: Register overview

### 7.12.1.1 EVENTS\_INVALIDOPERATION

Address offset: 0x100

An FPUIOC exception triggered by an invalid operation has occurred in the FPU



## 7.12.1.2 EVENTS\_DIVIDEBYZERO

Address offset: 0x104

An FPUDZC exception triggered by a floating-point divide-by-zero operation has occurred in the FPU





### 7.12.1.3 EVENTS OVERFLOW

Address offset: 0x108

An FPUOFC exception triggered by a floating-point overflow has occurred in the FPU



### 7.12.1.4 EVENTS UNDERFLOW

Address offset: 0x10C

An FPUUFC exception triggered by a floating-point underflow has occurred in the FPU



### 7.12.1.5 EVENTS INEXACT

Address offset: 0x110

An FPUIXC exception triggered by an inexact floating-point operation has occurred in the FPU





## 7.12.1.6 EVENTS\_DENORMALINPUT

Address offset: 0x114

An FPUIDC exception triggered by a denormal floating-point input has occurred in the FPU



### 7.12.1.7 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit n | umber    |                  |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                  |          |                         | FEDCBA                                                          |
| Rese  | et 0x000 | 00000            |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                  |          |                         |                                                                 |
| Α     | RW       | INVALIDOPERATION |          |                         | Enable or disable interrupt for event INVALIDOPERATION          |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
| В     | RW       | DIVIDEBYZERO     |          |                         | Enable or disable interrupt for event DIVIDEBYZERO              |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
| С     | RW       | OVERFLOW         |          |                         | Enable or disable interrupt for event OVERFLOW                  |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
| D     | RW       | UNDERFLOW        |          |                         | Enable or disable interrupt for event UNDERFLOW                 |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
| E     | RW       | INEXACT          |          |                         | Enable or disable interrupt for event INEXACT                   |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
| F     | RW       | DENORMALINPUT    |          |                         | Enable or disable interrupt for event DENORMALINPUT             |
|       |          |                  | Disabled | 0                       | Disable                                                         |
|       |          |                  | Enabled  | 1                       | Enable                                                          |
|       |          |                  |          |                         |                                                                 |

### 7.12.1.8 INTENSET

Address offset: 0x304

**Enable interrupt** 



Write '1' to enable interrupt for event INVALIDOPERATION



| Bit r | number   |               |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|------------------------|------------------------------------------------------------------|
| ID    |          |               |          |                        | F E D C B A                                                      |
| Res   | et 0x000 | 00000         |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |          |               |          |                        |                                                                  |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| В     | RW       | DIVIDEBYZERO  |          |                        | Write '1' to enable interrupt for event DIVIDEBYZERO             |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| С     | RW       | OVERFLOW      |          |                        | Write '1' to enable interrupt for event OVERFLOW                 |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| D     | RW       | UNDERFLOW     |          |                        | Write '1' to enable interrupt for event UNDERFLOW                |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| Ε     | RW       | INEXACT       |          |                        | Write '1' to enable interrupt for event INEXACT                  |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| F     | RW       | DENORMALINPUT |          |                        | Write '1' to enable interrupt for event DENORMALINPUT            |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
|       |          |               |          |                        |                                                                  |

### 7.12.1.9 INTENCLR

Address offset: 0x308

Disable interrupt

| umber   |                  |                              | 31 30 29 28 27 26 25 2                                                                                                                                                                                                  | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                  |                              |                                                                                                                                                                                                                         | FEDCBA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| t 0x000 | 00000            |                              | 0 0 0 0 0 0 0                                                                                                                                                                                                           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                  |                              |                                                                                                                                                                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| RW      | INVALIDOPERATION |                              |                                                                                                                                                                                                                         | Write '1' to disable interrupt for event INVALIDOPERATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                  | Clear                        | 1                                                                                                                                                                                                                       | Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                  | Disabled                     | 0                                                                                                                                                                                                                       | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                  | Enabled                      | 1                                                                                                                                                                                                                       | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RW      | DIVIDEBYZERO     |                              |                                                                                                                                                                                                                         | Write '1' to disable interrupt for event DIVIDEBYZERO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|         |                  | Clear                        | 1                                                                                                                                                                                                                       | Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                  | Disabled                     | 0                                                                                                                                                                                                                       | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                  | Enabled                      | 1                                                                                                                                                                                                                       | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RW      | OVERFLOW         |                              |                                                                                                                                                                                                                         | Write '1' to disable interrupt for event OVERFLOW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |                  | Clear                        | 1                                                                                                                                                                                                                       | Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                  | Disabled                     | 0                                                                                                                                                                                                                       | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                  | Enabled                      | 1                                                                                                                                                                                                                       | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RW      | UNDERFLOW        |                              |                                                                                                                                                                                                                         | Write '1' to disable interrupt for event UNDERFLOW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         |                  | Clear                        | 1                                                                                                                                                                                                                       | Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                  | Disabled                     | 0                                                                                                                                                                                                                       | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                  | Enabled                      | 1                                                                                                                                                                                                                       | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | R/W RW RW        | RW DIVIDEBYZERO  RW OVERFLOW | RW DIVIDEBYZERO  RW OVERFLOW  Clear Disabled Enabled  RW Dividebyzero  Clear Disabled Enabled  RW OVERFLOW  Clear Disabled Enabled  RW OVERFLOW  Clear Disabled Enabled  Clear Disabled Enabled  Clear Disabled Enabled | RW DIVIDEBYZERO  Clear 1  Enabled 0  Enabled 1  Clear 1  Disabled 0  Enabled 1  Clear 1  Disabled 0  Enabled 1  RW OVERFLOW  Clear 1  Disabled 0  Enabled 1  RW OVERFLOW  Clear 1  Disabled 0  Enabled 0 |



| Bit num | nber  |               |          | 31 | 30 | 29 2 | 8 27 | 7 26 : | 25 2 | 4 2 | 3 2: | 2 21  | 20 1  | 19 : | L8 1 | 7 10 | 5 15 | 14   | 13    | 12  | 11 1  | 9   | 8  | 7   | 6   | 5 4 | 4 3 | 2 | 1 0 |
|---------|-------|---------------|----------|----|----|------|------|--------|------|-----|------|-------|-------|------|------|------|------|------|-------|-----|-------|-----|----|-----|-----|-----|-----|---|-----|
| ID      |       |               |          |    |    |      |      |        |      |     |      |       |       |      |      |      |      |      |       |     |       |     |    |     |     | F   | E D | С | ВА  |
| Reset 0 | 0x000 | 00000         |          | 0  | 0  | 0 0  | 0    | 0      | 0 (  | ) ( | 0 0  | 0     | 0     | 0    | 0 (  | 0 0  | 0    | 0    | 0     | 0   | 0 0   | 0   | 0  | 0   | 0   | 0 ( | 0 0 | 0 | 0 0 |
| ID F    |       |               |          |    |    |      |      |        |      |     |      |       |       |      |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
| E F     | RW    | INEXACT       |          |    |    |      |      |        |      | ٧   | Vrit | e '1' | to c  | lisa | ble  | inte | erru | pt   | for ( | eve | nt IN | EXA | CT |     |     |     |     |   |     |
|         |       |               | Clear    | 1  |    |      |      |        |      | D   | isa  | ble   |       |      |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
|         |       |               | Disabled | 0  |    |      |      |        |      | R   | eac  | d: Di | sabl  | ed   |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
|         |       |               | Enabled  | 1  |    |      |      |        |      | R   | eac  | d: Er | nable | ed   |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
| F F     | RW    | DENORMALINPUT |          |    |    |      |      |        |      | ٧   | Vrit | e '1' | to c  | lisa | ble  | inte | erru | pt i | for ( | eve | nt DI | ENO | RM | ALI | NPl | JT  |     |   |     |
|         |       |               | Clear    | 1  |    |      |      |        |      | D   | isal | ble   |       |      |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
|         |       |               | Disabled | 0  |    |      |      |        |      | R   | eac  | d: Di | sabl  | ed   |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |
|         |       |               | Enabled  | 1  |    |      |      |        |      | R   | eac  | d: Er | nable | ed   |      |      |      |      |       |     |       |     |    |     |     |     |     |   |     |

# 7.13 GPIO — General purpose input/output

The general purpose input/output pins (GPIOs) are grouped as one or more ports with each port having up to 32 GPIOs.

The number of ports and GPIOs per port may vary with product variant and package. Refer to Registers on page 230 and Pin assignments on page 790 for more information about the number of GPIOs that are supported.

GPIO has the following user-configurable features:

- Up to 32 GPIO pins per GPIO port
- · Configurable output drive strength
- Internal pull-up and pull-down resistors
- Wake-up from high or low level triggers on all pins
- Trigger interrupt on state changes on any pin
- All pins can be used by the PPI task/event system
- One or more GPIO outputs can be controlled through PPI and GPIOTE channels
- All pins can be individually mapped to interface blocks for layout flexibility
- GPIO state changes captured on SENSE signal can be stored by LATCH register
- Pin sharing in multi-MCU system
- Support for secure and non-secure attributes for pins in conjunction with the system protection unit (SPU System protection unit on page 590)

GPIO port and the GPIO pin details on page 225 illustrates the GPIO port containing 32 individual pins, where PINO is illustrated in more detail as a reference. All signals on the left side in the illustration are used by other peripherals in the system and therefore not directly available to the CPU.





Figure 59: GPIO port and the GPIO pin details

### 7.13.1 Assigning pins between cores, peripherals, or subsystems

GPIO pins of the system can be allocated among the cores, peripherals with dedicated pins, or subsystems such as trace and debug.

The pins of the system are listed in Pin assignments on page 790.

A pin can be assigned to any of the following:

- · Application core
- Network core
- · Peripheral with dedicated pins
- · Trace and debug (TaD) subsystem

By default, all pins are assigned to the application core. The application core's MCUSEL bitfield in register PIN\_CNF[n] (n=0..31) (Retained) on page 233 controls the allocation of the pins into cores, peripherals and the TaD subsystem.

The pin's state, being either an output, input, or analog, can only be controlled and observed by the core for which the pin was allocated. Reading a pin that is not allocated to the current core will return zero, and writes will be ignored. If a pin is allocated to a subsystem that cannot access it, the pin stays under control of the application core's GPIO peripheral.

The GPIO peripheral of any core has its own set of registers that can be read and written independently, but they only affect a pin when it has been allocated to this core. Reading the GPIO peripheral registers of one core does not reveal the register contents of a different core.

The following figure illustrates how to assign a pin to a core, to a peripheral that has dedicated pins, or a subsystem such as trace and debug.





Figure 60: Pin allocation in multiple-core system

**Note:** To avoid glitches, changing the MCUSEL bitfield for a pin should only occur when the pin is disabled.

Also note that when a pin p is not assigned to the application core, the application core's GPIO LATCH register, PIN\_CNF[p].MCUSEL bitfield, and PIN\_CNF[p].SENSE bitfield is prevented. For these, any write operations are ignored, and any read operation will return 0.

# 7.13.2 Pin configuration

The GPIO port peripheral implements up to 32 pins, PIN0 through PIN31. Each of these pins can be individually configured in the PIN\_CNF[n] registers (n=0..31).

**Note:** For more information on pin assignment and the corresponding effect of read and write operations of GPIO registers, see Assigning pins between cores, peripherals, or subsystems on page 225.

The following parameters can be configured through these registers:

- Direction
- Drive strength
- Enabling of pull-up and pull-down resistors
- Pin sensing
- Input buffer disconnect
- Analog input (for selected pins)

**Note:** All write-capable registers are retained registers, see POWER — Power control on page 46 for more information.



The input buffer of a GPIO pin can be disconnected from the pin to enable power savings when the pin is not used as an input, see GPIO port and the GPIO pin details on page 225. Inputs must be connected to get a valid input value in the IN register, and for the sense mechanism to get access to the pin.

Other peripherals in the system can connect to GPIO pins and override their output value and configuration, or read their analog or digital input value. See GPIO port and the GPIO pin details on page 225.

Selected pins also support analog input signals, see ANAIN in GPIO port and the GPIO pin details on page 225. The assignment of the analog pins can be found in Pin assignments on page 790.

The drive strength is configured using the DRIVE field of register PIN\_CNF[n] (n=0..31) (Retained) on page 233. Some pins may not support every drive configuration, see Pin assignments on page 790 for more information.

The following delays should be taken into considerations:

- There is a delay of 2 CPU clock cycles from the GPIO pad to the IN register.
- The GPIO pad must be low (or high depending on the SENSE polarity) for 3 CPU clock cycles after DETECT has gone high to generate a new DETECT signal.

**Note:** When a pin is configured as digital input, care has been taken to minimize increased current consumption when the input voltage is between  $V_{IL}$  and  $V_{IH}$ . However, it is a good practice to ensure that the external circuitry does not drive that pin to levels between  $V_{IL}$  and  $V_{IH}$  for a long period of time.

#### 7.13.3 Pin sense mechanism

Pins sensitivity can be individually configured, through the SENSE field in the PIN\_CNF[n] register, to detect either a high level or a low level on their input.

**Note:** Refer to Assigning pins between cores, peripherals, or subsystems on page 225 for pin assignment and corresponding effect of read and write operations of GPIO registers

When the correct level is detected on any such configured pin, the sense mechanism will set the DETECT signal high. Each pin has a separate DETECT signal. Default behavior, defined by the DETECTMODE register, is that the DETECT signals from all pins in the GPIO port are combined into one common DETECT signal that is routed throughout the system, which then can be utilized by other peripherals. This mechanism is functional in both System ON and System OFF modes.

DETECTMODE and DETECTMODE\_SEC are provided to handle secure and non-secure pins.

DETECTMODE\_SEC register is available to control the behavior associated to pin marked as secure, while the DETECTMODE register is restricted to pin marked as non-secure. Please refer to GPIO security on page 228 for more details.

Make sure that a pin is in a level that cannot trigger the sense mechanism before enabling it. The DETECT signal will go high immediately if the SENSE condition configured in the PIN\_CNF registers is met when the sense mechanism is enabled. This will trigger a PORT event if the DETECT signal was low before enabling the sense mechanism.

The DETECT signal is also used by power and clock management system to exit from System OFF mode, and by GPIOTE to generate the PORT event. In addition GPIOTE\_SEC is used for PORT event related to secure pins). See POWER — Power control on page 46 and GPIOTE — GPIO tasks and events on page 235 for more information about how the DETECT signal is used.

When a pin's PINx.DETECT signal goes high, a flag will be set in the LATCH register. For example, when the PINO.DETECT signal goes high, bit 0 in the LATCH register will be set to '1'. If the CPU performs a clear operation on a bit in the LATCH register when the associated PINx.DETECT signal is high, the bit in the LATCH register will only be cleared if the CPU explicitly clears it by



writing a '1' to the bit that shall be cleared, i.e. the LATCH register will not be affected by a PINx.DETECT signal being set low.

The LDETECT signal will be set high when one or more bits in the LATCH register are '1'. The LDETECT signal will be set low when all bits in the LATCH register are successfully cleared to '0'.

If one or more bits in the LATCH register are '1' after the CPU has performed a clear operation on the LATCH registers, a rising edge will be generated on the LDETECT signal. This is illustrated in DETECT signal behavior on page 228.

**Note:** The CPU can read the LATCH register at any time to check if a SENSE condition has been met on one or more of the the GPIO pins, even if that condition is no longer met at the time the CPU queries the LATCH register. This mechanism will work even if the LDETECT signal is not used as the DETECT signal.

The LDETECT signal is by default not connected to the GPIO port's DETECT signal, but via the DETECTMODE register it is possible to change from default behavior to DETECT signal being derived directly from the LDETECT signal instead. See GPIO port and the GPIO pin details on page 225. DETECT signal behavior on page 228 illustrates the DETECT signal behavior for these two alternatives.



Figure 61: DETECT signal behavior

### 7.13.4 GPIO security

The general purpose input/output (GPIO) peripheral is implemented as a *split-security* peripheral. If marked as non-secure, it can be accessed by both secure and non-secure accesses but will behave differently depending on the access type.

**Note:** For more information on pin assignment and the corresponding effect of read and write operations of GPIO registers, see Assigning pins between cores, peripherals, or subsystems on page 225.

A non-secure peripheral access will only be able to configure and control pins defined as non-secure in the system protection unit (SPU) GPIOPORT.PERM[] register(s).

NORDIC

A non-secure access to a register or a bitfield controlling a pin marked as secure in GPIO.PERM[] register(s) will be ignored. Write access will have no effect and read access will return a zero value.

No exception is triggered when a non-secure access targets a register or bitfield controlling a secure pin. For example, if the bit  $\pm$  is set in the SPU.GPIO.PERM[0] register (declaring Pin P0. $\pm$  as secure), then

- non-secure write accesses to OUT, OUTSET, OUTCLR, DIR, DIRSET, DIRCLR and LATCH registers will not be able to write to bit i of those registers
- non-secure write accesses to registers PIN[i].OUT and PIN\_CNF[i] will be ignored
- non-secure read accesses to registers OUT, OUTSET, OUTCLR, IN, DIR, DIRSET, DIRCLR and LATCH will always read a '0' for the bit at position  $\dot{\text{1}}$
- non-secure read accesses to registers PIN[i].OUT, PIN[i].OUT and PIN CNF[i] will always return 0

The GPIO.DETECTMODE and GPIO.DETECTMODE\_SEC registers are handled differently than the other registers mentioned before. When accessed by a secure access, the DETECTMODE\_SEC register control the source for the DETECT\_SEC signal for the pins marked as secure. When accessed by a non-secure access, the DETECTMODE\_SEC is read as zero and write accesses are ignored. The GPIO.DETECTMODE register controls the source for the DETECT\_NSEC signal for the pins defined as non-secure.

The DETECT\_NSEC signal is routed to the GPIOTE peripheral, allowing generation of events and interrupts from pins marked as non-secure. The DETECT\_SEC signal is routed to the GPIOTESEC peripheral, allowing generation of events and interrupts from pins marked as secure. Principle of direct pin access on page 229 illustrates how the DETECT\_NSEC and DETECT\_SEC signals are generated from the GPIO PIN[].DETECT signals.



Figure 62: Principle of direct pin access



# 7.13.5 Registers

| Base address | Domain      | Peripheral | Instance | Secure mapping | DMA security | Description               | Configuration  |
|--------------|-------------|------------|----------|----------------|--------------|---------------------------|----------------|
| 0x50842500   | APPLICATION | CDIO       | P0 : S   | SPLIT          | NA           | General purpose input and | P0.00 to P0.31 |
| 0x40842500   | APPLICATION | GPIO       | P0 : NS  | SPLII          |              | output, port 0            | implemented    |
| 0x50842800   | ADDUCATION  | CNO        | P1:S     | SPLIT          |              | General purpose input and | P1.00 to P1.15 |
| 0x40842800   | APPLICATION | GPIO       | P1 : NS  | SPLII          | NA           | output, port 1            | implemented    |
| 0x418C0500   | NETWORK     | GPIO       | P0       | NS             | NA           | General purpose input and | P0.00 to P0.31 |
|              |             |            |          |                |              | output                    | implemented    |
| 0x418C0800   | NETWORK     | GPIO       | P1       | NS             | NA           | General purpose input and | P1.00 to P1.15 |
|              |             |            |          |                |              | output                    | implemented    |

Table 77: Instances

| Register       | Offset | Security | Description                                                                    |          |
|----------------|--------|----------|--------------------------------------------------------------------------------|----------|
| OUT            | 0x004  |          | Write GPIO port                                                                | Retained |
| OUTSET         | 0x008  |          | Set individual bits in GPIO port                                               |          |
| OUTCLR         | 0x00C  |          | Clear individual bits in GPIO port                                             |          |
| IN             | 0x010  |          | Read GPIO port                                                                 |          |
| DIR            | 0x014  |          | Direction of GPIO pins                                                         | Retained |
| DIRSET         | 0x018  |          | DIR set register                                                               |          |
| DIRCLR         | 0x01C  |          | DIR clear register                                                             |          |
| LATCH          | 0x020  |          | Latch register indicating what GPIO pins that have met the criteria set in the | Retained |
|                |        |          | PIN_CNF[n].SENSE registers                                                     |          |
| DETECTMODE     | 0x024  |          | Select between default DETECT signal behavior and LDETECT mode (For non-secure | Retained |
|                |        |          | pin only)                                                                      |          |
| DETECTMODE_SEC | 0x028  |          | Select between default DETECT signal behavior and LDETECT mode (For secure pin | Retained |
|                |        |          | only)                                                                          |          |
| PIN_CNF[n]     | 0x200  |          | Configuration of GPIO pins                                                     | Retained |

Table 78: Register overview

## 7.13.5.1 OUT (Retained)

Address offset: 0x004

This register is a retained register

Write GPIO port

| Bit n | umber   |                |      | 31 | L 30 | 29 | 28 | 27 2 | 26 2 | 5 2 | 4 23 | 3 2 2 | 21   | 20    | 19  | 18 1 | 7 16 | 15 | 14 | 13 1 | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1 | 0 |
|-------|---------|----------------|------|----|------|----|----|------|------|-----|------|-------|------|-------|-----|------|------|----|----|------|------|------|---|---|---|---|---|---|-----|---|---|
| ID    |         |                |      | f  | е    | d  | С  | b    | a Z  | Z Y | ′ X  | W     | ′ V  | U     | Т   | S F  | Q    | Р  | 0  | N I  | M    | L K  | J | 1 | Н | G | F | Е | 0 0 | В | Α |
| Rese  | t 0x000 | 00000          |      | 0  | 0    | 0  | 0  | 0    | 0 (  | ) ( | 0    | 0     | 0    | 0     | 0   | 0 (  | 0    | 0  | 0  | 0    | 0 (  | 0 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 |
| ID    |         |                |      |    |      |    |    |      |      |     |      |       |      |       |     |      |      |    |    |      |      |      |   |   |   |   |   |   |     |   |   |
| A-f   | RW      | PIN[i] (i=031) |      |    |      |    |    |      |      |     | Pi   | n i   |      |       |     |      |      |    |    |      |      |      |   |   |   |   |   |   |     |   |   |
|       |         |                | Low  | 0  |      |    |    |      |      |     | Pi   | n d   | rive | er is | lov | ٧    |      |    |    |      |      |      |   |   |   |   |   |   |     |   |   |
|       |         |                | High | 1  |      |    |    |      |      |     | Pi   | n d   | rive | er is | hig | gh   |      |    |    |      |      |      |   |   |   |   |   |   |     |   |   |

### 7.13.5.2 OUTSET

Address offset: 0x008

Set individual bits in GPIO port

Read: reads value of OUT register.



| Bit numbe | er   |                |      | 31 | l 30 | 29 | 28 | 27 2 | 26 2 | 25 | 24 | 23  | 22  | 21  | 20    | 19 1 | 18 1   | L7 1 | .6 1 | .5 1 | 4 13  | 3 12 | 11   | 10   | 9   | 8 7 | ' 6 | 5   | 4 | 3 | 2 | 1 0 |
|-----------|------|----------------|------|----|------|----|----|------|------|----|----|-----|-----|-----|-------|------|--------|------|------|------|-------|------|------|------|-----|-----|-----|-----|---|---|---|-----|
| ID        |      |                |      | f  | е    | d  | С  | b    | а    | Z  | Υ  | Χ   | W   | ٧   | U     | Т    | S I    | R (  | Q I  | P C  | ) N   | М    | L    | K    | J   | I F | 1 6 | i F | Ε | D | С | ВА  |
| Reset 0x0 | 0000 | 00000          |      | 0  | 0    | 0  | 0  | 0    | 0    | 0  | 0  | 0   | 0   | 0   | 0     | 0    | 0 (    | 0    | 0    | 0 (  | 0     | 0    | 0    | 0    | 0   | 0 ( | ) ( | 0   | 0 | 0 | 0 | 0 0 |
| ID R/V    |      |                |      |    |      |    |    |      |      |    |    |     |     |     |       |      |        |      |      |      |       |      |      |      |     |     |     |     |   |   |   |     |
| A-f RW    | V    | PIN[i] (i=031) |      |    |      |    |    |      |      |    |    | Pin | ı i |     |       |      |        |      |      |      |       |      |      |      |     |     |     |     |   |   |   |     |
|           |      |                | Low  | 0  |      |    |    |      |      |    |    | Rea | ad: | pir | n dr  | iver | is     | low  | ,    |      |       |      |      |      |     |     |     |     |   |   |   |     |
|           |      |                | High | 1  |      |    |    |      |      |    |    | Rea | ad: | pir | n dr  | iver | · is l | hig  | h    |      |       |      |      |      |     |     |     |     |   |   |   |     |
|           |      |                | Set  | 1  |      |    |    |      |      |    |    | Wr  | ite | : w | ritir | ng a | '1'    | set  | s tl | he p | oin l | nigh | ; wı | itin | g a | '0' | nas | no  |   |   |   |     |
|           |      |                |      |    |      |    |    |      |      |    |    | eff | ect |     |       |      |        |      |      |      |       |      |      |      |     |     |     |     |   |   |   |     |

### 7.13.5.3 OUTCLR

Address offset: 0x00C

Clear individual bits in GPIO port Read: reads value of OUT register.

| Bit n | umber   |                |       | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|-------|----------------------|------------------------------------------------------------------|
| ID    |         |                |       | f e d c b a Z        | Y X W V U T S R Q P O N M L K J I H G F E D C B A                |
| Rese  | t 0x000 | 00000          |       | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |         |                |       |                      |                                                                  |
| A-f   | RW      | PIN[i] (i=031) |       |                      | Pin i                                                            |
|       |         |                | Low   | 0                    | Read: pin driver is low                                          |
|       |         |                | High  | 1                    | Read: pin driver is high                                         |
|       |         |                | Clear | 1                    | Write: writing a '1' sets the pin low; writing a '0' has no      |
|       |         |                |       |                      | effect                                                           |

### 7.13.5.4 IN

Address offset: 0x010

Read GPIO port

| Bit n | umber   |                |      | 31 30 29 28 27 2 | 6 25 2 | 4 23 2 | 22 21 | . 20 1  | 9 18 | 17 1 | L6 15 | 14 1 | .3 12 | 2 11 | 10 | 9 8 | 7 | 6 | 5 | 4 3 | 2   | 1 | 0 |
|-------|---------|----------------|------|------------------|--------|--------|-------|---------|------|------|-------|------|-------|------|----|-----|---|---|---|-----|-----|---|---|
| ID    |         |                |      | fedcba           | a Z '  | ΥXV    | N V   | U .     | ГЅ   | R (  | Q P   | 0    | N M   | l L  | K  | J I | Н | G | F | E C | ) С | В | Α |
| Rese  | t 0x000 | 00000          |      | 0 0 0 0 0 0      | 0 (    | 0 0    | 0 0   | 0 (     | 0 0  | 0    | 0 0   | 0    | 0 0   | 0    | 0  | 0 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID    |         |                |      |                  |        |        |       |         |      |      |       |      |       |      |    |     |   |   |   |     |     |   |   |
| A-f   | R       | PIN[i] (i=031) |      |                  |        | Pin    | i     |         |      |      |       |      |       |      |    |     |   |   |   |     |     |   |   |
|       |         |                | Low  | 0                |        | Pin    | inpu  | t is lo | w    |      |       |      |       |      |    |     |   |   |   |     |     |   |   |
|       |         |                | High | 1                |        | Pin    | inpu  | t is h  | igh  |      |       |      |       |      |    |     |   |   |   |     |     |   |   |

# 7.13.5.5 DIR (Retained)

Address offset: 0x014

This register is a retained register

Direction of GPIO pins





#### 7.13.5.6 DIRSET

Address offset: 0x018

DIR set register

Read: reads value of DIR register.

| Bit n | umber   |                |        | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------|----------------------|--------------------------------------------------------------------|
| ID    |         |                |        | f edcba Z            | Y X W V U T S R Q P O N M L K J I H G F E D C B A                  |
| Rese  | t 0x000 | 00000          |        | 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID    |         |                |        |                      |                                                                    |
| A-f   | RW      | PIN[i] (i=031) |        |                      | Set as output pin i                                                |
|       |         |                | Input  | 0                    | Read: pin set as input                                             |
|       |         |                | Output | 1                    | Read: pin set as output                                            |
|       |         |                | Set    | 1                    | Write: writing a '1' sets pin to output; writing a '0' has no      |
|       |         |                |        |                      | effect                                                             |

### 7.13.5.7 DIRCLR

Address offset: 0x01C

DIR clear register

Read: reads value of DIR register.

| Bit n | umber   |                |        | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|---------|----------------|--------|-------------------------------------------------------------------------------------|
| ID    |         |                |        | fedcbaZYXWVUTSRQPONMLKJIHGFEDCB                                                     |
| Rese  | t 0x000 | 00000          |        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                             |
| ID    |         |                |        |                                                                                     |
| A-f   | RW      | PIN[i] (i=031) |        | Set as input pin i                                                                  |
|       |         |                | Input  | 0 Read: pin set as input                                                            |
|       |         |                | Output | 1 Read: pin set as output                                                           |
|       |         |                | Clear  | 1 Write: writing a '1' sets pin to input; writing a '0' has no                      |
|       |         |                |        | effect                                                                              |

## 7.13.5.8 LATCH (Retained)

Address offset: 0x020

This register is a retained register

Latch register indicating what GPIO pins that have met the criteria set in the PIN\_CNF[n].SENSE registers



| Bit number            | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|---------------------------------------------------------------------------------------|
| ID                    | fedcbaZYXWVUTSRQPONMLKJIHGFEDCBA                                                      |
| Reset 0x00000000      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| ID R/W Field Value ID | Value Description                                                                     |
| A-f RW PIN[i] (i=031) | Status on whether PIN[i] has met criteria set in                                      |
|                       | PIN_CNF[i].SENSE register. Write '1' to clear.                                        |
| NotLatched            | O Criteria has not been met                                                           |
| Latched               | 1 Criteria has been met                                                               |

### 7.13.5.9 DETECTMODE (Retained)

Address offset: 0x024

This register is a retained register

Select between default DETECT signal behavior and LDETECT mode (For non-secure pin only)



### 7.13.5.10 DETECTMODE\_SEC (Retained)

Address offset: 0x028

This register is a retained register

Select between default DETECT signal behavior and LDETECT mode (For secure pin only)



## 7.13.5.11 PIN\_CNF[n] (n=0..31) (Retained)

Address offset:  $0x200 + (n \times 0x4)$ This register is a retained register

Configuration of GPIO pins





| Bit | number   |        |            | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----|----------|--------|------------|-------------------------|-----------------------------------------------------------------|
| ID  |          |        |            | GGG                     | EE DDDD CCBA                                                    |
| Res | et 0x000 | 000002 |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|     |          |        |            |                         |                                                                 |
|     |          |        | Input      | 0                       | Configure pin as an input pin                                   |
|     |          |        | Output     | 1                       | Configure pin as an output pin                                  |
| В   | RW       | INPUT  |            |                         | Connect or disconnect input buffer                              |
|     |          |        | Connect    | 0                       | Connect input buffer                                            |
|     |          |        | Disconnect | 1                       | Disconnect input buffer                                         |
| С   | RW       | PULL   |            |                         | Pull configuration                                              |
|     |          |        | Disabled   | 0                       | No pull                                                         |
|     |          |        | Pulldown   | 1                       | Pull down on pin                                                |
|     |          |        | Pullup     | 3                       | Pull up on pin                                                  |
| D   | RW       | DRIVE  |            |                         | Drive configuration                                             |
|     |          |        |            |                         | Some pins may not support every drive configuration.            |
|     |          |        | S0S1       | 0                       | Standard '0', standard '1'                                      |
|     |          |        | H0S1       | 1                       | High drive '0', standard '1'                                    |
|     |          |        | S0H1       | 2                       | Standard '0', high drive '1'                                    |
|     |          |        | H0H1       | 3                       | High drive '0', high 'drive '1"                                 |
|     |          |        | D0S1       | 4                       | Disconnect '0', standard '1' (normally used for wired-or        |
|     |          |        |            |                         | connections)                                                    |
|     |          |        | D0H1       | 5                       | Disconnect '0', high drive '1' (normally used for wired-or      |
|     |          |        |            |                         | connections)                                                    |
|     |          |        | SOD1       | 6                       | Standard '0', disconnect '1' (normally used for wired-and       |
|     |          |        |            |                         | connections)                                                    |
|     |          |        | H0D1       | 7                       | High drive '0', disconnect '1' (normally used for wired-and     |
|     |          |        |            |                         | connections)                                                    |
|     |          |        | E0E1       | 11                      | Extra high drive '0', extra high drive '1'                      |
| E   | RW       | SENSE  |            |                         | Pin sensing mechanism                                           |
|     |          |        | Disabled   | 0                       | Disabled                                                        |
|     |          |        | High       | 2                       | Sense for high level                                            |
|     |          |        | Low        | 3                       | Sense for low level                                             |
| G   | RW       | MCUSEL |            |                         | Select which MCU/Subsystem controls this pin                    |
|     |          |        |            |                         | Note: this field is only accessible from secure code.           |
|     |          |        | AppMCU     | 0x0                     | Application MCU                                                 |
|     |          |        | NetworkMCU | 0x1                     | Network MCU                                                     |
|     |          |        | Peripheral | 0x3                     | Peripheral with dedicated pins                                  |
|     |          |        | TND        | 0x7                     | Trace and Debug Subsystem                                       |
|     |          |        |            |                         |                                                                 |

# 7.13.6 Electrical specification

# 7.13.6.1 GPIO Electrical Specification

| Symbol              | Description                                                   | Min.  | Тур. | Max.  | Units |
|---------------------|---------------------------------------------------------------|-------|------|-------|-------|
| $V_{IH}$            | Input high voltage                                            | 0.7 x |      | VDD   | V     |
|                     |                                                               | VDD   |      |       |       |
| $V_{IL}$            | Input low voltage                                             | VSS   |      | 0.3 x | V     |
|                     |                                                               |       |      | VDD   |       |
| $V_{OH,SD}$         | Output high voltage, standard drive, 0.5 mA, VDD $\geq$ 1.7 V | VDD - |      | VDD   | V     |
|                     |                                                               | 0.4   |      |       |       |
| V <sub>OH,HDH</sub> | Output high voltage, high drive, 5 mA, VDD ≥ 2.7 V            | VDD - |      | VDD   | V     |
|                     |                                                               | 0.4   |      |       |       |





| Symbol                       | Description                                                                                                             | Min.  | Тур. | Max.            | Units |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------|------|-----------------|-------|
| V <sub>OH,HDL</sub>          | Output high voltage, high drive, 3 mA, VDD ≥ 1.7 V                                                                      | VDD - |      | VDD             | V     |
|                              |                                                                                                                         | 0.4   |      |                 |       |
| $V_{OL,SD}$                  | Output low voltage, standard drive, 0.5 mA, VDD $\geq$ 1.7 V                                                            | VSS   |      | VSS + 0.4       | V     |
| $V_{OL,HDH}$                 | Output low voltage, high drive, 5 mA, VDD $\geq$ 2.7 V                                                                  | VSS   |      | VSS + 0.4       | V     |
| $V_{OL,HDL}$                 | Output low voltage, high drive, 3 mA, VDD ≥ 1.7 V                                                                       | VSS   |      | VSS + 0.4       | V     |
| I <sub>OL,SD</sub>           | Current at VSS + 0.4 V, output set low, standard drive, VDD $\geq$ 1.7 V                                                | 1     | 2    | 4               | mA    |
| I <sub>OL,HDH</sub>          | Current at VSS + 0.4 V, output set low, high drive, VDD $\geq$ 2.7 V                                                    | 6     |      |                 | mA    |
| I <sub>OL,HDL</sub>          | Current at VSS + 0.4 V, output set low, high drive, VDD $\geq$ 1.7 V                                                    | 3     |      |                 | mA    |
| I <sub>OL,HDL,QSPI</sub>     | Current at VSS + 0.4 V, output set low, high drive, VDD $\geq$ 1.7 V                                                    |       | 10   |                 | mA    |
| I <sub>OL,HDL,TWIM</sub>     | Current at VSS + 0.4 V, output set low, high drive, VDD $\geq$ 1.7 V                                                    |       | 50   |                 | mA    |
| I <sub>OH,SD</sub>           | Current at VDD - 0.4 V, output set high, standard drive, VDD ≥1.7                                                       | 1     | 2    | 3               | mA    |
| I <sub>OH,HDH</sub>          | Current at VDD - 0.4 V, output set high, high drive, VDD ≥ 2.7 V                                                        | 6     |      |                 | mA    |
| I <sub>OH,HDL</sub>          | Current at VDD - 0.4 V, output set high, high drive, VDD ≥ 1.7 V                                                        | 3     |      |                 | mA    |
| I <sub>OH,HDL,QSPI</sub>     | Current at VDD - 0.4 V, output set high, high drive, VDD ≥ 1.7 V                                                        |       | 10   |                 | mA    |
| I <sub>GPIO,TOTAL</sub>      | Recommended maximum current drawn by all GPIOs                                                                          |       |      | 15 <sup>2</sup> | mA    |
| t <sub>RF,15pF</sub>         | Rise/fall time, standard drive mode, 10 to 90%, 15 pF load <sup>1</sup>                                                 |       | 9    |                 | ns    |
| t <sub>RF,25pF</sub>         | Rise/fall time, standard drive mode, 10 to 90%, 25 pF load <sup>1</sup>                                                 |       | 14   |                 | ns    |
| t <sub>RF,50pF</sub>         | Rise/fall time, standard drive mode, 10 to 90%, 50 pF load                                                              |       | 26   |                 | ns    |
|                              | Rise/Fall time, standard drive mode, 10 to 90%, 50 pr load  Rise/Fall time, high drive mode, 20 to 80%, 10 pF load, VDD |       | 8.5  |                 | ns    |
| t <sub>HRF,10pF,QSPI96</sub> |                                                                                                                         |       | 0.5  |                 | 113   |
|                              | 1.6 V to 3.6 V, QSPI running at 96 MHz <sup>1</sup>                                                                     |       | 4    |                 | nc    |
| t <sub>HRF,15pF</sub>        | Rise/Fall time, high drive mode, 10 to 90%, 15 pF load <sup>1</sup>                                                     |       | 4    |                 | ns    |
| t <sub>HRF,25pF</sub>        | Rise/Fall time, high drive mode, 10 to 90%, 25 pF load <sup>1</sup>                                                     |       | 5    |                 | ns    |
| t <sub>HRF,50pF</sub>        | Rise/Fall time, high drive mode, 10 to 90%, 50 pF load <sup>1</sup>                                                     |       | 9    |                 | ns    |
| R <sub>PU</sub>              | Pull-up resistance                                                                                                      |       | 13   |                 | kΩ    |
| R <sub>PD</sub>              | Pull-down resistance                                                                                                    |       | 13   |                 | kΩ    |
| C <sub>PAD</sub>             | Pad capacitance                                                                                                         |       | 1.5  |                 | pF    |
| C <sub>PAD_NFC</sub>         | Pad capacitance on NFC pads                                                                                             |       | 4    |                 | pF    |
| I <sub>NFC_LEAK</sub>        | Leakage current between NFC pads when driven to                                                                         |       | 1    | 10              | μΑ    |

# 7.14 GPIOTE — GPIO tasks and events

The GPIO tasks and events (GPIOTE) module provides functionality for accessing GPIO pins using tasks and events. Each GPIOTE channel can be assigned to one pin.

A GPIOTE block enables GPIOs to generate events on pin state change which can be used to carry out tasks through the PPI system. A GPIO can also be driven to change state on system events using the PPI system. Tasks and events are briefly introduced in Peripheral interface on page 150, and GPIO is described in more detail in GPIO — General purpose input/output on page 224.

NORDIC\*

<sup>&</sup>lt;sup>2</sup> Excludes the 20 mA dedicated high-speed open-drain pins used for TWI. VREGH specifications must be followed if operating in high voltage mode.

<sup>&</sup>lt;sup>1</sup> Rise and fall times based on simulations

Low power detection of pin state changes is possible when in System ON or System OFF.

Up to three tasks can be used in each GPIOTE channel for performing write operations to a pin. Two tasks are fixed (SET and CLR), and one (OUT) is configurable to perform following operations:

- Set
- Clear
- Toggle

An event can be generated in each GPIOTE channel from one of the following input conditions:

- Rising edge
- · Falling edge
- Any change

#### 7.14.1 Pin events and tasks

The GPIOTE module has a number of tasks and events that can be configured to operate on individual GPIO pins.

The secure instance of the GPIOTE peripheral is able to operate on all GPIO pins configured in GPIOTE.CONFIG[n].PSEL.

The non-secure instance of the GPIOTE peripheral is able to operate only on non-secure GPIO pins. The field GPIOTE.CONFIG[n].PSEL can only select a non-secure pin.

The tasks SET[n], CLR[n], and OUT[n] can write to individual pins, and events IN[n] can be generated from input changes of individual pins.

The SET task will set the pin selected in GPIOTE.CONFIG[n]. PSEL to high. The CLR task will set the pin low.

The effect of the OUT task on the pin is configurable in CONFIG[n].POLARITY. It can set the pin high, set it low, or toggle it.

Tasks and events are configured using the CONFIG[n] registers. One CONFIG[n] register is associated with a set of SET[n], CLR[n], and OUT[n] tasks and IN[n] events.

As long as a SET[n], CLR[n], and OUT[n] task or an IN[n] event is configured to control pin **n**, the pin's output value will only be updated by the GPIOTE module. The pin's output value, as specified in the GPIO, will be ignored as long as the pin is controlled by GPIOTE. Attempting to write to the pin as a normal GPIO pin will have no effect. When the GPIOTE is disconnected from a pin, the associated pin gets the output and configuration values specified in the GPIO module, see MODE field in CONFIG[n] register.

When conflicting tasks are triggered simultaneously (i.e. during the same clock cycle) in one channel, the priority of the tasks is as described in the following table.

| Priority | Task |
|----------|------|
| 1        | OUT  |
| 2        | CLR  |
| 3        | SET> |

Table 79: Task priorities

When setting the CONFIG[n] registers, MODE=Disabled does not have the same effect as MODE=Task and POLARITY=None. In the latter case, a CLR or SET task occurring at the exact same time as OUT will end up with no change on the pin, based on the priorities described in the table above.

When a GPIOTE channel is configured to operate on a pin as a task, the initial value of that pin is configured in the OUTINIT field of CONFIG[n].



### 7.14.2 Port event

PORT is an event that can be generated from multiple input pins using the GPIO DETECT signal.

The event will be generated on the rising edge of the DETECT signal. See GPIO — General purpose input/output on page 224 for more information about the DETECT signal.

There are two DETECT signals that come from the GPIO peripheral. The secure DETECT\_SEC, for the secure instance of the GPIOTE peripheral, and the non-secure DETECT\_NONSEC, for the non-secure instance of the GPIOTE peripheral.

The GPIO DETECT signal will not wake the system up again if the system is put into System ON IDLE while the DETECT signal is high. Clear all DETECT sources before entering sleep. If the LATCH register is used as a source, a new rising edge will be generated on DETECT if any bit in LATCH is still high after clearing all or part of the register. This could occur if one of the PINx.DETECT signals is still high, for example. See Pin sense mechanism on page 227 for more information.

Setting the system to System OFF while DETECT is high will cause a wakeup from System OFF reset.

This feature can be used to wake up the CPU from a WFI or WFE type sleep in System ON when all peripherals and the CPU are idle, meaning the lowest power consumption in System ON mode.

To prevent spurious interrupts from the PORT event while configuring the sources, the following steps must be performed:

- 1. Disable interrupts on the PORT event (through INTENCLR.PORT).
- 2. Configure the sources (PIN CNF[n].SENSE).
- **3.** Clear any potential event that could have occurred during configuration (write 0 to EVENTS PORT).
- 4. Enable interrupts (through INTENSET.PORT).

## 7.14.3 Tasks and events pin configuration

Each GPIOTE channel is associated with one physical GPIO pin through the CONFIG.PSEL field.

When Event mode is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will be configured as an input, overriding the DIR setting in GPIO. Similarly, when Task mode is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will be configured as an output overriding the DIR setting and OUT value in GPIO. When Disabled is selected in CONFIG.MODE, the pin specified by CONFIG.PSEL will use its configuration from the PIN[n].CNF registers in GPIO.

**Note:** A pin can only be assigned to one GPIOTE channel at a time. Failing to do so may result in unpredictable behavior.

## 7.14.4 Low power

In Event mode (CONFIG.MODE=Event), the register LATENCY on page 242 makes it possible to reduce power consumption.

To enable the power saving behavior, set register LATENCY to LowPower.

LowPower can be used with both PORT event (EVENTS\_PORT) and IN event (EVENTS\_IN). The GPIO pins must have their PIN\_CNF[n].SENSE configured.

When using LowPower with IN event, the GPIO PIN\_CNF[] register's SENSE field needs to be configured according to CONFIG.POLARITY for the selected pin.

- When CONFIG.POLARITY=LoToHi, SENSE must be set to High.
- When CONFIG.POLARITY=HiToLo, SENSE must be set to Low.

When using LowPower with PORT event, the GPIO PIN\_CNF[] register's SENSE field can have any value.

 ${\color{blue} \textbf{CONFIG.POLARITY} = } \textbf{Toggle is not supported for LATENCY} = \textbf{LowPower.}$ 



# 7.14.5 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description           | Configuration |
|------------------------|------------|----------|----------------|--------------|-----------------------|---------------|
| 0x5000D000 APPLICATION | N GPIOTE   | GPIOTE0  | S              | NA           | GPIO tasks and events |               |
| 0x4002F000 APPLICATION | N GPIOTE   | GPIOTE1  | NS             | NA           | GPIO tasks and events |               |
| 0x4100A000 NETWORK     | GPIOTE     | GPIOTE   | NS             | NA           | GPIO tasks and events |               |

Table 80: Instances

| Register         | Offset | Security | Description                                                                             |
|------------------|--------|----------|-----------------------------------------------------------------------------------------|
| TASKS_OUT[n]     | 0x000  |          | Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is configured in     |
|                  |        |          | CONFIG[n].POLARITY.                                                                     |
| TASKS_SET[n]     | 0x030  |          | Task for writing to pin specified in $CONFIG[n].PSEL.$ Action on pin is to set it high. |
| TASKS_CLR[n]     | 0x060  |          | Task for writing to pin specified in $CONFIG[n].PSEL.$ Action on pin is to set it low.  |
| SUBSCRIBE_OUT[n] | 0x080  |          | Subscribe configuration for task OUT[n]                                                 |
| SUBSCRIBE_SET[n] | 0x0B0  |          | Subscribe configuration for task SET[n]                                                 |
| SUBSCRIBE_CLR[n] | 0x0E0  |          | Subscribe configuration for task CLR[n]                                                 |
| EVENTS_IN[n]     | 0x100  |          | Event generated from pin specified in CONFIG[n].PSEL                                    |
| EVENTS_PORT      | 0x17C  |          | Event generated from multiple input GPIO pins with SENSE mechanism enabled              |
| PUBLISH_IN[n]    | 0x180  |          | Publish configuration for event IN[n]                                                   |
| PUBLISH_PORT     | 0x1FC  |          | Publish configuration for event PORT                                                    |
| INTENSET         | 0x304  |          | Enable interrupt                                                                        |
| INTENCLR         | 0x308  |          | Disable interrupt                                                                       |
| LATENCY          | 0x504  |          | Latency selection for Event mode (MODE=Event) with rising or falling edge detection     |
|                  |        |          | on the pin.                                                                             |
| CONFIG[n]        | 0x510  |          | Configuration for OUT[n], SET[n], and CLR[n] tasks and IN[n] event                      |

Table 81: Register overview

# 7.14.5.1 TASKS\_OUT[n] (n=0..7)

Address offset:  $0x000 + (n \times 0x4)$ 

Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is configured in CONFIG[n].POLARITY.



# 7.14.5.2 TASKS\_SET[n] (n=0..7)

Address offset:  $0x030 + (n \times 0x4)$ 

Task for writing to pin specified in CONFIG[n].PSEL. Action on pin is to set it high.





## 7.14.5.3 TASKS\_CLR[n] (n=0..7)

Address offset:  $0x060 + (n \times 0x4)$ 

Task for writing to pin specified in CONFIG[n]. PSEL. Action on pin is to set it low.

| Bit n | umber   |           |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |         |           |         |                         | А                                                               |
| Rese  | t 0x000 | 00000     |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |           |         |                         | Description                                                     |
| Α     | W       | TASKS_CLR |         |                         | Task for writing to pin specified in CONFIG[n].PSEL. Action     |
|       |         |           |         |                         | on pin is to set it low.                                        |
|       |         |           | Trigger | 1                       | Trigger task                                                    |

### 7.14.5.4 SUBSCRIBE\_OUT[n] (n=0..7)

Address offset:  $0x080 + (n \times 0x4)$ 

Subscribe configuration for task OUT[n]

| Bit n            | umber |                 |                                         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|-------|-----------------|-----------------------------------------|-------------------------|-----------------------------------------------------------------|
| ID               |       |                 |                                         | В                       | A A A A A A A                                                   |
| Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                         |                                                                 |
| ID               |       |                 |                                         |                         |                                                                 |
| Α                | RW    | CHIDX           |                                         | [2550]                  | DPPI channel that task OUT[n] will subscribe to                 |
| В                | DIA   |                 |                                         |                         |                                                                 |
| ь                | RW    | EN              |                                         |                         |                                                                 |
| Ь                | KW    | EN              | Disabled                                | 0                       | Disable subscription                                            |

## 7.14.5.5 SUBSCRIBE\_SET[n] (n=0..7)

Address offset:  $0x0B0 + (n \times 0x4)$ 

Subscribe configuration for task SET[n]

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 6 | 5 | 4 3 | 3 2 | 1 0 |
|-------|----------|-------|----------|-------------------------|---------------------------------------------------|---|---|-----|-----|-----|
| ID    |          |       |          | В                       | A                                                 | Α | Α | A A | AA  | АА  |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 | 0 | 0 ( | 0   | 0 0 |
| ID    |          |       |          |                         |                                                   |   |   |     |     |     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task SET[n] will subscribe to   |   |   |     |     |     |
| В     | RW       | EN    |          |                         |                                                   |   |   |     |     |     |
|       |          |       | Disabled | 0                       | Disable subscription                              |   |   |     |     |     |
|       |          |       | Enabled  | 1                       | Enable subscription                               |   |   |     |     |     |

# 7.14.5.6 SUBSCRIBE\_CLR[n] (n=0..7)

Address offset:  $0x0E0 + (n \times 0x4)$ 



#### Subscribe configuration for task CLR[n]



### 7.14.5.7 EVENTS IN[n] (n=0..7)

Address offset:  $0x100 + (n \times 0x4)$ 

Event generated from pin specified in CONFIG[n].PSEL



### 7.14.5.8 **EVENTS\_PORT**

Address offset: 0x17C

Event generated from multiple input GPIO pins with SENSE mechanism enabled



### 7.14.5.9 PUBLISH\_IN[n] (n=0..7)

Address offset: 0x180 + (n × 0x4)

Publish configuration for event IN[n]





# 7.14.5.10 PUBLISH\_PORT

Address offset: 0x1FC

Publish configuration for event PORT

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         | Description                                                     |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event PORT will publish to.                   |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       |          |                         |                                                                 |

### 7.14.5.11 INTENSET

Address offset: 0x304

Enable interrupt

| Bit number  |              |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------|--------------|----------|-------------------------|---------------------------------------------------------------|
| ID          |              |          | 1                       | HGFEDCBA                                                      |
| Reset 0x000 | 00000        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID R/W      |              |          |                         |                                                               |
| A-H RW      | IN[i] (i=07) |          |                         | Write '1' to enable interrupt for event IN[i]                 |
|             |              | Set      | 1                       | Enable                                                        |
|             |              | Disabled | 0                       | Read: Disabled                                                |
|             |              | Enabled  | 1                       | Read: Enabled                                                 |
| I RW        | PORT         |          |                         | Write '1' to enable interrupt for event PORT                  |
|             |              | Set      | 1                       | Enable                                                        |
|             |              | Disabled | 0                       | Read: Disabled                                                |
|             |              | Enabled  | 1                       | Read: Enabled                                                 |

### 7.14.5.12 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit nur | mber   |              |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|---------|--------|--------------|----------|-------------------------|---------------------------------------------------------------|
| ID      |        |              |          | 1                       | HGFEDCBA                                                      |
| Reset   | 0x0000 | 00000        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID      |        |              |          |                         |                                                               |
| A-H     | RW     | IN[i] (i=07) |          |                         | Write '1' to disable interrupt for event IN[i]                |
|         |        |              | Clear    | 1                       | Disable                                                       |
|         |        |              | Disabled | 0                       | Read: Disabled                                                |
|         |        |              | Enabled  | 1                       | Read: Enabled                                                 |
| 1       | RW     | PORT         |          |                         | Write '1' to disable interrupt for event PORT                 |
|         |        |              | Clear    | 1                       | Disable                                                       |
|         |        |              | Disabled | 0                       | Read: Disabled                                                |
|         |        |              | Enabled  | 1                       | Read: Enabled                                                 |



#### 7.14.5.13 LATENCY

Address offset: 0x504

Latency selection for Event mode (MODE=Event) with rising or falling edge detection on the pin.

POLARITY=Toggle can only be used with LATENCY=LowLatency.



## 7.14.5.14 CONFIG[n] (n=0..7)

Address offset:  $0x510 + (n \times 0x4)$ 

Configuration for OUT[n], SET[n], and CLR[n] tasks and IN[n] event

| Bit r | umber    |          |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|----------|-------------------|---------------------------------------------------------------------|
| ID    |          |          |          |                   | E DD CBBBB AA                                                       |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
|       |          |          |          |                   |                                                                     |
| Α     | RW       | MODE     |          |                   | Mode                                                                |
|       |          |          | Disabled | 0                 | Disabled. Pin specified by PSEL will not be acquired by the         |
|       |          |          |          |                   | GPIOTE module.                                                      |
|       |          |          | Event    | 1                 | Event mode                                                          |
|       |          |          |          |                   | The pin specified by PSEL will be configured as an input            |
|       |          |          |          |                   | and the IN[n] event will be generated if operation specified        |
|       |          |          |          |                   | in POLARITY occurs on the pin.                                      |
|       |          |          | Task     | 3                 | Task mode                                                           |
|       |          |          |          |                   | The GPIO specified by PSEL will be configured as an output          |
|       |          |          |          |                   | and triggering the SET[n], CLR[n] or OUT[n] task will               |
|       |          |          |          |                   | perform the operation specified by POLARITY on the pin.             |
|       |          |          |          |                   | When enabled as a task the GPIOTE module will acquire               |
|       |          |          |          |                   | the pin and the pin can no longer be written as a regular           |
|       |          |          |          |                   | output pin from the GPIO module.                                    |
| В     | RW       | PSEL     |          | [031]             | GPIO number associated with SET[n], CLR[n], and OUT[n]              |
|       |          |          |          |                   | tasks and IN[n] event                                               |
| С     | RW       | PORT     |          | [01]              | Port number                                                         |
| D     | RW       | POLARITY |          |                   | When In task mode: Operation to be performed on output              |
|       |          |          |          |                   | when OUT[n] task is triggered. When In event mode:                  |
|       |          |          |          |                   | Operation on input that shall trigger IN[n] event.                  |
|       |          |          | None     | 0                 | Task mode: No effect on pin from OUT[n] task. Event                 |
|       |          |          |          |                   | mode: no IN[n] event generated on pin activity.                     |
|       |          |          | LoToHi   | 1                 | Task mode: Set pin from OUT[n] task. Event mode:                    |
|       |          |          |          |                   | Generate IN[n] event when rising edge on pin.                       |
|       |          |          | HiToLo   | 2                 | Task mode: Clear pin from OUT[n] task. Event mode:                  |
|       |          |          |          |                   | Generate IN[n] event when falling edge on pin.                      |



| Bit number       |        | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|--------|-------------------------|-----------------------------------------------------------------|
| ID               |        |                         | E DD CBBBBB AA                                                  |
| Reset 0x00000000 |        | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field     |        |                         |                                                                 |
|                  | Toggle | 3                       | Task mode: Toggle pin from OUT[n]. Event mode: Generate         |
|                  |        |                         | IN[n] when any change on pin.                                   |
|                  |        |                         | POLARITY=Toggle requires the use of                             |
|                  |        |                         | LATENCY=LowLatency.                                             |
| E RW OUTINIT     |        |                         | When in task mode: Initial value of the output when the         |
|                  |        |                         | GPIOTE channel is configured. When in event mode: No            |
|                  |        |                         | effect.                                                         |
|                  | Low    | 0                       | Task mode: Initial value of pin before task triggering is low   |
|                  | High   | 1                       | Task mode: Initial value of pin before task triggering is high  |

# 7.14.6 Electrical specification

# $7.15 \, \text{l}^2\text{S}$ — Inter-IC sound interface

The I<sup>2</sup>S (Inter-IC Sound) module, supports the original two-channel I<sup>2</sup>S format, and left- or right-aligned formats. It implements EasyDMA for sample transfer directly to and from RAM without CPU intervention.

The I<sup>2</sup>S peripheral has the following main features:

- Master and Slave mode
- Simultaneous bidirectional (TX and RX) audio streaming
- Original I<sup>2</sup>S and left- or right-aligned format
- 32, 24, 16 and 8-bit sample widths
- Separate sample and word widths
- Low-jitter master clock generator
- Various sample rates





Figure 63: I<sup>2</sup>S master

### 7.15.1 Mode

The I<sup>2</sup>S protocol specification defines two modes of operation, Master and Slave.

The I<sup>2</sup>S mode decides which of the two sides (master or slave) shall provide the clock signals LRCK and SCK, and these signals are always supplied by the master to the slave.

# 7.15.2 Transmitting and receiving

The I<sup>2</sup>S module supports both transmission (TX) and reception (RX) of serial data. In both cases the serial data is shifted synchronously to the clock signals SCK and LRCK.

TX data is written to the SDOUT pin on the falling edge of SCK, and RX data is read from the SDIN pin on the rising edge of SCK. The most significant bit (MSB) is always transmitted first.

**Note:** When starting a transmission in master mode, the first frame is filled with zeros.

TX and RX are available in both Master and Slave modes and can be enabled/disabled independently in the CONFIG.TXEN on page 262 and CONFIG.RXEN on page 262.

Transmission and/or reception is started by triggering the START task. With transmission enabled in CONFIG.TXEN), the TXPTRUPD event will be generated for every number of transmitted data words given by RXTXD.MAXCNT on page 267. Each data word contains one or more samples. The TXPTRUPD event is generated just before MAXCNT number of data words have been transmitted. Similarly, with reception enabled in CONFIG.RXEN, the RXPTRUPD event will be generated for every received data word given by RXTXD.MAXCNT on page 267. The RXPTRUPD event is generated just after MAXCNT number of data words have been received.



The FRAMESTART event is generated synchronously to the active LRCK edge at the beginning of a frame after transmitting RXTXD.MAXCNT data words. The initial FRAMESTART event is generated at the first active edge of LRCK after the START task has been triggered. The FRAMESTART event is only defined for transmitting full left and right sample pairs. If MAXCNT is configured so that the frame ends between the left and right sample pairs, the FRAMESTART event is not generated. This occurs for the following combinations of SWIDTH and MAXCNT:

| SWIDTH    | MAXCNT restriction               |
|-----------|----------------------------------|
| 24Bit     | Only even numbers (2,4,6, etc)   |
| 32        | Only even numbers (2, 4, 6, etc) |
| 24BitIn32 | Only even numbers (2, 4, 6, etc) |

Table 82: Restrictions on combinations of SWIDTH and MAXCNT for correct FRAMESTART



Figure 64: Transmitting and receiving. CONFIG.FORMAT = Aligned, CONFIG.SWIDTH = 8Bit, CONFIG.CHANNELS = Stereo, RXTXD.MAXCNT = 1

# 7.15.3 Left right clock (LRCK)

The left right clock (LRCK), often referred to as word clock, sample clock, or word select in I<sup>2</sup>S context, is the clock defining the frames in serial bitstreams sent and received on SDOUT and SDIN, respectively.

In I2S format, each frame contains one left and/or right sample pair. The left sample is transferred during the low half period of LRCK, followed by the right sample being transferred during the high half period of LRCK.

In Aligned format, each frame contains one left and/or right sample pair. The left sample is transferred during the high half period of LRCK, followed by the right sample being transferred during the low half period of LRCK.

For mono, the frame will contain only zeros for the unused half period of LRCK.

Consequently, the LRCK frequency is equivalent to the audio sample rate.

When operating in Master mode, the LRCK is generated from the MCK, and the frequency of LRCK is then given as:

LRCK = MCK / CONFIG.RATIO



LRCK always toggles around the falling edge of the serial clock SCK.

### 7.15.4 Serial clock (SCK)

The serial clock (SCK), often referred to as the serial bit clock, pulses once for each data bit being transferred on the serial data lines SDIN and SDOUT.

When operating in Master mode, the SCK is generated from the MCK, and the frequency of SCK is then given as:

```
SCK = 2 * LRCK * CONFIG.SWIDTH
```

The falling edge of the SCK falls on the toggling edge of LRCK.

When operating in Slave mode, SCK is provided by the external I<sup>2</sup>S master.

### 7.15.5 Master clock (MCK)

The master clock (MCK) is the clock from which LRCK and SCK are derived when operating in Master mode.

The master clock generator always needs to be enabled when in Master mode, but the generator can also be enabled when in Slave mode. Enabling the generator when in Slave mode can be useful in the case where the external master is not able to generate its own master clock.

MCK is generated from the clock source selected in the CONFIG.CLKCONFIG and CONFIG.MCKFREQ registers.

The following equation can be used to calculate the value of CONFIG.MCKFREQ for given MCK and clock source frequency:

$$MCKFREQ = 4096 \cdot \left[ \frac{f_{MCK} \cdot 1048576}{f_{source} + \frac{f_{MCK}}{2}} \right]$$

Figure 65: MCK clock frequency equation

The parameter  $f_{MCK}$  is the requested MCK clock frequency in Hz, and  $f_{source}$  is the frequency of the selected clock source in Hz. Because of rounding errors, an accurate MCK clock may not be achievable. The equation does not take into account the maximum register value of CONFIG.MCKFREQ on page 263.

The actual MCK frequency can be calculated using the equation below.

$$f_{actual} = \frac{f_{source}}{\left| \frac{1048576 \cdot 4096}{MCKFREQ} \right|}$$

Figure 66: Actual MCK clock frequency

The clock error can be calculated using the equation below. The error e is the percentage difference from the requested  $f_{MCK}$  frequency.

$$e = 100 \cdot \frac{f_{actual} - f_{MCK}}{f_{MCK}} = 100 \cdot \frac{\frac{f_{source}}{1048576.4098} - f_{MCK}}{f_{MCK}}$$

Figure 67: MCK frequency error equation

The master clock generator does not add any jitter to the clock source chosen.

The master clock generator is enabled/disabled using CONFIG.MCKEN on page 262, and the generator is started or stopped by the START or STOP tasks respectively.

The MCK frequency can be adjusted on-the-fly:

• For PCLK32M, by using MCKFREQ

NORDIC

For ACLK, by adjusting the audio clock source, see CLOCK — Clock control on page 73.

In Master mode, the LRCK and the SCK frequencies are closely related as both are derived from MCK and set indirectly through CONFIG.RATIO on page 264 and CONFIG.SWIDTH on page 264.

When configuring these registers, the user is responsible for fulfilling the following requirements:

- 1. The SCK frequency can never exceed the MCK frequency.
- 2. The MCK/LRCK ratio shall be a multiple of 2 \* CONFIG.SWIDTH.

The MCK signal can be routed to an output pin (specified in PSEL.MCK) to supply external I<sup>2</sup>S devices that require the MCK to be supplied from the outside.

When operating in Slave mode, the I<sup>2</sup>S module does not use the MCK and the MCK generator does not need to be enabled.



Figure 68: Relation between RATIO, MCK and LRCK

#### 7.15.5.1 Clock source selection

The clock source for the master clock generator can be selected in the register CONFIG.CLKCONFIG on page 266. Choose one of the following clocks as the clock source:

- 32 MHz peripheral clock (PCLK32M), synchronous to HFCLK.
- Audio PLL clock (ACLK) with configurable frequency.

To improve the master clock accuracy and jitter performance, it is recommended (but not mandatory) that the PCLK32M source is running off the HFXO instead of the HFINT oscillator. The ACLK source requires the use of HFXO. See CLOCK — Clock control on page 73 for more information about starting HFXO for the relevant clock source.

The master clock generator can be bypassed so the MCK clock is derived directly from the input source. This can be configured in the BYPASS field of register CONFIG.CLKCONFIG on page 266.

#### 7.15.5.2 Configuration examples

Configuration examples for CLKCONFIG = PCLK32M on page 248 and Configuration examples for CLKCONFIG = ACLK on page 248 show some configuration examples for popular sample rates, using both the 32 MHz master clock and the Audio PLL clock source.



| Source<br>frequency<br>[Hz] | Requested<br>LRCK [Hz] | RATIO | Requested<br>MCK [Hz] | MCKFREQ   | MCK [Hz] | LRCK [Hz] | LRCK<br>error<br>[%] |
|-----------------------------|------------------------|-------|-----------------------|-----------|----------|-----------|----------------------|
| 32000000                    | 16000                  | 32    | 512000                | 68173824  | 507936   | 15873     | -0.8                 |
| 32000000                    | 16000                  | 64    | 1024000               | 135274496 | 1032258  | 16129     | 0.8                  |
| 32000000                    | 16000                  | 256   | 4096000               | 516685824 | 4000000  | 15625     | -2.3                 |
| 32000000                    | 32000                  | 32    | 1024000               | 135274496 | 1032258  | 32258     | 0.8                  |
| 32000000                    | 32000                  | 64    | 2048000               | 266350592 | 2000000  | 31250     | -2.3                 |
| 32000000                    | 32000                  | 256   | 8192000               | 974741504 | 8000000  | 31250     | -2.3                 |
| 32000000                    | 44100                  | 32    | 1411200               | 185319424 | 1391304  | 43478     | -1.4                 |
| 32000000                    | 44100                  | 64    | 2822400               | 362815488 | 2909090  | 45455     | 3.1                  |
| 32000000                    | 48000                  | 32    | 1536000               | 201326592 | 1523809  | 47619     | -0.8                 |
| 32000000                    | 48000                  | 64    | 3072000               | 393428992 | 3200000  | 50000     | 4.2                  |
| 32000000                    | 96000                  | 32    | 3072000               | 393428992 | 3200000  | 100000    | 4.2                  |
| 32000000                    | 96000                  | 64    | 6144000               | 752402432 | 6400000  | 100000    | 4.2                  |

Table 83: Configuration examples for CLKCONFIG = PCLK32M

| Source<br>frequency<br>[Hz] | Requested<br>LRCK [Hz] | RATIO | Requested<br>MCK [Hz] | MCKFREQ   | MCK [Hz] | LRCK [Hz] | LRCK<br>error<br>[%] |
|-----------------------------|------------------------|-------|-----------------------|-----------|----------|-----------|----------------------|
| 11289600                    | 44100                  | 32    | 1411200               | 505286656 | 1411200  | 44100     | 0                    |
| 11289600                    | 44100                  | 64    | 2822400               | 954433536 | 2822400  | 44100     | 0                    |
| 12288000                    | 16000                  | 32    | 510000                | 175304704 | 512000   | 16000     | 0                    |
| 12288000                    | 16000                  | 64    | 1024000               | 343597056 | 1024000  | 16000     | 0                    |
| 12288000                    | 32000                  | 32    | 1024000               | 343597056 | 1024000  | 32000     | 0                    |
| 12288000                    | 32000                  | 64    | 2048000               | 660762624 | 2048000  | 32000     | 0                    |
| 12288000                    | 48000                  | 32    | 1536000               | 505286656 | 1536000  | 48000     | 0                    |
| 12288000                    | 48000                  | 64    | 3072000               | 954433536 | 3072000  | 48000     | 0                    |
| 12288000                    | 96000                  | 32    | 3072000               | 954433536 | 3072000  | 96000     | 0                    |

Table 84: Configuration examples for CLKCONFIG = ACLK

# 7.15.6 Width, alignment and format

The register CONFIG.SWIDTH on page 264 defines the sample width of the data read and written to memory, as well as the number of SCK clock cycles per half-frame. Figure Aligned format, with CONFIG.SWIDTH configured to 16 bit samples in a 16 bit half-frame on page 249 illustrates a configuration with identical sample and half-frame widths. The number of SCK pulses matches the number of sample bits. Aligned format, with CONFIG.SWIDTH configured to 16-bit samples in a 24-bit half-frame on page 249 illustrates a configuration with greater half-frame width than sample width. The number of SCK pulses are greater than the number of sample bits, with the sample being left-aligned in the half-frame.



Figure 69: Aligned format, with CONFIG.SWIDTH configured to 16 bit samples in a 16 bit half-frame



Figure 70: Aligned format, with CONFIG.SWIDTH configured to 16-bit samples in a 24-bit half-frame

The register CONFIG.FORMAT on page 265 is used to choose whether a word shall be aligned on the LRCK edge, or be delayed one bit period after this edge:

- When using Aligned format, the first bit in a half-frame gets sampled on the first rising edge of SCK following a LRCK edge, as illustrated in Aligned format. Identical sample width and half-frame width.
   Left sample on high level of LRCK on page 249. The left sample is transferred during the high half period of LRCK.
- When using I<sup>2</sup>S format, the first bit in a half-frame (containing one left or right sample) gets sampled on the second rising edge of the SCK after a LRCK edge, as illustrated in I<sup>2</sup>S format. Identical sample width and half-frame width. Left sample on low level of LRCK on page 249. The left sample is transferred during the low half period of LRCK.



Figure 71: Aligned format. Identical sample width and half-frame width. Left sample on high level of LRCK



Figure 72: 1<sup>2</sup>S format. Identical sample width and half-frame width. Left sample on low level of LRCK

If the half-frame width differs from the sample width, the sample value can be either right or left-aligned inside a half-frame, as specified in CONFIG.ALIGN on page 265

- When using left-alignment, each half-frame starts with the MSB of the sample value, as illustrated by CONFIG.ALIGN set to left justified on page 249.
- When using right-alignment, each half-frame ends with the LSB of the sample value. This is illustrated in CONFIG.ALIGN set to right justified on page 250.



Figure 73: CONFIG.ALIGN set to left justified





Figure 74: CONFIG.ALIGN set to right justified

#### Slave mode considerations

In Slave mode, the sample width does not need to equal the half-frame width, or even frame size. This means that there can be extra or fewer SCK pulses per half-frame than what the sample and half-frame widths specified in CONFIG.SWIDTH on page 264 require.

In cases where **left-alignment** is used, and the number of SCK pulses per half-frame is **higher** than the configured width, the following will apply:

- For data received on SDIN, all bits after the least significant bit (LSB) of the word value will be discarded
- For data sent on SDOUT, all bits after the LSB of the word value will be 0.

In cases where **left-alignment** is used, and the number of SCK pulses per frame is **lower** than the word width, the following will apply:

• Data sent and received on SDOUT and SDIN will be truncated with the LSBs being removed first.

In cases where **right-alignment** is used, and the number of SCK pulses per frame is **higher** than the configured width, the following will apply:

- For data received on SDIN, all bits before the MSB of the word value will be discarded.
- For data sent on SDOUT, all bits after the LSB of the word value will be 0 (same behavior as for left-alignment).

In cases where **right-alignment** is used, and the number of SCK pulses per frame is **lower** than the configured width, the following will apply:

- Data received on SDIN will be sign-extended to the same number of bits as the sample width before being written to memory.
- Data sent on SDOUT will be truncated with the LSBs being removed first (same behavior as for left-alignment).

# 7.15.7 EasyDMA

The I<sup>2</sup>S module implements EasyDMA for accessing internal Data RAM without CPU intervention.

The source and destination pointers for the TX and RX data are configured in TXD.PTR on page 266 and RXD.PTR on page 266. The memory pointed to by these pointers will only be read or written when TX or RX are enabled in CONFIG.TXEN on page 262, and CONFIG.RXEN on page 262.

The addresses written to the pointer registers TXD.PTR on page 266 and RXD.PTR on page 266 are double-buffered in hardware. These double buffers are updated for every number of transmitted data words given by RXTXD.MAXCNT on page 267 read from/written to memory. The events TXPTRUPD and RXPTRUPD are generated whenever the TXD.PTR and RXD.PTR are transferred to these double buffers.

If TXD.PTR on page 266 is not pointing to the Data RAM region when transmission is enabled, or RXD.PTR on page 266 is not pointing to the Data RAM region when reception is enabled, an EasyDMA transfer may result in a HardFault and/or memory corruption. See Memory on page 19 for more information about the different memory regions.

Due to the nature of I<sup>2</sup>S, where the number of transmitted samples always equals the number of received samples (at least when both TX and RX are enabled), one common register RXTXD.MAXCNT on page 267 is used for specifying the sizes of these two memory buffers. The size of the buffers is specified in

NORDIC

a number of 32-bit words. Such a 32-bit memory word can either contain one 32-bit sample, one right-aligned 24-bit sample sign extended to 32-bit, two 16-bit samples or four 8-bit samples.

In Stereo mode (CONFIG.CHANNELS on page 265=Stereo), the samples are stored as left and right sample pairs in memory. Memory mapping for 8-bit stereo. CONFIG.SWIDTH = 8Bit, CONFIG.CHANNELS = Stereo. on page 251, Memory mapping for 16-bit stereo. CONFIG.SWIDTH = 16Bit, CONFIG.CHANNELS = Stereo. on page 251 and Memory mapping for 24-bit stereo. CONFIG.SWIDTH = 24Bit, CONFIG.CHANNELS = Stereo. on page 252 show how the samples are mapped to memory in this mode. The mapping is valid for both RX and TX.

In Mono mode (CONFIG.CHANNELS on page 265=Left or Right), RX sample from only one channel in the frame is stored in memory, the other channel sample is ignored. Memory mapping for 8-bit mono. CONFIG.SWIDTH = 8Bit, CONFIG.CHANNELS = Left. on page 251, Memory mapping for 16-bit mono, left channel only. CONFIG.SWIDTH = 16Bit, CONFIG.CHANNELS = Left. on page 252 and Memory mapping for 24-bit mono, left channel only. CONFIG.SWIDTH = 24Bit, CONFIG.CHANNELS = Left. on page 252 show how RX samples are mapped to memory in this mode. For TX, the same outgoing sample read from memory is transmitted on both left and right in a frame, resulting in a mono output stream.

|                   | 31 24               | 23 16              | 15 8                | 7 0                |
|-------------------|---------------------|--------------------|---------------------|--------------------|
| x.PTR             | Right sample 1      | Left sample 1      | Right sample 0      | Left sample 0      |
| x.PTR + 4         | Right sample 3      | Left sample 3      | Right sample 2      | Left sample 2      |
|                   |                     |                    |                     |                    |
| x.PTR + (n*2) - 4 | Right sample<br>n-1 | Left sample<br>n-1 | Right sample<br>n-2 | Left sample<br>n-2 |

Figure 75: Memory mapping for 8-bit stereo. CONFIG.SWIDTH = 8Bit, CONFIG.CHANNELS = Stereo.

|               | 31 24           | 23 16           | 15 8            | 7 0             |
|---------------|-----------------|-----------------|-----------------|-----------------|
| x.PTR         | Left sample 3   | Left sample 2   | Left sample 1   | Left sample 0   |
| x.PTR + 4     | Left sample 7   | Left sample 6   | Left sample 5   | Left sample 4   |
|               |                 |                 |                 |                 |
| x.PTR + n - 4 | Left sample n-1 | Left sample n-2 | Left sample n-3 | Left sample n-4 |

Figure 76: Memory mapping for 8-bit mono. CONFIG.SWIDTH = 8Bit, CONFIG.CHANNELS = Left.

|                   | 31 16              | 15 0              |
|-------------------|--------------------|-------------------|
| x.PTR             | Right sample 0     | Left sample 0     |
| x.PTR + 4         | Right sample 1     | Left sample 1     |
|                   |                    |                   |
| x.PTR + (n*4) - 4 | Right sample n - 1 | Left sample n - 1 |

Figure 77: Memory mapping for 16-bit stereo. CONFIG.SWIDTH = 16Bit, CONFIG.CHANNELS = Stereo.



|                   | 31 16             | 15 0              |
|-------------------|-------------------|-------------------|
| x.PTR             | Left sample 1     | Left sample 0     |
| x.PTR + 4         | Left sample 3     | Left sample 2     |
|                   |                   |                   |
| x.PTR + (n*2) - 4 | Left sample n - 1 | Left sample n - 2 |

Figure 78: Memory mapping for 16-bit mono, left channel only. CONFIG.SWIDTH = 16Bit, CONFIG.CHANNELS = Left.



Figure 79: Memory mapping for 24-bit stereo. CONFIG.SWIDTH = 24Bit, CONFIG.CHANNELS = Stereo.



Figure 80: Memory mapping for 24-bit mono, left channel only. CONFIG.SWIDTH = 24Bit, CONFIG.CHANNELS = Left.



Figure 81: Memory mapping for 32-bit stereo. CONFIG.SWIDTH = 32Bit, CONFIG.CHANNELS = Stereo.





Figure 82: Memory mapping for 32-bit mono, left channel only. CONFIG.SWIDTH = 32Bit, CONFIG.CHANNELS = Left.

## 7.15.8 Module operation

Described here is a typical operating procedure for the I<sup>2</sup>S module.

1. Configure the I<sup>2</sup>S module using the CONFIG registers

```
// Enable reception
NRF I2S->CONFIG.RXEN = (I2S CONFIG RXEN RXEN Enabled <<
                                      12S_CONFIG_RXEN_RXEN_Pos);
// Enable transmission
NRF I2S->CONFIG.TXEN = (I2S CONFIG TXEN TXEN Enabled <<
                                      I2S CONFIG TXEN TXEN Pos);
// Enable MCK generator
NRF I2S->CONFIG.MCKEN = (I2S CONFIG MCKEN MCKEN Enabled <<
                                       12S CONFIG MCKEN MCKEN Pos);
// MCKFREQ = 4 MHz
NRF I2S->CONFIG.MCKFREQ = I2S CONFIG MCKFREQ MCKFREQ 32MDIV8 <<
                                      12S_CONFIG_MCKFREQ_MCKFREQ_Pos;
// Ratio = 256
NRF I2S->CONFIG.RATIO = I2S CONFIG RATIO RATIO 256X <<
                                       12S CONFIG RATIO RATIO Pos;
// MCKFREQ = 4 MHz and Ratio = 256 gives sample rate = 15.625 \text{ ks/s}
// Sample width = 16 bit
NRF I2S->CONFIG.SWIDTH = I2S_CONFIG_SWIDTH_SWIDTH_16Bit <<
                                      12S CONFIG SWIDTH SWIDTH Pos;
// Alignment = Left
NRF I2S->CONFIG.ALIGN = I2S CONFIG ALIGN ALIGN Left <<
                                      12S CONFIG ALIGN ALIGN Pos;
// Format = I2S
NRF I2S->CONFIG.FORMAT = I2S CONFIG FORMAT FORMAT I2S <<
                                      12S CONFIG FORMAT FORMAT Pos;
// Use stereo
NRF I2S->CONFIG.CHANNELS = I2S CONFIG CHANNELS CHANNELS Stereo <<
                                       12S CONFIG CHANNELS CHANNELS Pos;
```



2. Map IO pins using the PINSEL registers

```
// MCK routed to pin 0
NRF_I2S->PSEL.MCK = (0 << I2S_PSEL_MCK_PIN_Pos) |
                   (I2S_PSEL_MCK_CONNECT_Connected <<
                                                 I2S PSEL MCK CONNECT Pos);
// SCK routed to pin 1
NRF I2S->PSEL.SCK = (1 << I2S PSEL SCK PIN Pos) |
                    (I2S PSEL SCK CONNECT Connected <<
                                                 12S_PSEL_SCK_CONNECT_Pos);
// LRCK routed to pin 2
NRF I2S->PSEL.LRCK = (2 << I2S PSEL LRCK PIN Pos) |
                     (I2S PSEL LRCK CONNECT Connected <<
                                                 12S_PSEL_LRCK_CONNECT_Pos);
// SDOUT routed to pin 3
NRF I2S->PSEL.SDOUT = (3 << I2S PSEL SDOUT PIN Pos) |
                     (I2S_PSEL_SDOUT_CONNECT_Connected <<
                                                12S_PSEL_SDOUT_CONNECT_Pos);
// SDIN routed on pin 4
NRF_I2S->PSEL.SDIN = (4 << I2S_PSEL_SDIN_PIN_POs) |
                     (I2S PSEL SDIN CONNECT Connected <<
                                                 12S PSEL SDIN CONNECT Pos);
```

3. Configure TX and RX data pointers using the TXD, RXD and RXTXD registers

```
NRF_I2S->TXD.PTR = my_tx_buf;
NRF_I2S->RXD.PTR = my_rx_buf;
NRF_I2S->TXD.MAXCNT = MY_BUF_SIZE;
```

4. Enable the I<sup>2</sup>S module using the ENABLE register

```
NRF_I2S->ENABLE = 1;
```

5. Start audio streaming using the START task

```
NRF_I2S->TASKS_START = 1;
```

6. Handle received and transmitted data when receiving the TXPTRUPD and RXPTRUPD events

```
if(NRF_I2S->EVENTS_TXPTRUPD != 0)
{
    NRF_I2S->TXD.PTR = my_next_tx_buf;
    NRF_I2S->EVENTS_TXPTRUPD = 0;
}

if(NRF_I2S->EVENTS_RXPTRUPD != 0)
{
    NRF_I2S->RXD.PTR = my_next_rx_buf;
    NRF_I2S->EVENTS_RXPTRUPD = 0;
}
```



## 7.15.9 Pin configuration

The MCK, SCK, LRCK, SDIN and SDOUT signals associated with the I<sup>2</sup>S module are mapped to physical pins according to the pin numbers specified in the PSEL.x registers.

These pins are acquired whenever the I<sup>2</sup>S module is enabled through the register ENABLE on page 261.

When a pin is acquired by the I<sup>2</sup>S module, the direction of the pin (input or output) will be configured automatically, and any pin direction setting done in the GPIO module will be overridden. The directions for the various I<sup>2</sup>S pins are shown below in GPIO configuration before enabling peripheral (Master mode) on page 255 and GPIO configuration before enabling peripheral (Slave mode) on page 255.

To secure correct signal levels on the pins in System OFF mode, and when the I<sup>2</sup>S module is disabled, these pins must be configured in the GPIO peripheral directly.

| I <sup>2</sup> S signal | I <sup>2</sup> S pin       | Direction | Output value   | Comment |
|-------------------------|----------------------------|-----------|----------------|---------|
| MCK                     | As specified in PSEL.MCK   | Output    | 0              |         |
| LRCK                    | As specified in PSEL.LRCK  | Output    | 0              |         |
| SCK                     | As specified in PSEL.SCK   | Output    | 0              |         |
| SDIN                    | As specified in PSEL.SDIN  | Input     | Not applicable |         |
| SDOUT                   | As specified in PSEL.SDOUT | Output    | 0              |         |

Table 85: GPIO configuration before enabling peripheral (Master mode)

| I <sup>2</sup> S signal | I <sup>2</sup> S pin       | Direction | Output value   | Comment |
|-------------------------|----------------------------|-----------|----------------|---------|
| МСК                     | As specified in PSEL.MCK   | Output    | 0              |         |
| LRCK                    | As specified in PSEL.LRCK  | Input     | Not applicable |         |
| SCK                     | As specified in PSEL.SCK   | Input     | Not applicable |         |
| SDIN                    | As specified in PSEL.SDIN  | Input     | Not applicable |         |
| SDOUT                   | As specified in PSEL.SDOUT | Output    | 0              |         |

Table 86: GPIO configuration before enabling peripheral (Slave mode)

# 7.15.10 Registers

| Base address Domain      | Peripheral | Instance  | Secure mapping | DMA security | Description              | Configuration |
|--------------------------|------------|-----------|----------------|--------------|--------------------------|---------------|
| 0x50028000<br>APPLICATIO | N I2C      | 12S0 : S  | US             | SA           | Inter-IC sound interface |               |
| 0x40028000               | IN 125     | 12S0 : NS | US             | SA           | inter-ic sound interface |               |

Table 87: Instances

| Register        | Offset | Security | Description                                                                     |
|-----------------|--------|----------|---------------------------------------------------------------------------------|
| TASKS_START     | 0x000  |          | Starts continuous I2S transfer. Also starts MCK generator when this is enabled  |
| TASKS_STOP      | 0x004  |          | Stops I2S transfer and MCK generator. Triggering this task will cause the event |
|                 |        |          | STOPPED to be generated.                                                        |
| SUBSCRIBE_START | 0x080  |          | Subscribe configuration for task START                                          |
| SUBSCRIBE_STOP  | 0x084  |          | Subscribe configuration for task STOP                                           |
| EVENTS_RXPTRUPD | 0x104  |          | The RXD.PTR register has been copied to internal double-buffers. When the       |
|                 |        |          | 12S module is started and RX is enabled, this event will be generated for every |
|                 |        |          | RXTXD.MAXCNT words received on the SDIN pin.                                    |
| EVENTS_STOPPED  | 0x108  |          | 12S transfer stopped.                                                           |
| EVENTS_TXPTRUPD | 0x114  |          | The TDX.PTR register has been copied to internal double-buffers. When the       |
|                 |        |          | 12S module is started and TX is enabled, this event will be generated for every |
|                 |        |          | RXTXD.MAXCNT words that are sent on the SDOUT pin.                              |



| Register           | Offset | Security | Description                                             |
|--------------------|--------|----------|---------------------------------------------------------|
| EVENTS_FRAMESTART  | 0x11C  |          | Frame start event, generated on the active edge of LRCK |
| PUBLISH_RXPTRUPD   | 0x184  |          | Publish configuration for event RXPTRUPD                |
| PUBLISH_STOPPED    | 0x188  |          | Publish configuration for event STOPPED                 |
| PUBLISH_TXPTRUPD   | 0x194  |          | Publish configuration for event TXPTRUPD                |
| PUBLISH_FRAMESTART | 0x19C  |          | Publish configuration for event FRAMESTART              |
| INTEN              | 0x300  |          | Enable or disable interrupt                             |
| INTENSET           | 0x304  |          | Enable interrupt                                        |
| INTENCLR           | 0x308  |          | Disable interrupt                                       |
| ENABLE             | 0x500  |          | Enable I2S module                                       |
| CONFIG.MODE        | 0x504  |          | I2S mode                                                |
| CONFIG.RXEN        | 0x508  |          | Reception (RX) enable                                   |
| CONFIG.TXEN        | 0x50C  |          | Transmission (TX) enable                                |
| CONFIG.MCKEN       | 0x510  |          | Master clock generator enable                           |
| CONFIG.MCKFREQ     | 0x514  |          | I2S clock generator control                             |
| CONFIG.RATIO       | 0x518  |          | MCK / LRCK ratio                                        |
| CONFIG.SWIDTH      | 0x51C  |          | Sample width                                            |
| CONFIG.ALIGN       | 0x520  |          | Alignment of sample within a frame                      |
| CONFIG.FORMAT      | 0x524  |          | Frame format                                            |
| CONFIG.CHANNELS    | 0x528  |          | Enable channels                                         |
| CONFIG.CLKCONFIG   | 0x52C  |          | Clock source selection for the I2S module               |
| RXD.PTR            | 0x538  |          | Receive buffer RAM start address.                       |
| TXD.PTR            | 0x540  |          | Transmit buffer RAM start address                       |
| RXTXD.MAXCNT       | 0x550  |          | Size of RXD and TXD buffers                             |
| PSEL.MCK           | 0x560  |          | Pin select for MCK signal                               |
| PSEL.SCK           | 0x564  |          | Pin select for SCK signal                               |
| PSEL.LRCK          | 0x568  |          | Pin select for LRCK signal                              |
| PSEL.SDIN          | 0x56C  |          | Pin select for SDIN signal                              |
| PSEL.SDOUT         | 0x570  |          | Pin select for SDOUT signal                             |

Table 88: Register overview

## 7.15.10.1 TASKS\_START

Address offset: 0x000

Starts continuous I2S transfer. Also starts MCK generator when this is enabled



## 7.15.10.2 TASKS\_STOP

Address offset: 0x004

Stops I2S transfer and MCK generator. Triggering this task will cause the event STOPPED to be generated.







## 7.15.10.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



### 7.15.10.4 SUBSCRIBE\_STOP

Address offset: 0x084

Subscribe configuration for task STOP



### 7.15.10.5 EVENTS\_RXPTRUPD

Address offset: 0x104

The RXD.PTR register has been copied to internal double-buffers. When the I2S module is started and RX is enabled, this event will be generated for every RXTXD.MAXCNT words received on the SDIN pin.





### 7.15.10.6 EVENTS\_STOPPED

Address offset: 0x108 I2S transfer stopped.



### 7.15.10.7 EVENTS TXPTRUPD

Address offset: 0x114

The TDX.PTR register has been copied to internal double-buffers. When the I2S module is started and TX is enabled, this event will be generated for every RXTXD.MAXCNT words that are sent on the SDOUT pin.



### 7.15.10.8 EVENTS\_FRAMESTART

Address offset: 0x11C

Frame start event, generated on the active edge of LRCK





## 7.15.10.9 PUBLISH\_RXPTRUPD

Address offset: 0x184

Publish configuration for event RXPTRUPD

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A A                                                   |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |          |                         | Description                                                     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that event RXPTRUPD will publish to.               |
| В     | RW       | EN    |          |                         |                                                                 |
|       |          |       | Disabled | 0                       | Disable publishing                                              |
|       |          |       | Enabled  | 1                       | Enable publishing                                               |

### 7.15.10.10 PUBLISH\_STOPPED

Address offset: 0x188

Publish configuration for event STOPPED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                     |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event STOPPED will publish to.                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

### 7.15.10.11 PUBLISH\_TXPTRUPD

Address offset: 0x194

Publish configuration for event TXPTRUPD





# 7.15.10.12 PUBLISH\_FRAMESTART

Address offset: 0x19C

Publish configuration for event FRAMESTART

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event FRAMESTART will publish to.           |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 1                       | Enable publishing                                             |

### 7.15.10.13 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit n | umber    |            |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |            |          |                         | H F C B                                                         |
| Rese  | et 0x000 | 00000      |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |            |          |                         |                                                                 |
| В     | RW       | RXPTRUPD   |          |                         | Enable or disable interrupt for event RXPTRUPD                  |
|       |          |            | Disabled | 0                       | Disable                                                         |
|       |          |            | Enabled  | 1                       | Enable                                                          |
| С     | RW       | STOPPED    |          |                         | Enable or disable interrupt for event STOPPED                   |
|       |          |            | Disabled | 0                       | Disable                                                         |
|       |          |            | Enabled  | 1                       | Enable                                                          |
| F     | RW       | TXPTRUPD   |          |                         | Enable or disable interrupt for event TXPTRUPD                  |
|       |          |            | Disabled | 0                       | Disable                                                         |
|       |          |            | Enabled  | 1                       | Enable                                                          |
| Н     | RW       | FRAMESTART |          |                         | Enable or disable interrupt for event FRAMESTART                |
|       |          |            | Disabled | 0                       | Disable                                                         |
|       |          |            | Enabled  | 1                       | Enable                                                          |
|       |          |            |          |                         |                                                                 |

### 7.15.10.14 INTENSET

Address offset: 0x304

Enable interrupt

| Bit r | umber    |          |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |          |          |                         | H F C B                                                         |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |          |          |                         |                                                                 |
| В     | RW       | RXPTRUPD |          |                         | Write '1' to enable interrupt for event RXPTRUPD                |
|       |          |          | Set      | 1                       | Enable                                                          |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | STOPPED  |          |                         | Write '1' to enable interrupt for event STOPPED                 |
|       |          |          | Set      | 1                       | Enable                                                          |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |





| D:+   |         |            |          | 21 20 20 20 27 26 25 2  | 122 22 21 20 10 10 17 16 17 14 12 12 11 10 0 0 7 6 7 4 2 2 1 0             |
|-------|---------|------------|----------|-------------------------|----------------------------------------------------------------------------|
| BIT N | umber   |            |          | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| ID    |         |            |          |                         | H F C B                                                                    |
| Rese  | t 0x000 | 00000      |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
| ID    |         |            |          |                         |                                                                            |
|       |         |            | Enabled  | 1                       | Read: Enabled                                                              |
| F     | RW      | TXPTRUPD   |          |                         | Write '1' to enable interrupt for event TXPTRUPD                           |
|       |         |            | Set      | 1                       | Enable                                                                     |
|       |         |            | Disabled | 0                       | Read: Disabled                                                             |
|       |         |            | Enabled  | 1                       | Read: Enabled                                                              |
| Н     | RW      | FRAMESTART |          |                         | Write '1' to enable interrupt for event FRAMESTART                         |
|       |         |            | Set      | 1                       | Enable                                                                     |
|       |         |            | Disabled | 0                       | Read: Disabled                                                             |
|       |         |            | Enabled  | 1                       | Read: Enabled                                                              |

## 7.15.10.15 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber   |            |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |            |          |                        | H F C B                                                         |
| Rese  | t 0x000 | 00000      |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |            |          |                        | Description                                                     |
| В     | RW      | RXPTRUPD   |          |                        | Write '1' to disable interrupt for event RXPTRUPD               |
|       |         |            | Clear    | 1                      | Disable                                                         |
|       |         |            | Disabled | 0                      | Read: Disabled                                                  |
|       |         |            | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW      | STOPPED    |          |                        | Write '1' to disable interrupt for event STOPPED                |
|       |         |            | Clear    | 1                      | Disable                                                         |
|       |         |            | Disabled | 0                      | Read: Disabled                                                  |
|       |         |            | Enabled  | 1                      | Read: Enabled                                                   |
| F     | RW      | TXPTRUPD   |          |                        | Write '1' to disable interrupt for event TXPTRUPD               |
|       |         |            | Clear    | 1                      | Disable                                                         |
|       |         |            | Disabled | 0                      | Read: Disabled                                                  |
|       |         |            | Enabled  | 1                      | Read: Enabled                                                   |
| Н     | RW      | FRAMESTART |          |                        | Write '1' to disable interrupt for event FRAMESTART             |
|       |         |            | Clear    | 1                      | Disable                                                         |
|       |         |            | Disabled | 0                      | Read: Disabled                                                  |
|       |         |            | Enabled  | 1                      | Read: Enabled                                                   |

## 7.15.10.16 ENABLE

Address offset: 0x500 Enable I2S module

| Bit n | umber   |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |        |          |                         | A                                                               |
| Rese  | t 0x000 | 00000  |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |        |          |                         |                                                                 |
| Α     | RW      | ENABLE |          |                         | Enable I2S module                                               |
|       |         |        | Disabled | 0                       | Disable                                                         |
|       |         |        | Enabled  | 1                       | Enable                                                          |





#### 7.15.10.17 CONFIG.MODE

Address offset: 0x504

12S mode



#### 7.15.10.18 CONFIG.RXEN

Address offset: 0x508 Reception (RX) enable



#### 7.15.10.19 CONFIG.TXEN

Address offset: 0x50C Transmission (TX) enable



#### 7.15.10.20 CONFIG.MCKEN

Address offset: 0x510

Master clock generator enable



| Bit n | umber    |       |          | 31 30 29 28 27 26 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------|-----------------------------------------------------------------------|
| ID    |          |       |          |                   | А                                                                     |
| Rese  | et 0x000 | 00001 |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |       |          |                   |                                                                       |
| Α     | RW       | MCKEN |          |                   | Master clock generator enable                                         |
|       |          |       | Disabled | 0                 | Master clock generator disabled and PSEL.MCK not                      |
|       |          |       |          |                   | connected(available as GPIO).                                         |
|       |          |       | Enabled  | 1                 | Master clock generator running and MCK output on                      |
|       |          |       |          |                   | PSEL.MCK.                                                             |

## 7.15.10.21 CONFIG.MCKFREQ

Address offset: 0x514

I2S clock generator control

| Bit n | umber    |         |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|----------|---------|----------|------------------------|----------------------------------------------------------------|
| ID    |          |         |          | A A A A A A A          | A A A A A A A A A A A A A A A A A A A                          |
| Rese  | et 0x200 | 00000   |          | 0 0 1 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                        |
|       |          |         |          |                        |                                                                |
| Α     | RW       | MCKFREQ |          |                        | I2S MCK frequency configuration                                |
|       |          |         |          |                        | NOTE: Enumerations are deprecated, use MCKFREQ                 |
|       |          |         |          |                        | equation.                                                      |
|       |          |         |          |                        | NOTE: The 12 least significant bits of the register are        |
|       |          |         |          |                        | ignored and shall be set to zero.                              |
|       |          |         | 32MDIV2  | 0x80000000             | 32 MHz / 2 = 16.0 MHz                                          |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV3  | 0x50000000             | 32 MHz / 3 = 10.6666667 MHz                                    |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV4  | 0x40000000             | 32 MHz / 4 = 8.0 MHz                                           |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV5  | 0x30000000             | 32 MHz / 5 = 6.4 MHz                                           |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV6  | 0x28000000             | 32 MHz / 6 = 5.3333333 MHz                                     |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV8  | 0x20000000             | 32 MHz / 8 = 4.0 MHz                                           |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV10 | 0x18000000             | 32 MHz / 10 = 3.2 MHz                                          |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV11 | 0x16000000             | 32 MHz / 11 = 2.9090909 MHz                                    |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV15 | 0x11000000             | 32 MHz / 15 = 2.1333333 MHz                                    |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV16 | 0x10000000             | 32 MHz / 16 = 2.0 MHz                                          |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV21 | 0x0C000000             | 32 MHz / 21 = 1.5238095 MHz                                    |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |
|       |          |         | 32MDIV23 | 0x0B000000             | 32 MHz / 23 = 1.3913043 MHz                                    |
|       |          |         |          |                        | Deprecated, use MCKFREQ equation.                              |



| Bit number       |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|------------|------------------------|-----------------------------------------------------------------|
| ID               |            | A A A A A A A          | A A A A A A A A A A A A A A A A A A A                           |
| Reset 0x20000000 |            | 0 0 1 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field     |            |                        | Description                                                     |
|                  | 32MDIV30   | 0x0880000              | 32 MHz / 30 = 1.0666667 MHz                                     |
|                  |            |                        | Deprecated, use MCKFREQ equation.                               |
|                  | 32MDIV31   | 0x08400000             | 32 MHz / 31 = 1.0322581 MHz                                     |
|                  |            |                        | Deprecated, use MCKFREQ equation.                               |
|                  | 32MDIV32   | 0x08000000             | 32 MHz / 32 = 1.0 MHz                                           |
|                  |            |                        | Deprecated, use MCKFREQ equation.                               |
|                  | 32MDIV42   | 0x06000000             | 32 MHz / 42 = 0.7619048 MHz                                     |
|                  |            |                        | ,                                                               |
|                  | 32MDIV63   | 0x04100000             | Deprecated, use MCKFREQ equation.  32 MHz / 63 = 0.5079365 MHz  |
|                  | 321/101/03 | 0x04100000             | 32 MINZ / 03 = 0.3079303 MINZ                                   |
|                  |            |                        | Deprecated, use MCKFREQ equation.                               |
|                  | 32MDIV125  | 0x020C0000             | 32 MHz / 125 = 0.256 MHz                                        |
|                  |            |                        | Deprecated, use MCKFREQ equation.                               |

## 7.15.10.22 CONFIG.RATIO

Address offset: 0x518

MCK / LRCK ratio

| Bit n | umber    |       |      | 31 30 29 28 | 3 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|------|-------------|-----------------------------------------------------------------------------|
| ID    |          |       |      |             | ААА                                                                         |
| Rese  | et 0x000 | 00006 |      | 0 0 0 0     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                     |
| ID    |          |       |      |             |                                                                             |
| Α     | RW       | RATIO |      |             | MCK / LRCK ratio                                                            |
|       |          |       | 32X  | 0           | LRCK = MCK / 32                                                             |
|       |          |       | 48X  | 1           | LRCK = MCK / 48                                                             |
|       |          |       | 64X  | 2           | LRCK = MCK / 64                                                             |
|       |          |       | 96X  | 3           | LRCK = MCK / 96                                                             |
|       |          |       | 128X | 4           | LRCK = MCK / 128                                                            |
|       |          |       | 192X | 5           | LRCK = MCK / 192                                                            |
|       |          |       | 256X | 6           | LRCK = MCK / 256                                                            |
|       |          |       | 384X | 7           | LRCK = MCK / 384                                                            |
|       |          |       | 512X | 8           | LRCK = MCK / 512                                                            |

## 7.15.10.23 CONFIG.SWIDTH

Address offset: 0x51C

Sample width





#### 7.15.10.24 CONFIG.ALIGN

Address offset: 0x520

Alignment of sample within a frame



#### 7.15.10.25 CONFIG.FORMAT

Address offset: 0x524

Frame format



### 7.15.10.26 CONFIG.CHANNELS

Address offset: 0x528

**Enable channels** 





### 7.15.10.27 CONFIG.CLKCONFIG

Address offset: 0x52C

Clock source selection for the I2S module

| Bit r | number   |        |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |          |        |         |                         | В А                                                             |
| Rese  | et 0x000 | 000000 |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |        |         |                         | Description                                                     |
| Α     | RW       | CLKSRC |         |                         | Clock source selection                                          |
|       |          |        | PCLK32M | 0                       | 32MHz peripheral clock                                          |
|       |          |        | ACLK    | 1                       | Audio PLL clock                                                 |
| В     | RW       | BYPASS |         |                         | Bypass clock generator. MCK will be equal to source input.      |
|       |          |        |         |                         | If bypass is enabled the MCKFREQ setting has no effect.         |
|       |          |        | Disable | 0                       | Disable bypass                                                  |
|       |          |        | Enable  | 1                       | Enable bypass                                                   |

#### 7.15.10.28 RXD.PTR

Address offset: 0x538

Receive buffer RAM start address.

| Bit r | number   |       |  |  |  | 3 | 1 30 | 0 29 | 28 | 27 | 26 2 | 5 24 | 4 23 | 3 22  | 2 21 | . 20  | 19 :   | 18 1          | 7 16 | 5 15  | 14   | 13 : | 12 1 | 11 1 | 0 9 | 8    | 7  | 6   | 5        | 4 3 | 3 2 | 1 | 0 |
|-------|----------|-------|--|--|--|---|------|------|----|----|------|------|------|-------|------|-------|--------|---------------|------|-------|------|------|------|------|-----|------|----|-----|----------|-----|-----|---|---|
| ID    |          |       |  |  |  | А | ι A  | A    | Α  | Α  | A A  | Δ Δ  | A    | A     | A    | Α     | Α      | ΑА            | A    | Α     | Α    | Α    | Α    | A A  | A   | Α    | Α  | Α   | Α.       | A A | A A | Α | Α |
| Res   | et 0x000 | 00000 |  |  |  | 0 | 0    | 0    | 0  | 0  | 0 (  | 0    | 0    | 0     | 0    | 0     | 0      | 0 0           | 0    | 0     | 0    | 0    | 0    | 0 0  | 0   | 0    | 0  | 0   | 0        | 0 ( | 0   | 0 | 0 |
| ID    |          |       |  |  |  |   |      |      |    |    |      |      |      |       |      |       |        |               |      |       |      |      |      |      |     |      |    |     |          |     |     |   |   |
| Α     | RW       | PTR   |  |  |  |   |      |      |    |    |      |      |      |       |      |       |        | Data<br>ng sa |      |       |      |      |      |      |     |      |    |     | <i>-</i> |     |     |   |   |
|       |          |       |  |  |  |   |      |      |    |    |      |      | Tł   | his a | add  | lress | s is a | a wo          | rd a | aligi | ned  | Dat  | ta R | RAM  | ado | dres | s. |     |          |     |     |   |   |
|       |          |       |  |  |  |   |      |      |    |    |      |      |      |       | No   | te:   | See    | the           | me   | emo   | ry o | chap | oter | for  | det | ails | ab | out |          |     |     |   |   |

**Note:** See the memory chapter for details about which memories are available for EasyDMA.

#### 7.15.10.29 TXD.PTR

Address offset: 0x540

Transmit buffer RAM start address





#### 7.15.10.30 RXTXD.MAXCNT

Address offset: 0x550

Size of RXD and TXD buffers



#### 7.15.10.31 PSEL.MCK

Address offset: 0x560
Pin select for MCK signal



#### 7.15.10.32 PSEL.SCK

Address offset: 0x564
Pin select for SCK signal





#### 7.15.10.33 PSEL.LRCK

Address offset: 0x568

Pin select for LRCK signal

| Bit n | umber   |         |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    | D       |         |              | С                       | ВАААА                                                           |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |         |         |              |                         |                                                                 |
| Α     | RW      | PIN     |              | [031]                   | Pin number                                                      |
| В     | RW      | PORT    |              | [01]                    | Port number                                                     |
| С     | RW      | CONNECT |              |                         | Connection                                                      |
|       |         |         | Disconnected | 1                       | Disconnect                                                      |
|       |         |         | Connected    | 0                       | Connect                                                         |

#### 7.15.10.34 PSEL.SDIN

Address offset: 0x56C

Pin select for SDIN signal



### 7.15.10.35 PSEL.SDOUT

Address offset: 0x570

Pin select for SDOUT signal





## 7.15.11 Electrical specification

## 7.15.11.1 I2S timing specification

| Symbol                | Description                        | Min. | Тур. | Max.  | Units |
|-----------------------|------------------------------------|------|------|-------|-------|
| $t_{S\_SDIN}$         | SDIN setup time before SCK rising  | 20   |      |       | ns    |
| t <sub>H_SDIN</sub>   | SDIN hold time after SCK rising    | 15   |      |       | ns    |
| t <sub>S_SDOUT</sub>  | SDOUT setup time after SCK falling | 50   |      |       | ns    |
| t <sub>H_SDOUT</sub>  | SDOUT hold time after SCK falling  | 13   |      |       | ns    |
| t <sub>SCK_LRCK</sub> | SCLK falling to LRCK edge          | -5   | 0    | 5     | ns    |
| $f_{\text{MCK}}$      | MCK frequency                      |      |      | 12288 | kHz   |
| $f_{LRCK}$            | LRCK frequency                     |      |      | 96    | kHz   |
| f <sub>SCK</sub>      | SCK frequency                      |      |      | 8000  | kHz   |
| DC <sub>CK</sub>      | Clock duty cycle (MCK, LRCK, SCK)  | 45   |      | 55    | %     |



Figure 83: I2S timing diagram

# 7.16 IPC — Interprocessor communication

The interprocessor communication (IPC) peripheral is used to send and receive events between MCUs in the system.

The following figure illustrates the IPC peripheral in a multi-MCU system, where each MCU has one dedicated IPC peripheral. The IPC peripheral can be used to send and receive events to and from other IPC peripherals.





Figure 84: IPC block diagram

An instance of the IPC peripheral can have multiple SEND tasks and RECEIVE events. A single SEND task can be configured to signal an event on one or more IPC channels, and a RECEIVE event can be configured to listen on one or more IPC channels. The IPC channels that are triggered in a SEND task can be configured through the SEND\_CNF registers, and the IPC channels that trigger a RECEIVE event are configured through the RECEIVE\_CNF registers. The figure below illustrates how the SEND\_CNF and RECEIVE\_CNF registers work. Both the SEND task and the RECEIVE event can be connected to all IPC channels.





Figure 85: IPC registers SEND\_CNF and RECEIVE\_CNF

A SEND task can be viewed as broadcasting events onto one or more IPC channels, and a RECEIVE event can be seen as subscribing to a subset of IPC channels. It is possible for multiple IPCs to trigger events onto the same PPI channel at the same time. When two or more events on the same channel occur within  $t_{IPC}$ , the events may be merged into a single event seen from the IPC receiver. One of the events can therefore be lost. To prevent this, the user must ensure that events on the same IPC channel do not occur within  $t_{IPC}$  of each other. When implementing firmware data structures, such as queues or mailboxes, this can be done by using one IPC channel for acknowledgements.

An IPC event often does not contain any data itself, it is used to signal other MCUs that something has occurred. Data can be shared through shared memory, for example in the form of a software implemented mailbox, or command/event queues. It is up to software to assign a logical functionality to an IPC channel. For instance, one IPC channel can be used to signal that a command is ready to be executed, and any processor in the system can subscribe to that particular IPC channel and decode/execute the command.

#### **General purpose memory**

The GPMEM registers can be used freely to store information. These registers are accessed like any other of the IPC peripheral's registers. Note that the contents of the GPMEM registers are not shared between the instances of the peripherals. I.e. writing the GPMEM register of one peripheral does not change the value in another.

#### 7.16.1 IPC and PPI connections

The IPC SEND tasks and RECEIVE events can be connected through PPI channels. This makes it possible to relay events from peripherals in one MCU to another, without CPU involvement.

Figure below illustrates a timer COMPARE event that is relayed from one MCU to IPC using PPI, then back into a timer CAPTURE event in another MCU.

NORDIC



Figure 86: Example of PPI and IPC connections

# 7.16.2 Registers

| Base address Domain       | Peripheral | Instance | Secure mapping | DMA security | Description    | Configuration |
|---------------------------|------------|----------|----------------|--------------|----------------|---------------|
| 0x5002A000<br>APPLICATION | N IDC      | IPC:S    | US             | NA           | Interprocessor |               |
| 0x4002A000                | VIFC       | IPC : NS | 03             | NA           | communication  |               |
| 0x41012000 NETWORK        | IPC        | IPC      | NS             | NA           | Interprocessor |               |
|                           |            |          |                |              | communication  |               |

Table 89: Instances

| Register           | Offset | Security | Description                                                                 |
|--------------------|--------|----------|-----------------------------------------------------------------------------|
| TASKS_SEND[n]      | 0x000  |          | Trigger events on IPC channel enabled in SEND_CNF[n]                        |
| SUBSCRIBE_SEND[n]  | 0x080  |          | Subscribe configuration for task SEND[n]                                    |
| EVENTS_RECEIVE[n]  | 0x100  |          | Event received on one or more of the enabled IPC channels in RECEIVE_CNF[n] |
| PUBLISH_RECEIVE[n] | 0x180  |          | Publish configuration for event RECEIVE[n]                                  |
| INTEN              | 0x300  |          | Enable or disable interrupt                                                 |
| INTENSET           | 0x304  |          | Enable interrupt                                                            |
| INTENCLR           | 0x308  |          | Disable interrupt                                                           |
| INTPEND            | 0x30C  |          | Pending interrupts                                                          |
| SEND_CNF[n]        | 0x510  |          | Send event configuration for TASKS_SEND[n]                                  |
| RECEIVE_CNF[n]     | 0x590  |          | Receive event configuration for EVENTS_RECEIVE[n]                           |
| GPMEM[n]           | 0x610  |          | General purpose memory                                                      |

Table 90: Register overview

## 7.16.2.1 TASKS\_SEND[n] (n=0..15)

Address offset:  $0x000 + (n \times 0x4)$ 

Trigger events on IPC channel enabled in SEND\_CNF[n]





### 7.16.2.2 SUBSCRIBE\_SEND[n] (n=0..15)

Address offset:  $0x080 + (n \times 0x4)$ 

Subscribe configuration for task SEND[n]



## 7.16.2.3 EVENTS\_RECEIVE[n] (n=0..15)

Address offset:  $0x100 + (n \times 0x4)$ 

Event received on one or more of the enabled IPC channels in RECEIVE\_CNF[n]



#### 7.16.2.4 PUBLISH RECEIVE[n] (n=0..15)

Address offset:  $0x180 + (n \times 0x4)$ 

Publish configuration for event RECEIVE[n]



#### 7.16.2.5 INTEN

Address offset: 0x300

Enable or disable interrupt



| Bit number                |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|---------------------------|----------|------------------------|-----------------------------------------------------------------|
| ID                        |          |                        | PONMLKJIHGFEDCBA                                                |
| Reset 0x00000000          |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field              |          |                        | Description                                                     |
| A-P RW RECEIVE[i] (i=015) |          |                        | Enable or disable interrupt for event RECEIVE[i]                |
|                           | Disabled | 0                      | Disable                                                         |
|                           | Enabled  | 1                      | Enable                                                          |

### 7.16.2.6 INTENSET

Address offset: 0x304

Enable interrupt

| Bit nu | umber   |                    |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------|---------|--------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID     |         |                    |          |                         | PONMLKJIHGFEDCBA                                                |
| Reset  | t 0x000 | 00000              |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID     |         |                    |          |                         |                                                                 |
| A-P    | RW      | RECEIVE[i] (i=015) |          |                         | Write '1' to enable interrupt for event RECEIVE[i]              |
|        |         |                    | Set      | 1                       | Enable                                                          |
|        |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|        |         |                    | Enabled  | 1                       | Read: Enabled                                                   |

# 7.16.2.7 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber   |                    |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------------|----------|-------------------------|---------------------------------------------------------------|
| ID    | ID      |                    |          |                         | PONMLKJIHGFEDCBA                                              |
| Rese  | t 0x000 | 00000              |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |                    |          |                         |                                                               |
| A-P   | RW      | RECEIVE[i] (i=015) |          |                         | Write '1' to disable interrupt for event RECEIVE[i]           |
|       |         |                    | Clear    | 1                       | Disable                                                       |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                 |

### 7.16.2.8 INTPEND

Address offset: 0x30C

Pending interrupts

| Bit n | umber   |                    |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------------|------------|------------------------|-----------------------------------------------------------------|
| ID    |         |                    |            |                        | PONMLKJIHGFEDCBA                                                |
| Rese  | t 0x000 | 00000              |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |         |                    |            |                        |                                                                 |
| A-P   | R       | RECEIVE[i] (i=015) |            |                        | Read pending status of interrupt for event RECEIVE[i]           |
|       |         |                    | NotPending | 0                      | Read: Not pending                                               |
|       |         |                    | Pending    | 1                      | Read: Pending                                                   |

## 7.16.2.9 SEND\_CNF[n] (n=0..15)

Address offset:  $0x510 + (n \times 0x4)$ 



#### Send event configuration for TASKS\_SEND[n]



### 7.16.2.10 RECEIVE CNF[n] (n=0..15)

Address offset:  $0x590 + (n \times 0x4)$ 

Receive event configuration for EVENTS\_RECEIVE[n]



## 7.16.2.11 GPMEM[n] (n=0..1)

Address offset:  $0x610 + (n \times 0x4)$ 

General purpose memory

Retained only in System ON mode



## 7.16.3 Electrical specification

### 7.16.3.1 IPC Electrical Specification

| Symbol           | Description                                       | Min. | Тур. | Max. | Units |
|------------------|---------------------------------------------------|------|------|------|-------|
| t <sub>IPC</sub> | Time window during which IPC events can be merged |      |      |      | μs    |

# 7.17 KMU — Key management unit

The key management unit (KMU) enforces access policies to a subset region of user information configuration register (UICR). This subset region is used for storing cryptographic key values inside the key slots, which the CPU has no access to.

In total there are 128 key slots available, where each key slot can store one 128-bit key value together with an access policy and a destination address for the key value. Multiple key slots can be combined in order



to support key sizes larger than 128 bits. The access policy of a key slot governs if and how a key value can be used, while the destination address determines where in the memory map the KMU pushes the key value upon a request from the CPU.

Key slots can be configured to be pushed directly into write-only key registers in cryptographic accelerators, like e.g. CryptoCell, without exposing the key value itself to the CPU. This enables the CPU to use the key values stored inside the key slots for cryptographic operations without being exposed to the key value.

Access to the KMU, and the key slots in the UICR, is only allowed from secure mode.

#### 7.17.1 Functional view

From a functional view the UICR is divided into two different regions, one-time programmable (OTP) memory and key storage.



Figure 87: Memory map overview

One-time programmable (OTP) memory is typically used for holding values that are written once, and then never to be changed again throughout the product lifetime. The OTP region of UICR is emulated by placing a write-once per halfword limitation on registers defined here.

The key storage region contains multiple key slots, where each slot consists of a key header and an associated key value. The key value is limited to 128 bits. Any key size greater than 128 bits must be divided and distributed over multiple key slot instances.

Key headers are allocated an address range of 0x400 in the UICR memory map, allowing a total of 128 keys to be addressable inside the key storage region.

**Note:** The use of the key storage region in UICR should be limited to keys with a certain life span, and not per-session derived keys where the CPU is involved in the key exchange.

#### 7.17.2 Access control

Access control to the underlying UICR infopage in flash is enforced by a hardware finite-state machine (FSM). The FSM can allow or block transactions, depending both on the security of the transaction (secure or non-secure) and on the type of register being written and/or read.



| Access type | Key headers | Key values |
|-------------|-------------|------------|
| Read        | Allowed     | Restricted |
| Write       | Restricted  | Restricted |

Table 91: Access control

Any restricted access requires an explicit key slot selection through the KMU register interface. Any illegal access to restricted key slot registers will be blocked and word <code>OxDEADDEAD</code> will be returned on the AHB.

The OTP region has individual access control behavior, while access control to the key storage region is configured on a per key slot basis. The KMU FSM operates on only one key slot instance at a time, and the permissions and the usage restriction for a key value associated with a key slot can be configured individually.

**Note:** Even if the KMU can be configured as non-secure, all non-secure transactions will be blocked.

## 7.17.3 Protecting the UICR content

The UICR content can be protected against device-internal NVMC.ERASEALL requests, in addition to device-external ERASEALL requests, through the CTRL-AP interface. This feature is useful if the firmware designers want to prevent the OTP region from being erased.

Since enabling this step will permanently disable erase for the UICR, the procedure requires an implementation defined 32-bit word to be written into the UICR's ERASEPROTECT register.

In case of a field return handling, it is still possible to erase the UICR even if the ERASEPROTECT is set. If this functionality is desired, the secure boot code must implement a secure communication channel over the CTRL-AP mailbox interface. Upon successful authentication of the external party, the secure boot code can temporarily re-enable the CTRL-AP ERASEALL functionality.

## 7.17.4 Usage

This section describes the specific KMU and UICR behavior in more detail, to help the reader get a better overview of KMU's features and the intended usage.

#### 7.17.4.1 OTP

The OTP region of the UICR contains a user-defined static configuration of the device. The KMU emulates the OTP functionality by placing a write-once per halfword limitation of registers defined in this region, i.e. only halfwords containing all '1's can be written.

An OTP write transaction must consist of a full 32-bit word. Both halfwords can either be written simultaneously or one at a time. The KMU FSM will block any write to a halfword in the OTP region, if the initial value of this halfword is not  $0\times FFFF$ . When writing halfwords one at a time, the non-active halfword must be masked as  $0\times FFFFF$ , otherwise the request will be blocked. For example, writing  $0\times1234\times\times\times$  to an OTP destination address which already contains the value  $0\times FFFFAABB$ , must be configured as  $0\times1234FFFF$ . The OTP destination address will contain the value  $0\times1234AABB$  after both write transactions have been processed.

The KMU will also only allow secure AHB write transactions into the OTP region of the UICR. Any AHB write transaction to this region that does not satisfy the above requirements will be ignored, and the STATUS.BLOCKED register will be set to '1'.

### 7.17.4.2 Key storage

The key storage region of the UICR can contain multiple keys of different type, including symmetrical keys, hashes, public/private key pairs and other device secrets. One of the key features of the KMU, is that these



device secrets can be installed and made available for use in cryptographic operations without revealing the actual secret values.

Keys in this region will typically have a certain life span. The region is not designed to be used for persession derived keys where the non-secure side (i.e. application) is participating in the key exchange.

All key storage is done through the concept of multiple key slots, where each key slot instance consists of one key header and an associated key value. Each key header supports the configuration of usage permissions and an optional secure destination address.

The key header secure destination address option enables the KMU to push the associated key value over a dedicated secure APB to a pre-configured secure location within the memory map. Such locations typically include a write-only key register of the hardware cryptograhic accelerator, allowing the KMU to distribute keys within the system without compromising the key values.

One key slot instance can store a key value of maximum 128 bits. If a key size exceeds this limit, the key value itself must be split over multiple key slot instances.

The following usage and read permissions scheme is applicable for each key slot:

| State      | Push     | Read     | Write    | Description                                                                                                  |
|------------|----------|----------|----------|--------------------------------------------------------------------------------------------------------------|
| Active (1) | Enabled  | Enabled  | Enabled  | Default flash erase value. Key slot cannot be pushed, write is enabled.                                      |
|            | (1)      | (1)      | (1)      |                                                                                                              |
| Active (1) | Enabled  | Enabled  | Disabled | Key slot is active, push is enabled. Key slot VALUE registers can be read, but write is disabled.            |
|            | (1)      | (1)      | (0)      |                                                                                                              |
| Active (1) | Enabled  | Disabled | Disabled | Key slot is active, push is enabled. Read and write to key slot VALUE registers are disabled.                |
|            | (1)      | (0)      | (0)      |                                                                                                              |
| Active (1) | Disabled | Enabled  | Disabled | Key slot is active, push is disabled. Key slot VALUE registers can be read, but write is disabled.           |
|            | (0)      | (1)      | (0)      |                                                                                                              |
| Revoked    | -        | -        | -        | Key slot is revoked and key value is set to zero. Cannot be read or pushed over secure APB regardless of the |
| (0)        |          |          |          | permission settings.                                                                                         |

Table 92: Valid key slot permission schemes

#### 7.17.4.2.1 Selecting a key slot

The KMU FSM is designed to process only one key slot at a time, effectively operating as a memory protection unit for the key storage region. Whenever a key slot is selected, the KMU will allow access to writing, reading, and/or pushing the associated key value according to the selected slot configuration.

A key slot must be selected prior to use, by writing the key slot ID into the KMU SELECTKEYSLOT register. Because the reset value of this register is  $0 \times 00000000$ , there is no key slot associated with ID=0 and no slot is selected by default. All key slots are addressed using IDs from 1 to 128.

SELECTED status is set when a key slot is selected, and a read or write access to that keyslot occurs.

BLOCKED status is set when any illegal access to key slot registers is detected.

When the use of the particular key slot is stopped, the key slot selection in SELECTKEYSLOT must be set back to 0.

By default, all KMU key slots will consist of a 128-bit key value of '1's, where the key headers have no secure destination address, or any usage and read restrictions.

#### 7.17.4.2.2 Writing to a key slot

Writing a key slot into UICR is a five-step process.

- 1. Select which key slot the KMU shall operate on by writing the desired key slot ID into the KMU SELECTKEYSLOT register. The selected key slot must be empty in order to add a new entry to UICR.
- 2. If the key value shall be pushable over secure APB, the destination address of the recipient must be configured in register KEYSLOT.CONFIG[ID-1].DEST.

NORDIC

- 3. Write the 128-bit key value into KEYSLOT.KEY[ID-1].VALUE[0-3].
- **4.** Write the desired key slot permissions into KEYSLOT.CONFIG[ID-1].PERM, including any applicable usage restrictions.
- **5.** Select key slot 0.

In case the total key size is greater than 128 bits, the key value itself must be split into 128-bit segments and written to multiple key slot instances. Steps 1 through 5 above must be repeated for the entire key size.

**Note:** If a key slot is configured as readable, and KEYSLOT.CONFIG[ID-1].DEST is not to be used, it is recommended to disable the push bit in KEYSLOT.CONFIG[ID-1].PERM when configuring key slot permissions.

**Note:** A key value distributed over multiple key slots should use the same key slot configuration in its key headers, but the secure destination address for each key slot instance must be incremented by 4 words (128 bits) for each key slot instance spanned.

**Note:** Write to flash must be enabled in NVMC->CONFIG prior to writing keys to flash, and subsequently disabled once writing is complete.

Steps 1 through 5 above will be blocked if any of the following violations are detected:

- No key slot selected
- Non-empty key slot selected
- NVM destination address not empty
- AHB write to KEYSLOT.KEY[ID-1].VALUE[0-3] registers not belonging to selected key slot

#### 7.17.4.2.3 Reading a key value

Key slots that are configured as readable can have their key value read directly from the UICR memory map by the CPU.

Readable keys are typically used during the secure boot sequence, where the CPU is involved in falsifying or verifying the integrity of the system. Since the CPU is involved in this decision process, it makes little sense not to trust the CPU having access to the actual key value but ultimately trust the decision of the integrity check. Another use-case for readable keys is if the key type in question does not have a HW peripheral in the platform that is able to accept such keys over secure APB.

Reading a key value from the UICR is a three-step process:

- 1. Select the key slot which the KMU shall operate on by writing the desired key slot ID into KMU->SELECTKEYSLOT.
- 2. If STATE and READ permission requirements are fulfilled as defined in KEYSLOT.CONFIG[ID-1].PERM, the key value can be read from region KEYSLOT.KEY[ID-1].VALUE[0-3] for selected key slot.
- **3.** Select key slot 0.

Step 2 will be blocked and word 0xDEADDEAD will be returned on AHB if any of the following violations are detected:

- No key slot selected
- Key slot not configured as readable
- Key slot is revoked
- AHB read to KEYSLOT.KEY[ID-1].VALUE[0-3] registers not belonging to selected key slot



#### 7.17.4.2.4 Push over secure APB

Key slots that are configured as non-readable cannot be read by the CPU regardless of the mode the system is in, and must be pushed over secure APB in order to use the key value for cryptographic operations.

The secure APB destination address is set in the key slot configuration DEST register. Such destination addresses are typically write-only key registers in a hardware cryptographic accelerators memory map. The secure APB allows key slots to be utilized by the software side, without exposing the key value itself.

Pushing a key slot over secure APB is a four-step process:

- Select the key slot on which the KMU shall operate by writing the desired key slot ID into KMU->SELECTKEYSLOT.
- **2.** Start TASKS\_PUSH\_KEYSLOT to initiate a secure APB transaction, writing the 128-bit key value associated with the selected key slot into address defined in KEYSLOT.CONFIG[ID-1].DEST.
- **3.** After completing the secure APB transaction, the 128-bit key value is ready for use by the peripheral and EVENTS\_KEYSLOT\_PUSHED is triggered.
- **4.** Select key slot 0.

**Note:** If a key value is distributed over multiple key slots due to its key size, exceeding the maximum 128-bit key value limitation, then each distributed key slot must be pushed individually in order to transfer the entire key value over secure APB.

Step 3 will trigger other events than EVENTS\_KEYSLOT\_PUSHED if the following violations are detected:

- EVENTS KEYSLOT ERROR:
  - If no key slot is selected
  - · If a key slot has no destination address configured
  - If when pushing a key slot, flash or peripheral returns an error
  - If pushing a key slot when push permissions are disabled
  - If attempting to push a key slot with default permissions
- EVENTS\_KEYSLOT\_REVOKED if a key slot is marked as revoked in its key header configuration

#### 7.17.4.2.5 Revoking the key slots

All key slots within the key storage area can be marked as revoked.

To revoke any key slots, write to the STATE field in the KEYSLOT.CONFIG[ID-1].PERM register. The following rules apply to keys that have been revoked:

- 1. Key slots that have the PUSH field enabled in PERM register can no longer be pushed. If a revoked key slot is selected and task TASKS\_PUSH\_KEYSLOT is started, the event EVENTS\_KEYSLOT\_REVOKED is triggered.
- **2.** Key slots that have the READ field enabled in PERM register are invalidated. Any read operation to a revoked key value will return the fixed value 3735936685.
- **3.** Previously pushed key values stored in a peripheral write-only key register are not affected by key revocation. If secure code wants to enforce that a revoked key is no longer usable by a peripheral for cryptographic operations, the secure code should disable or reset the peripheral in question.

**Note:** If a key slot is revoked, the KMU will automatically zeroize the associated VALUE registers.

#### 7.17.4.3 STATUS register

The KMU uses a STATUS register to indicate its status of operation. The SELECTED bit will be asserted whenever the currently selected key slot is successfully read from or written to.

All read or write operations to other key slots than what is currently selected in KMU->SELECTKEYSLOT will assert the BLOCKED bit. The BLOCKED bit will also be asserted if the KMU fails to select a key slot, or



if a request has been blocked due to an access violation. Normal operation using the KMU should never trigger the BLOCKED bit. If this bit is triggered during the development phase, it indicates that the code is using the KMU incorrectly.

The STATUS register is reset every time register SELECTKEYSLOT is written.

## 7.17.5 Registers

| Base address Domain        | Peripheral | Instance | Secure mapping | DMA security | Description         | Configuration |
|----------------------------|------------|----------|----------------|--------------|---------------------|---------------|
| 0x50039000                 | N KNALL    | KMU : S  | SPLIT          | NA           | Vou managament unit |               |
| 0x40039000 APPLICATION KMU |            | KMU : NS | SPLII          | NA           | Key management unit |               |

Table 93: Instances

| Register               | Offset | Security | Description                                                                          |
|------------------------|--------|----------|--------------------------------------------------------------------------------------|
| TASKS_PUSH_KEYSLOT     | 0x0000 |          | Push a key slot over secure APB                                                      |
| EVENTS_KEYSLOT_PUSHED  | 0x100  |          | Key slot successfully pushed over secure APB                                         |
| EVENTS_KEYSLOT_REVOKED | 0x104  |          | Key slot has been revoked and cannot be tasked for selection                         |
| EVENTS_KEYSLOT_ERROR   | 0x108  |          | No key slot selected, no destination address defined, or error during push operation |
| INTEN                  | 0x300  |          | Enable or disable interrupt                                                          |
| INTENSET               | 0x304  |          | Enable interrupt                                                                     |
| INTENCLR               | 0x308  |          | Disable interrupt                                                                    |
| INTPEND                | 0x30C  |          | Pending interrupts                                                                   |
| STATUS                 | 0x40C  |          | Status bits for KMU operation                                                        |
| SELECTKEYSLOT          | 0x500  |          | Select key slot to be read over AHB or pushed over secure APB when                   |
|                        |        |          | TASKS_PUSH_KEYSLOT is started                                                        |

Table 94: Register overview

### 7.17.5.1 TASKS\_PUSH\_KEYSLOT

Address offset: 0x0000

Push a key slot over secure APB



### 7.17.5.2 EVENTS\_KEYSLOT\_PUSHED

Address offset: 0x100

Key slot successfully pushed over secure APB





### 7.17.5.3 EVENTS\_KEYSLOT\_REVOKED

Address offset: 0x104

Key slot has been revoked and cannot be tasked for selection



### 7.17.5.4 EVENTS\_KEYSLOT\_ERROR

Address offset: 0x108

No key slot selected, no destination address defined, or error during push operation



#### 7.17.5.5 INTEN

Address offset: 0x300

Enable or disable interrupt







| Bit number       |          | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|----------------------|--------------------------------------------------------------------|
| ID               |          |                      | СВА                                                                |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID R/W Field     |          |                      | Description                                                        |
|                  | Disabled |                      | Disable                                                            |
|                  | Enabled  |                      | Enable                                                             |

## 7.17.5.6 INTENSET

Address offset: 0x304

Enable interrupt

| Bit r | Bit number |                 |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------|-----------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |            |                 |          |                        | СВА                                                             |
| Rese  | et 0x000   | 00000           |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |            |                 |          |                        |                                                                 |
| Α     | RW         | KEYSLOT_PUSHED  |          |                        | Write '1' to enable interrupt for event KEYSLOT_PUSHED          |
|       |            |                 | Set      | 1                      | Enable                                                          |
|       |            |                 | Disabled | 0                      | Read: Disabled                                                  |
|       |            |                 | Enabled  | 1                      | Read: Enabled                                                   |
| В     | RW         | KEYSLOT_REVOKED |          |                        | Write '1' to enable interrupt for event KEYSLOT_REVOKED         |
|       |            |                 | Set      | 1                      | Enable                                                          |
|       |            |                 | Disabled | 0                      | Read: Disabled                                                  |
|       |            |                 | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW         | KEYSLOT_ERROR   |          |                        | Write '1' to enable interrupt for event KEYSLOT_ERROR           |
|       |            |                 | Set      | 1                      | Enable                                                          |
|       |            |                 | Disabled | 0                      | Read: Disabled                                                  |
|       |            |                 | Enabled  | 1                      | Read: Enabled                                                   |

## 7.17.5.7 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |                 |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                 |          |                         | СВА                                                             |
| Rese  | et 0x000 | 000000          |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                 |          |                         | Description                                                     |
| Α     | RW       | KEYSLOT_PUSHED  |          |                         | Write '1' to disable interrupt for event KEYSLOT_PUSHED         |
|       |          |                 | Clear    | 1                       | Disable                                                         |
|       |          |                 | Disabled | 0                       | Read: Disabled                                                  |
|       |          |                 | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | KEYSLOT_REVOKED |          |                         | Write '1' to disable interrupt for event KEYSLOT_REVOKED        |
|       |          |                 | Clear    | 1                       | Disable                                                         |
|       |          |                 | Disabled | 0                       | Read: Disabled                                                  |
|       |          |                 | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | KEYSLOT_ERROR   |          |                         | Write '1' to disable interrupt for event KEYSLOT_ERROR          |
|       |          |                 | Clear    | 1                       | Disable                                                         |
|       |          |                 | Disabled | 0                       | Read: Disabled                                                  |
|       |          |                 | Enabled  | 1                       | Read: Enabled                                                   |



#### 7.17.5.8 INTPEND

Address offset: 0x30C

Pending interrupts

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Bit number ID Reset 0x00000000 KEYSLOT\_PUSHED Read pending status of interrupt for event KEYSLOT\_PUSHED NotPending 0 Read: Not pending Pending 1 Read: Pending KEYSLOT\_REVOKED Read pending status of interrupt for event R KEYSLOT REVOKED NotPending 0 Read: Not pending Pending 1 Read: Pending KEYSLOT\_ERROR Read pending status of interrupt for event KEYSLOT\_ERROR Read: Not pending NotPending 0

Read: Pending

#### 7.17.5.9 STATUS

Address offset: 0x40C

Status bits for KMU operation

This register is reset and re-written by the KMU whenever SELECTKEYSLOT is written

1

Pending



#### 7.17.5.10 SELECTKEYSLOT

Address offset: 0x500

Select key slot to be read over AHB or pushed over secure APB when TASKS\_PUSH\_KEYSLOT is started





# 7.18 LPCOMP — Low-power comparator

Low-power comparator (LPCOMP) compares an input voltage against a reference voltage.

Listed here are the main features of LPCOMP:

- 0 VDD input range
- Ultra-low power
- Eight input options (AINO to AIN7)
- Reference voltage options:
  - Two external analog reference inputs, or
  - 15-level internal reference ladder (VDD/16)
- · Optional hysteresis enable on input
- Can be used as a wakeup source from System OFF mode

In System ON, the LPCOMP can generate separate events on rising and falling edges of a signal, or sample the current state of the pin as being above or below the selected reference. The block can be configured to use any of the analog inputs on the device. Additionally, the low-power comparator can be used as an analog wakeup source from System OFF or System ON. The comparator threshold can be programmed to a range of fractions of the supply voltage.

**Note:** LPCOMP cannot be used (STARTed) at the same time as COMP. Only one comparator can be used at a time.



Figure 88: Low-power comparator



The wakeup comparator (LPCOMP) compares an input voltage (VIN+), which comes from an analog input pin selected via the PSEL register, against a reference voltage (VIN-) selected via registers REFSEL on page 293 and EXTREFSEL.

The PSEL, REFSEL, and EXTREFSEL registers must be configured before the LPCOMP is enabled through the ENABLE register.

The HYST register allows enabling an optional hysteresis in the comparator core. This hysteresis shall prevent noise on the signal to create unwanted events. Figure below illustrates the effect of an active hysteresis on a noisy input signal. It is disabled by default, and shall be configured before enabling LPCOMP as well.



Figure 89: Effect of hysteresis on a noisy input signal

The LPCOMP is started by triggering the START task. After a startup time of  $t_{LPCOMP,STARTUP}$ , the LPCOMP will generate a READY event to indicate that the comparator is ready to use and the output of the LPCOMP is correct. The LPCOMP will generate events every time VIN+ crosses VIN-. More specifically, every time VIN+ rises above VIN- (upward crossing) an UP event is generated along with a CROSS event. Every time VIN+ falls below VIN- (downward crossing), a DOWN event is generated along with a CROSS event. When hysteresis is enabled, the upward crossing level becomes (VIN- + VHYST/2), and the downward crossing level becomes (VIN- - VHYST/2).

The LPCOMP is stopped by triggering the STOP task.

LPCOMP will be operational in both System ON and System OFF mode when it is enabled through the ENABLE register. See POWER — Power control on page 46 for more information about power modes. Note that it is not allowed to go to System OFF when a READY event is pending to be generated.

All LPCOMP registers, including ENABLE, are classified as retained registers when the LPCOMP is enabled. However, when the device wakes up from System OFF, all LPCOMP registers will be reset.

The LPCOMP can wake up the system from System OFF by asserting the ANADETECT signal. The ANADETECT signal can be derived from any of the event sources that generate the UP, DOWN and CROSS events. In case of wakeup from System OFF, no events will be generated, only the ANADETECT signal. See the ANADETECT register (ANADETECT on page 294) for more information on how to configure the ANADETECT signal.

The immediate value of the LPCOMP can be sampled to RESULT on page 293 by triggering the SAMPLE task.

See RESETREAS on page 70 for more information on how to detect a wakeup from LPCOMP.

### 7.18.1 Shared resources

The LPCOMP shares analog resources with SAADC. While it is possible to use the SAADC at the same time as the LPCOMP, selecting the same analog input pin for both modules is not supported.

Additionally, LPCOMP shares registers and other resources with other peripherals that have the same ID as the LPCOMP. See Peripherals with shared ID on page 152 for more information.



The LPCOMP peripheral shall not be disabled (by writing to the ENABLE register) before the peripheral has been stopped. Failing to do so may result in unpredictable behavior.

## 7.18.2 Pin configuration

You can use the LPCOMP.PSEL register to select one of the analog input pins, **AINO** through **AIN7**, as the analog input pin for the LPCOMP.

See GPIO — General purpose input/output on page 224 for more information about the pins. Similarly, you can use EXTREFSEL on page 294 to select one of the analog reference input pins, **AINO** and **AIN1**, as input for AREF in case AREF is selected in EXTREFSEL on page 294. The selected analog pins will be acquired by the LPCOMP when it is enabled through ENABLE on page 293.

## 7.18.3 Registers

| Base address Domain      | Peripheral   | Instance    | Secure mapping | DMA security | Description          | Configuration |
|--------------------------|--------------|-------------|----------------|--------------|----------------------|---------------|
| 0x5001A000<br>APPLICATIO | N I PCOMP    | LPCOMP : S  | LIS            | NA           | Low-power comparator |               |
| 0x4001A000               | iv El COlvii | LPCOMP : NS |                | 10.1         | zow power comparator |               |

Table 95: Instances

|       |                                                                                                                         | Description                                                                                                                         |
|-------|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0x000 |                                                                                                                         | Start comparator                                                                                                                    |
| 0x004 |                                                                                                                         | Stop comparator                                                                                                                     |
| 0x008 |                                                                                                                         | Sample comparator value                                                                                                             |
| 0x080 |                                                                                                                         | Subscribe configuration for task START                                                                                              |
| 0x084 |                                                                                                                         | Subscribe configuration for task STOP                                                                                               |
| 0x088 |                                                                                                                         | Subscribe configuration for task SAMPLE                                                                                             |
| 0x100 |                                                                                                                         | LPCOMP is ready and output is valid                                                                                                 |
| 0x104 |                                                                                                                         | Downward crossing                                                                                                                   |
| 0x108 |                                                                                                                         | Upward crossing                                                                                                                     |
| 0x10C |                                                                                                                         | Downward or upward crossing                                                                                                         |
| 0x180 |                                                                                                                         | Publish configuration for event READY                                                                                               |
| 0x184 |                                                                                                                         | Publish configuration for event DOWN                                                                                                |
| 0x188 |                                                                                                                         | Publish configuration for event UP                                                                                                  |
| 0x18C |                                                                                                                         | Publish configuration for event CROSS                                                                                               |
| 0x200 |                                                                                                                         | Shortcuts between local events and tasks                                                                                            |
| 0x304 |                                                                                                                         | Enable interrupt                                                                                                                    |
| 0x308 |                                                                                                                         | Disable interrupt                                                                                                                   |
| 0x400 |                                                                                                                         | Compare result                                                                                                                      |
| 0x500 |                                                                                                                         | Enable LPCOMP                                                                                                                       |
| 0x504 |                                                                                                                         | Input pin select                                                                                                                    |
| 0x508 |                                                                                                                         | Reference select                                                                                                                    |
| 0x50C |                                                                                                                         | External reference select                                                                                                           |
| 0x520 |                                                                                                                         | Analog detect configuration                                                                                                         |
| 0x538 |                                                                                                                         | Comparator hysteresis enable                                                                                                        |
|       | 0x004 0x008 0x080 0x084 0x088 0x100 0x104 0x108 0x10C 0x180 0x18C 0x200 0x304 0x308 0x400 0x500 0x504 0x508 0x50C 0x520 | 0x004 0x008 0x080 0x084 0x088 0x100 0x104 0x108 0x10C 0x180 0x184 0x188 0x18C 0x200 0x304 0x308 0x400 0x500 0x504 0x508 0x50C 0x520 |

Table 96: Register overview

### 7.18.3.1 TASKS\_START

Address offset: 0x000

Start comparator





### 7.18.3.2 TASKS STOP

Address offset: 0x004

Stop comparator



## 7.18.3.3 TASKS\_SAMPLE

Address offset: 0x008

Sample comparator value



#### 7.18.3.4 SUBSCRIBE START

Address offset: 0x080

Subscribe configuration for task START

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|----------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A                                                   |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |          |       |          |                         |                                                               |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task START will subscribe to                |
| В     | RW       | EN    |          |                         |                                                               |
|       |          |       | Disabled | 0                       | Disable subscription                                          |
|       |          |       |          |                         |                                                               |

### 7.18.3.5 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP





# 7.18.3.6 SUBSCRIBE\_SAMPLE

Address offset: 0x088

Subscribe configuration for task SAMPLE

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A A                                                   |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |          |                         |                                                                 |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task SAMPLE will subscribe to                 |
| В     | RW       | EN    |          |                         |                                                                 |
|       |          |       | Disabled | 0                       | Disable subscription                                            |
|       |          |       | Enabled  | 1                       | Enable subscription                                             |

## 7.18.3.7 EVENTS\_READY

Address offset: 0x100

LPCOMP is ready and output is valid

| Bit n | umber   |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                        | A                                                               |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                        |                                                                 |
| Α     | RW      | EVENTS_READY |              |                        | LPCOMP is ready and output is valid                             |
|       |         |              | NotGenerated | 0                      | Event not generated                                             |
|       |         |              | Generated    | 1                      | Event generated                                                 |

## 7.18.3.8 EVENTS\_DOWN

Address offset: 0x104

Downward crossing



## 7.18.3.9 EVENTS\_UP

Address offset: 0x108



#### Upward crossing



## 7.18.3.10 EVENTS CROSS

Address offset: 0x10C

Downward or upward crossing



#### 7.18.3.11 PUBLISH\_READY

Address offset: 0x180

Publish configuration for event READY



## 7.18.3.12 PUBLISH DOWN

Address offset: 0x184

Publish configuration for event DOWN







# 7.18.3.13 PUBLISH\_UP

Address offset: 0x188

Publish configuration for event UP



# 7.18.3.14 PUBLISH\_CROSS

Address offset: 0x18C

Publish configuration for event CROSS



#### 7.18.3.15 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber    |              |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |              |          |                         | EDCBA                                                           |
| Rese  | et 0x000 | 00000        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |          |                         |                                                                 |
| Α     | RW       | READY_SAMPLE |          |                         | Shortcut between event READY and task SAMPLE                    |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| В     | RW       | READY_STOP   |          |                         | Shortcut between event READY and task STOP                      |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| С     | RW       | DOWN_STOP    |          |                         | Shortcut between event DOWN and task STOP                       |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| D     | RW       | UP_STOP      |          |                         | Shortcut between event UP and task STOP                         |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
| Ε     | RW       | CROSS_STOP   |          |                         | Shortcut between event CROSS and task STOP                      |
|       |          |              | Disabled | 0                       | Disable shortcut                                                |
|       |          |              | Enabled  | 1                       | Enable shortcut                                                 |
|       |          |              |          |                         |                                                                 |



# 7.18.3.16 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          |                         | D C B A                                                         |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         | Description                                                     |
| Α     | RW      | READY |          |                         | Write '1' to enable interrupt for event READY                   |
|       |         |       | Set      | 1                       | Enable                                                          |
|       |         |       | Disabled | 0                       | Read: Disabled                                                  |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW      | DOWN  |          |                         | Write '1' to enable interrupt for event DOWN                    |
|       |         |       | Set      | 1                       | Enable                                                          |
|       |         |       | Disabled | 0                       | Read: Disabled                                                  |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW      | UP    |          |                         | Write '1' to enable interrupt for event UP                      |
|       |         |       | Set      | 1                       | Enable                                                          |
|       |         |       | Disabled | 0                       | Read: Disabled                                                  |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                   |
| D     | RW      | CROSS |          |                         | Write '1' to enable interrupt for event CROSS                   |
|       |         |       | Set      | 1                       | Enable                                                          |
|       |         |       | Disabled | 0                       | Read: Disabled                                                  |
|       |         |       | Enabled  | 1                       | Read: Enabled                                                   |

# 7.18.3.17 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |       |          | 31 | 30 2 | 29 2 | 8 2 | 7 26 | 25 | 24 | 23 2     | 22 2  | 1 2  | 0 1  | 9 1  | 8 17  | 7 16 | 15  | 14   | 13 1 | .2 1 | 1 10 | 9   | 8   | 7 6 | 5 | 4 | 3 | 2 | 1 0 |
|-------|----------|-------|----------|----|------|------|-----|------|----|----|----------|-------|------|------|------|-------|------|-----|------|------|------|------|-----|-----|-----|---|---|---|---|-----|
| ID    |          |       |          |    |      |      |     |      |    |    |          |       |      |      |      |       |      |     |      |      |      |      |     |     |     |   |   | D | С | ВА  |
| Rese  | et 0x000 | 00000 |          | 0  | 0    | 0 0  | 0 0 | 0    | 0  | 0  | 0        | 0 (   | 0 (  | ) (  | ) (  | 0     | 0    | 0   | 0    | 0    | 0 0  | 0    | 0   | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 0 |
| ID    |          |       |          |    |      |      |     |      |    |    |          |       |      |      |      |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
| Α     | RW       | READY |          |    |      |      |     |      |    |    | Wri      | te '  | 1' t | o d  | isal | ole i | nte  | rru | ot f | or e | ven  | t RE | ADY |     |     |   |   |   |   |     |
|       |          |       | Clear    | 1  |      |      |     |      |    |    | Disa     | able  | 9    |      |      |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Disabled | 0  |      |      |     |      |    |    | Rea      | ıd: [ | Disa | ble  | ed   |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Enabled  | 1  |      |      |     |      |    |    | Rea      | ıd: E | na   | ble  | d    |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
| В     | RW       | DOWN  |          |    |      |      |     |      |    |    | Wri      | te '  | 1' t | o d  | isal | ole i | nte  | rru | ot f | or e | ven  | t DC | WN  |     |     |   |   |   |   |     |
|       |          |       | Clear    | 1  |      |      |     |      |    |    | Disa     | able  | 9    |      |      |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Disabled | 0  |      |      |     |      |    |    | Rea      | ıd: [ | Disa | ble  | ed   |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Enabled  | 1  |      |      |     |      |    |    | Rea      | ıd: E | na   | ble  | d    |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
| С     | RW       | UP    |          |    |      |      |     |      |    |    | Wri      | te '  | 1' t | o d  | isal | ole i | nte  | rru | ot f | or e | ven  | t UP |     |     |     |   |   |   |   |     |
|       |          |       | Clear    | 1  |      |      |     |      |    |    | Disa     | able  | 9    |      |      |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Disabled | 0  |      |      |     |      |    |    | Rea      | ıd: [ | Disa | ble  | ed   |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Enabled  | 1  |      |      |     |      |    |    | Rea      | ıd: E | Ena  | ble  | d    |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
| D     | RW       | CROSS |          |    |      |      |     |      |    |    | Wri      | te '  | 1' t | o d  | isal | ole i | nte  | rru | ot f | or e | ven  | t CR | oss |     |     |   |   |   |   |     |
|       |          |       | Clear    | 1  |      |      |     |      |    |    | Disa     | able  | 9    |      |      |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Disabled | 0  |      |      |     |      |    |    | Rea      | ıd: [ | Disa | ble  | ed   |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Enabled  | 1  |      |      |     |      |    |    | Rea      | ıd: E | na   | ble  | d    |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |
|       |          |       | Litablea | -  |      |      |     |      |    |    | · · · ca | u. L  |      | JIC. | u    |       |      |     |      |      |      |      |     |     |     |   |   |   |   |     |



#### 7.18.3.18 RESULT

Address offset: 0x400

Compare result



#### 7.18.3.19 ENABLE

Address offset: 0x500

**Enable LPCOMP** 



#### 7.18.3.20 PSEL

Address offset: 0x504

Input pin select



#### 7.18.3.21 REFSEL

Address offset: 0x508

Reference select



| Bit number            | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|------------------------|------------------------------------------------------------------|
| ID                    |                        | АААА                                                             |
| Reset 0x00000004      | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field Value ID |                        | Description                                                      |
| A RW REFSEL           |                        | Reference select                                                 |
| Ref1_8Vdd             | 0                      | VDD * 1/8 selected as reference                                  |
| Ref2_8Vdd             | 1                      | VDD * 2/8 selected as reference                                  |
| Ref3_8Vdd             | 2                      | VDD * 3/8 selected as reference                                  |
| Ref4_8Vdd             | 3                      | VDD * 4/8 selected as reference                                  |
| Ref5_8Vdd             | 4                      | VDD * 5/8 selected as reference                                  |
| Ref6_8Vdd             | 5                      | VDD * 6/8 selected as reference                                  |
| Ref7_8Vdd             | 6                      | VDD * 7/8 selected as reference                                  |
| ARef                  | 7                      | External analog reference selected                               |
| Ref1_16Vdd            | 8                      | VDD * 1/16 selected as reference                                 |
| Ref3_16Vdd            | 9                      | VDD * 3/16 selected as reference                                 |
| Ref5_16Vdd            | 10                     | VDD * 5/16 selected as reference                                 |
| Ref7_16Vdd            | 11                     | VDD * 7/16 selected as reference                                 |
| Ref9_16Vdd            | 12                     | VDD * 9/16 selected as reference                                 |
| Ref11_16Vdd           | 13                     | VDD * 11/16 selected as reference                                |
| Ref13_16Vdd           | 14                     | VDD * 13/16 selected as reference                                |
| Ref15_16Vdd           | 15                     | VDD * 15/16 selected as reference                                |

#### 7.18.3.22 EXTREFSEL

Address offset: 0x50C

External reference select



## 7.18.3.23 ANADETECT

Address offset: 0x520

Analog detect configuration



7.18.3.24 HYST

Address offset: 0x538





#### Comparator hysteresis enable



# 7.18.4 Electrical specification

#### 7.18.4.1 LPCOMP Electrical Specification

| Symbol                 | Description                                         | Min. | Тур. | Max. | Units |
|------------------------|-----------------------------------------------------|------|------|------|-------|
| t <sub>LPCANADET</sub> | Time from VIN crossing (≥ 50 mV above threshold) to |      | 2.7  |      | μs    |
|                        | ANADETECT signal generated                          |      |      |      |       |
| V <sub>INPOFFSET</sub> | Input offset including reference ladder error       | -40  |      | 40   | mV    |
| V <sub>HYST</sub>      | Optional hysteresis                                 |      | 38   |      | mV    |
| t <sub>STARTUP</sub>   | Startup time for LPCOMP                             | 28   | 51   | 134  | μs    |

# 7.19 MUTEX — Mutual exclusive peripheral

The MUTEX peripheral uses mutual exclusion to support locking a resource that is shared between different CPUs in the system. The shared resource can only be used by one of these cores during the duration that it is locked.

The MUTEX peripheral includes several mutex registers. Each mutex register contains one bit which indicates if it is in a locked or unlocked state. Reading or writing to a mutex register may impact its state.

When a mutex is read, the following conditions apply:

- If the state is locked, the MUTEX[i] state is unchanged (remains in a locked state) and reading the register will return '1'.
- If the state is unlocked, the MUTEX[i] state changes to the locked state and reading the register will return '0'.

When writing '0' to a mutex, the following occurs:

- If the state is unlocked, the MUTEX[i] state is unchanged (remains in unlocked state) and the store is ignored.
- If the state is locked, the MUTEX[i] state changes to the unlocked state.

**Note:** Faults are not managed by the peripheral. If a mutex is locked and a fault occurs, it is the responsibility of the fault handler to release the mutex. If a fault handler is not managing the mutex release, the mutex will stay locked.

The following figure illustrates the mutex state transitions.





Figure 90: MUTEX - state transitions

The following code is an example of how a mutex can be used by two different CPUs:

Only one CPU can access the mutex at a time, meaning the mutex must be released before being accessed by the another CPU. If the load operation occurs at the same time, a bus arbitration mechanism will ensure only one CPU gets the mutex.



# 7.19.1 Registers



Table 97: Instances

| Register | Offset Sec | curity Description |
|----------|------------|--------------------|
| MUTEX[n] | 0x400      | Mutex register     |

Table 98: Register overview

#### 7.19.1.1 MUTEX[n] (n=0..15)

Address offset:  $0x400 + (n \times 0x4)$ 

Mutex register



# 7.20 NFCT — Near field communication tag

The NFCT peripheral is an implementation of an NFC Forum compliant listening device NFC-A.

With appropriate software, the NFCT peripheral can be used as the listening device NFC-A as specified by the NFC Forum.

Listed here are the main features for the NFCT peripheral:

- NFC-A listen mode operation
  - 13.56 MHz input frequency
  - · Bit rate 106 kbps
- Wake-on-field low power field detection (SENSE) mode
- Frame assemble and disassemble for the NFC-A frames specified by the NFC Forum
- Programmable frame timing controller
- Integrated automatic collision resolution, cyclic redundancy check (CRC), and parity functions





Figure 91: NFCT block diagram

## 7.20.1 Overview

The NFCT peripheral contains a 13.56 MHz AM receiver and a 13.56 MHz load modulator with 106 kbps data rate as defined by the NFC Forum.





Figure 92: NFCT overview

When transmitting, the frame data will be transferred directly from RAM and transmitted with configurable frame type and delay timing. The system will be notified by an event whenever a complete frame is received or sent. The received frames will be automatically disassembled and the data part of the frame transferred to RAM.

The NFCT peripheral also supports the collision detection and resolution ("anticollision") as defined by the NFC Forum.

Wake-on-field is supported in SENSE mode while the device is either in System OFF or System ON mode. When the antenna enters an NFC field, an event will be triggered notifying the system to activate the NFCT functionality for incoming frames. In System ON, if the energy detected at the antenna increases beyond a threshold value, the module will generate a FIELDDETECTED event. When the strength of the field no longer supports NFC communication, the module will generate a FIELDLOST event. For the Low Power Field Detect threshold values, refer to NFCT Electrical Specification on page 334.

In System OFF, the NFCT Low Power Field Detect function can wake the system up through a reset. See RESETREAS on page 70 for more information on how to detect a wakeup from NFCT.

If the system is put into System OFF mode while a field is already present, the NFCT Low Power Field Detect function will wake the system up right away and generate a reset.

**Note:** As a consequence of a reset, NFCT is disabled, and therefore the reset handler will have to activate NFCT again and set it up properly.

The HFXO must be running before the NFCT peripheral goes into ACTIVATED state. Note that the NFCT peripheral calibration is automatically done on ACTIVATE task. The HFXO can be turned off when the NFCT peripheral goes into SENSE mode. The shortcut FIELDDETECTED\_ACTIVATE can be used when the HFXO is already running while in SENSE mode.

Outgoing data will be collected from RAM with the EasyDMA function and assembled according to the TXD.FRAMECONFIG register. Incoming data will be disassembled according to the RXD.FRAMECONFIG register and the data section in the frame will be written to RAM via the EasyDMA function.

The NFCT peripheral includes a frame timing controller that can be used to accurately control the interframe delay between the incoming frame and a corresponding outgoing frame. It also includes optional CRC functionality.

NORDIC

## 7.20.2 Operating states

Tasks and events are used to control the operating state of the peripheral. The module can change state by triggering a task, or when specific operations are finalized. Events and tasks allow software to keep track of and change the current state.

See NFCT block diagram on page 298 and NFCT state diagram, automatic collision resolution enabled on page 300 for more information. See NFC Forum, NFC Activity Technical Specification for description on NFCT operating states.



Figure 93: NFCT state diagram, automatic collision resolution enabled



Figure 94: NFCT state diagram, automatic collision resolution disabled

#### Important:

- FIELDLOST event is not generated in SENSE mode.
- Sending SENSE task while field is still present does not generate FIELDDETECTED event.
- If the FIELDDETECTED event is cleared before sending the ACTIVATE task, then the FIELDDETECTED event shows up again after sending the ACTIVATE task. The shortcut FIELDDETECTED\_ACTIVATE can be used to avoid this condition.



## 7.20.3 Pin configuration

NFCT uses two pins to connect the antenna and these pins are shared with GPIOs.

The PROTECT field in the NFCPINS register in UICR defines the usage of these pins and their protection level against excessive voltages. The content of the NFCPINS register is reloaded at every reset. See Pin assignments on page 790 for the pins used by the NFCT peripheral.

When NFCPINS.PROTECT=NFC, a protection circuit will be enabled on the dedicated pins, preventing the chip from being damaged in the presence of a strong NFC field. The protection circuit will short the two pins together if voltage difference exceeds approximately 2V. The GPIO function on those pins will also be disabled.

When NFCPINS.PROTECT=Disabled, the device will not be protected against strong NFC field damages caught by a connected NFCT antenna, and the NFCT peripheral will not operate as expected, as it will never leave the DISABLE state.

The pins dedicated to the NFCT antenna function will have some limitation when the pins are configured for normal GPIO operation. The pin capacitance will be higher on those (refer to C<sub>PAD\_NFC</sub> in the Electrical Specification of GPIO — General purpose input/output on page 224), and some increased leakage current between the two pins is to be expected if they are used in GPIO mode, and are driven to different logical values. To save power, the two pins should always be set to the same logical value whenever entering one of the device power saving modes. For details, refer to I<sub>NFC\_LEAK</sub> in the Electrical Specification of GPIO — General purpose input/output on page 224.

## 7.20.4 EasyDMA

The NFCT peripheral implements EasyDMA for reading and writing of data packets from and to the Data RAM.

The NFCT EasyDMA utilizes a pointer called PACKETPTR on page 329 for receiving and transmitting packets.

The NFCT peripheral uses EasyDMA to read or write RAM, but not both at the same time. The event RXFRAMESTART indicates that the EasyDMA has started writing to the RAM for a receive frame and the event RXFRAMEND indicates that the EasyDMA has completed writing to the RAM. Similarly, the event TXFRAMESTART indicates that the EasyDMA has started reading from the RAM for a transmit frame and the event TXFRAMEND indicates that the EasyDMA has completed reading from the RAM. If a transmit and a receive operation is issued at the same time, the transmit operation would be prioritized.

Starting a transmit operation while the EasyDMA is writing a receive frame to the RAM will result in unpredictable behavior. Starting an EasyDMA operation when there is an ongoing EasyDMA operation may result in unpredictable behavior. It is recommended to wait for the TXFRAMEEND or RXFRAMEEND event for the ongoing transmit or receive before starting a new receive or transmit operation.

The MAXLEN on page 329 register determines the maximum number of bytes that can be read from or written to the RAM. This feature can be used to ensure that the NFCT peripheral does not overwrite, or read beyond, the RAM assigned to a packet. Note that if the RXD.AMOUNT or TXD.AMOUNT register indicates longer data packets than set in MAXLEN, the frames sent to or received from the physical layer will be incomplete. If that situation occurs in RX mode, the OVERRUN bit in the FRAMESTATUS.RX register will be set and an RXERROR event will be triggered.

**Important:** The RXD.AMOUNT and TXD.AMOUNT define a frame length in bytes and bits excluding start of frame (SoF), end of frame (EoF), and parity, but including CRC for RXD.AMOUNT only. Make sure to take potential additional bits into account when setting MAXLEN.

Only sending task ENABLERXDATA ensures that a new value in PACKETPTR pointing to the RX buffer in Data RAM is taken into account.



If PACKETPTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a hard fault or RAM corruption. For more information about the different memory regions, see Chapter Memory on page 19

The NFCT peripherals normally do alternative receive and transmit frames. Therefore, to prepare for the next frame, the PACKETPTR, MAXLEN, TXD.FRAMECONFIG and TXD.AMOUNT can be updated while the receive is in progress, and, similarly, the PACKETPTR, MAXLEN and RXD.FRAMECONFIG can be updated while the transmit is in progress. They can be updated and prepared for the next NFC frame immediately after the STARTED event of the current frame has been received. Updating the TXD.FRAMECONFIG and TXD.AMOUNT during the current transmit frame or updating RXD.FRAMECONFIG during current receive frame may cause unpredictable behaviour.

In accordance with NFC Forum, NFC Digital Protocol Technical Specification, the least significant bit (LSB) from the least significant byte (LSByte) is sent on air first. The bytes are stored in increasing order, starting at the lowest address in the EasyDMA buffer in RAM.

#### 7.20.5 Frame assembler

The NFCT peripheral implements a frame assembler in hardware.

When the NFCT peripheral is in the ACTIVE\_A state, the software can decide to enter RX or TX mode. For RX mode, see Frame disassembler on page 303. For TX mode, the software must indicate the address of the source buffer in Data RAM and its size through programming the PACKETPTR and MAXLEN registers respectively, then issuing a STARTTX task.

MAXLEN must be set so that it matches the size of the frame to be sent.

The STARTED event indicates that the PACKETPTR and MAXLEN registers have been captured by the frame assembler EasyDMA.

When asserting the STARTTX task, the frame assembler module will start reading TXD.AMOUNT.TXDATABYTES bytes (plus one additional byte if TXD.AMOUNT.TXDATABITS > 0) from the RAM position set by the PACKETPTR.

The NFCT peripheral transmits the data as read from RAM, adding framing and the CRC calculated on the fly if set in TXD.FRAMECONFIG. The NFCT peripheral will take (8\*TXD.AMOUNT.TXDATABYTES + TXD.AMOUNT.TXDATABITS) bits and assemble a frame according to the settings in TXD.FRAMECONFIG. Both short frames, standard frames, and bit-oriented SDD frames as specified in the NFC Forum, NFC Digital Protocol Technical Specification can be assembled by the correct setting of the TXD.FRAMECONFIG register.

The bytes will be transmitted on air in the same order as they are read from RAM with a rising bit order within each byte, least significant bit (LSB) first. That is, the least significant bit (b0) will be transmitted on air before the second bit (b1), and so on. The bits read from RAM will be coded into symbols as defined in the NFC Forum, NFC Digital Protocol Technical Specification.

**Note:** Some NFC Forum documents, such as *NFC Forum, NFC Digital Protocol Technical Specification*, define bit numbering in a byte from b1 (LSB) to b8 (most significant bit (MSB)), while most other technical documents from the NFC Forum, and also the Nordic Semiconductor documentation, traditionally number them from b0 to b7. The present document uses the b0–b7 numbering scheme. Be aware of this when comparing the *NFC Forum, NFC Digital Protocol Technical Specification* to others.

The frame assembler can be configured in TXD.FRAMECONFIG to add SoF symbol, calculate and add parity bits, and calculate and add CRC to the data read from RAM when assembling the frame. The total frame will then be longer than what is defined by TXD.AMOUNT.TXDATABYTES. TXDATABITS. DISCARDMODE will select if the first bits in the first byte read from RAM or the last bits in the last byte read from RAM will be discarded if TXD.AMOUNT.TXDATABITS are not equal to zero. Note that if TXD.FRAMECONFIG.PARITY



= Parity and TXD.FRAMECONFIG.DISCARDMODE=DiscardStart, a parity bit will be included after the non-complete first byte. No parity will be added after a non-complete last byte.

The frame assemble operation for different settings in TXD.FRAMECONFIG is illustrated in the following table. All shaded bit fields are added by the frame assembler. Some of these bits are optional and appearances are configured in TXD.FRAMECONFIG. Note that the frames illustrated do not necessarily comply with the NFC specification. The figure only illustrates the behavior of the NFCT peripheral.



Figure 95: Frame assemble illustration

The accurate timing for transmitting the frame on air is set using the frame timing controller settings.

#### 7.20.6 Frame disassembler

The NFCT peripheral implements a frame disassembler in hardware.

When the NFCT peripheral is in the ACTIVE\_A state, the software can decide to enter RX or TX mode. For TX mode, see Frame assembler on page 302. For RX mode, the software must indicate the address and size of the destination buffer in Data RAM through programming the PACKETPTR and MAXLEN registers before issuing an ENABLERXDATA task.

The STARTED event indicates that the PACKETPTR and MAXLEN registers have been captured by the frame disassembler EasyDMA.

When an incoming frame starts, the RXFRAMESTART event will get issued and data will be written to the buffer in Data RAM. The frame disassembler will verify and remove any parity bits, start of frame (SoF) and end of frame (EoF) symbols on the fly based on RXD.FRAMECONFIG register configuration. It will, however, verify and transfer the CRC bytes into RAM, if the CRC is enabled through RXD.FRAMECONFIG.

When an EoF symbol is detected, the NFCT peripheral will assert the RXFRAMEEND event and write the RXD.AMOUNT register to indicate numbers of received bytes and bits in the data packet. The module does not interpret the content of the data received from the remote NFC device, except for SoF, EoF, parity, and CRC checking, as described above. The frame disassemble operation is illustrated in the following figure.





Figure 96: Frame disassemble illustration

Per NFC specification, the time between EoF to the next SoF can be as short as  $86 \mu s$ , and thefore care must be taken that PACKETPTR and MAXLEN are ready and ENABLERXDATA is issued on time after the end of previous frame. The use of a PPI shortcut from TXFRAMEEND to ENABLERXDATA is recommended.

## 7.20.7 Frame timing controller

The NFCT peripheral includes a frame timing controller that continuously keeps track of the number of the 13.56 MHz RF carrier clock periods since the end of the EoF of the last received frame.

The NFCT peripheral can be programmed to send a responding frame within a time window or at an exact count of RF carrier periods. In case of FRAMEDELAYMODE = Window, a STARTTX task triggered before the frame timing controller counter is equal to FRAMEDELAYMIN will force the transmission to halt until the counter is equal to FRAMEDELAYMIN. If the counter is within FRAMEDELAYMIN and FRAMEDELAYMAX when the STARTTX task is triggered, the NFCT peripheral will start the transmission straight away. In case of FRAMEDELAYMODE = ExactVal, a STARTTX task triggered before the frame delay counter is equal to FRAMEDELAYMAX will halt the actual transmission start until the counter is equal to FRAMEDELAYMAX.

In case of FRAMEDELAYMODE = WindowGrid, the behaviour is similar to the FRAMEDELAYMODE = Window, but the actual transmission between FRAMEDELAYMIN and FRAMEDELAYMAX starts on a bit grid as defined for NFC-A Listen frames (slot duration of 128 RF carrier periods).

An ERROR event (with FRAMEDELAYTIMEOUT cause in ERRORSTATUS) will be asserted if the frame timing controller counter reaches FRAMEDELAYMAX without any STARTTX task triggered. This may happen even when the response is not required as per *NFC Forum, NFC Digital Protocol Technical Specification*. Any commands handled by the automatic collision resolution that don't involve a response being generated may also result in an ERROR event (with FRAMEDELAYTIMEOUT cause in ERRORSTATUS). The FRAMEDELAYMIN and FRAMEDELAYMAX values shall only be updated before the STARTTX task is triggered. Failing to do so may cause unpredictable behaviour.

The frame timing controller operation is illustrated in the following figure. The frame timing controller automatically adjusts the frame timing counter based on the last received data bit according to NFC-A technology in the NFC Forum, NFC Digital Protocol Technical Specification.





Figure 97: Frame timing controller (FRAMEDELAYMODE=Window)

#### 7.20.8 Collision resolution

The NFCT peripheral implements an automatic collision resolution function as defined by the NFC Forum.

Automatic collision resolution is enabled by default, and it is recommended that the feature is used since it is power efficient and reduces the complexity of software handling the collision resolution sequence. This feature can be disabled through the MODE field in the AUTOCOLRESCONFIG register. When the automatic collision resolution is disabled, all commands will be sent over EasyDMA as defined in frame disassembler.

The SENSRES and SELRES registers need to be programmed upfront in order for the collision resolution to behave correctly. Depending on the NFCIDSIZE field in SENSRES, the following registers also need to be programmed upfront:

- NFCID1 LAST if NFCID1SIZE=NFCID1Single (ID = 4 bytes);
- NFCID1\_2ND\_LAST and NFCID1\_LAST if NFCID1SIZE=NFCID1Double (ID = 7 bytes);
- NFCID1\_3RD\_LAST, NFCID1\_2ND\_LAST and NFCID1\_LAST if NFCID1SIZE=NFCID1Triple (ID = 10 bytes);

A pre-defined set of registers, NFC.TAGHEADER0..3, containing a valid NFCID1 value, is available in FICR and can be used by software to populate the NFCID1\_3RD\_LAST, NFCID1\_2ND\_LAST, and NFCID1\_LAST registers.

NFCID1 byte allocation (top sent first on air) on page 306 explains the position of the ID bytes in NFCID1\_3RD\_LAST, NFCID1\_2ND\_LAST, and NFCID1\_LAST, depending on the ID size, and as compared to the definition used in the *NFC Forum*, *NFC Digital Protocol Technical Specification*.



|          | ID = 4 bytes        | ID = 7 bytes        | ID = 10 bytes       |
|----------|---------------------|---------------------|---------------------|
| NFCID1_Q |                     |                     | nfcid1 <sub>0</sub> |
| NFCID1_R |                     |                     | $nfcid1_1$          |
| NFCID1_S |                     |                     | nfcid1 <sub>2</sub> |
| NFCID1_T |                     | nfcid1 <sub>0</sub> | nfcid1 <sub>3</sub> |
| NFCID1_U |                     | $nfcid1_1$          | nfcid1 <sub>4</sub> |
| NFCID1_V |                     | nfcid1 <sub>2</sub> | nfcid1 <sub>5</sub> |
| NFCID1_W | nfcid1 <sub>0</sub> | nfcid1 <sub>3</sub> | nfcid1 <sub>6</sub> |
| NFCID1_X | nfcid1 <sub>1</sub> | nfcid1 <sub>4</sub> | nfcid1 <sub>7</sub> |
| NFCID1_Y | nfcid1 <sub>2</sub> | nfcid1 <sub>5</sub> | nfcid1 <sub>8</sub> |
| NFCID1_Z | nfcid1 <sub>3</sub> | nfcid1 <sub>6</sub> | nfcid1 <sub>9</sub> |

Table 99: NFCID1 byte allocation (top sent first on air)

The hardware implementation can handle the states from IDLE to ACTIVE\_A automatically as defined in the NFC Forum, NFC Activity Technical Specification, and the other states are to be handled by software. The software keeps track of the state through events. The collision resolution will trigger an AUTOCOLRESSTARTED event when it has started. Reaching the ACTIVE\_A state is indicated by the SELECTED event.

If collision resolution fails, a COLLISION event is triggered. Note that errors occurring during automatic collision resolution may also cause ERROR and/or RXERROR events to be generated. Other events may also get generated. It is recommended that the software ignores any event except COLLISION, SELECTED and FIELDLOST during automatic collision resolution. Software shall also make sure that any unwanted SHORT or PPI shortcut is disabled during automatic collision resolution.

The automatic collision resolution will be restarted, if the packets are received with CRC or parity errors while in ACTIVE\_A state. The automatic collision resolution feature can be disabled while in ACTIVE\_A state to avoid this.

The SLP\_REQ is automatically handled by the NFCT peripheral when the automatic collision resolution is enabled. However, this results in an ERROR event (with FRAMEDELAYTIMEOUT cause in ERRORSTATUS) since the SLP\_REQ has no response. This error must be ignored until the SELECTED event is triggered and this error should be cleared by the software when the SELECTED event is triggered.

#### 7.20.9 Antenna interface

In ACTIVATED state, an amplitude regulator will adjust the voltage swing on the antenna pins to a value that is within the  $V_{swing}$  limit.

Refer to NFCT Electrical Specification on page 334.

#### 7.20.10 NFCT antenna recommendations

The NFCT antenna coil must be connected differential between NFC1 and NFC2 pins of the device.

Two external capacitors should be used to tune the resonance of the antenna circuit to 13.56 MHz.





Figure 98: NFCT antenna recommendations

The required tuning capacitor value is given by the below equations:

$$C'_{tone} = \frac{1}{(2\pi \cdot 13.56 \text{ MHz})^2 \cdot L_{ans}} \quad \text{where } C'_{tone} = \frac{1}{2} \cdot (C_p + C_{int} + C_{tone})$$

$$and \ C_{tone} = C_{tone} = C_{tone} \qquad C_{p1} = C_{p2} = C_p \qquad C_{int1} = C_{int2} = C_{int}$$

$$C_{tone} = \frac{2}{(2\pi \cdot 13.56 \text{ MHz})^2 \cdot L_{ans}} - C_p - C_{int}$$

An antenna inductance of  $L_{ant} = 2 \mu H$  will give tuning capacitors in the range of 130 pF on each pin. The total capacitance on **NFC1** and **NFC2** must be matched.

# 7.20.11 Battery protection

If the antenna is exposed to a strong NFC field, current may flow in the opposite direction on the supply due to parasitic diodes and ESD structures.

If the battery used does not tolerate return current, a series diode must be placed between the battery and the device in order to protect the battery.

# 7.20.12 Digital Modulation Signal

Support for external analog frontends or antenna architectures is possible by optionally outputting the digital modulation signal to a GPIO.

The NFCT peripheral is designed to connect directly to a loop antenna, receive a modulated signal from an NFC Reader with its internal analog frontend and transmit data back by changing the input resistance that is then seen as modulated load by the NFC Reader.

In addition, the peripheral has an option to output the digital modulation signal to a GPIO. Reception still occurs through the internal analog frontend, whereas transmission can be done by one of the following:

- The internal analog frontend through the loop antenna (default)
- An external frontend using the digital modulation signal
- The combination of both above



There are two registers that allow configuration of the modulation signal (i.e. of the response from NFCT to the NFC Reader), MODULATIONCTRL and MODULATIONPSEL. The registers need to be programmed before NFCT sends a response to a request from a reader. Ideally, this configuration is performed during startup and whenever the NFCT peripheral is powered up.

The selected GPIO needs to be configured as output in the corresponding GPIO configuration register. It is recommended to set an output value in the corresponding GPIO.OUT register – this value will be driven whenever the NFCT peripheral is disabled.

NFCT drives the pin low when there is no modulation, and drives it with On-Off Keying (OOK) modulation of an 847 kHz subcarrier (derived from the carrier frequency) when it responds to commands from an NFC Reader.

#### 7.20.13 References

NFC Forum, NFC Analog Specification version 2.1, www.nfc-forum.org

NFC Forum, NFC Digital Protocol Technical Specification version 2.2, www.nfc-forum.org

NFC Forum, NFC Activity Technical Specification version 2.1, www.nfc-forum.org

# 7.20.14 Registers

| Base address Domain       | Peripheral | Instance  | Secure mapping | DMA security | Description              | Configuration |
|---------------------------|------------|-----------|----------------|--------------|--------------------------|---------------|
| 0x5002D000<br>APPLICATION | N NECT     | NFCT : S  | HE             | SA           | Near field communication |               |
| 0x4002D000                | N INFCI    | NFCT : NS | 03             | SA           | tag                      |               |

Table 100: Instances

| Register               | Offset | Security | Description                                                                          |
|------------------------|--------|----------|--------------------------------------------------------------------------------------|
| TASKS_ACTIVATE         | 0x000  |          | Activate NFCT peripheral for incoming and outgoing frames, change state to activated |
| TASKS_DISABLE          | 0x004  |          | Disable NFCT peripheral                                                              |
| TASKS_SENSE            | 0x008  |          | Enable NFC sense field mode, change state to sense mode                              |
| TASKS_STARTTX          | 0x00C  |          | Start transmission of an outgoing frame, change state to transmit                    |
| TASKS_ENABLERXDATA     | 0x01C  |          | Initializes the EasyDMA for receive.                                                 |
| TASKS_GOIDLE           | 0x024  |          | Force state machine to IDLE state                                                    |
| TASKS_GOSLEEP          | 0x028  |          | Force state machine to SLEEP_A state                                                 |
| SUBSCRIBE_ACTIVATE     | 0x080  |          | Subscribe configuration for task ACTIVATE                                            |
| SUBSCRIBE_DISABLE      | 0x084  |          | Subscribe configuration for task DISABLE                                             |
| SUBSCRIBE_SENSE        | 0x088  |          | Subscribe configuration for task SENSE                                               |
| SUBSCRIBE_STARTTX      | 0x08C  |          | Subscribe configuration for task STARTTX                                             |
| SUBSCRIBE_ENABLERXDATA | 0x09C  |          | Subscribe configuration for task ENABLERXDATA                                        |
| SUBSCRIBE_GOIDLE       | 0x0A4  |          | Subscribe configuration for task GOIDLE                                              |
| SUBSCRIBE_GOSLEEP      | 0x0A8  |          | Subscribe configuration for task GOSLEEP                                             |
| EVENTS_READY           | 0x100  |          | The NFCT peripheral is ready to receive and send frames                              |
| EVENTS_FIELDDETECTED   | 0x104  |          | Remote NFC field detected                                                            |
| EVENTS_FIELDLOST       | 0x108  |          | Remote NFC field lost                                                                |
| EVENTS_TXFRAMESTART    | 0x10C  |          | Marks the start of the first symbol of a transmitted frame                           |
| EVENTS_TXFRAMEEND      | 0x110  |          | Marks the end of the last transmitted on-air symbol of a frame                       |
| EVENTS_RXFRAMESTART    | 0x114  |          | Marks the end of the first symbol of a received frame                                |
| EVENTS_RXFRAMEEND      | 0x118  |          | Received data has been checked (CRC, parity) and transferred to RAM, and EasyDMA     |
|                        |        |          | has ended accessing the RX buffer                                                    |
| EVENTS_ERROR           | 0x11C  |          | NFC error reported. The ERRORSTATUS register contains details on the source of the   |
|                        |        |          | error.                                                                               |



| Register                  | Offset 5 | Security | Description                                                                           |
|---------------------------|----------|----------|---------------------------------------------------------------------------------------|
| EVENTS_RXERROR            | 0x128    |          | NFC RX frame error reported. The FRAMESTATUS.RX register contains details on the      |
|                           |          |          | source of the error.                                                                  |
| EVENTS_ENDRX              | 0x12C    |          | RX buffer (as defined by PACKETPTR and MAXLEN) in Data RAM full.                      |
| EVENTS_ENDTX              | 0x130    |          | Transmission of data in RAM has ended, and EasyDMA has ended accessing the TX         |
|                           |          |          | buffer                                                                                |
| EVENTS_AUTOCOLRESSTARTED  | 0x138    |          | Auto collision resolution process has started                                         |
| EVENTS_COLLISION          | 0x148    |          | NFC auto collision resolution error reported.                                         |
| EVENTS_SELECTED           | 0x14C    |          | NFC auto collision resolution successfully completed                                  |
| EVENTS_STARTED            | 0x150    |          | EasyDMA is ready to receive or send frames.                                           |
| PUBLISH_READY             | 0x180    |          | Publish configuration for event READY                                                 |
| PUBLISH_FIELDDETECTED     | 0x184    |          | Publish configuration for event FIELDDETECTED                                         |
| PUBLISH_FIELDLOST         | 0x188    |          | Publish configuration for event FIELDLOST                                             |
| PUBLISH_TXFRAMESTART      | 0x18C    |          | Publish configuration for event TXFRAMESTART                                          |
| PUBLISH_TXFRAMEEND        | 0x190    |          | Publish configuration for event TXFRAMEEND                                            |
| PUBLISH_RXFRAMESTART      | 0x194    |          | Publish configuration for event RXFRAMESTART                                          |
| PUBLISH_RXFRAMEEND        | 0x198    |          | Publish configuration for event RXFRAMEEND                                            |
| PUBLISH_ERROR             | 0x19C    |          | Publish configuration for event ERROR                                                 |
| PUBLISH_RXERROR           | 0x1A8    |          | Publish configuration for event RXERROR                                               |
| PUBLISH_ENDRX             | 0x1AC    |          | Publish configuration for event ENDRX                                                 |
| PUBLISH_ENDTX             | 0x1B0    |          | Publish configuration for event ENDTX                                                 |
| PUBLISH_AUTOCOLRESSTARTED | 0x1B8    |          | Publish configuration for event AUTOCOLRESSTARTED                                     |
| PUBLISH_COLLISION         | 0x1C8    |          | Publish configuration for event COLLISION                                             |
| PUBLISH_SELECTED          | 0x1CC    |          | Publish configuration for event SELECTED                                              |
| PUBLISH_STARTED           | 0x1D0    |          | Publish configuration for event STARTED                                               |
| HORTS                     | 0x200    |          | Shortcuts between local events and tasks                                              |
| NTEN                      | 0x300    |          | Enable or disable interrupt                                                           |
| NTENSET                   | 0x304    |          | Enable interrupt                                                                      |
| NTENCLR                   | 0x308    |          | Disable interrupt                                                                     |
| RRORSTATUS                | 0x404    |          | NFC Error Status register                                                             |
| RAMESTATUS.RX             | 0x40C    |          | Result of last incoming frame                                                         |
| NFCTAGSTATE               | 0x410    |          | Current operating state of NFC tag                                                    |
| SLEEPSTATE                | 0x420    |          | Sleep state during automatic collision resolution                                     |
| FIELDPRESENT              | 0x43C    |          | Indicates the presence or not of a valid field                                        |
| RAMEDELAYMIN              | 0x504    |          | Minimum frame delay                                                                   |
| FRAMEDELAYMAX             | 0x508    |          | Maximum frame delay                                                                   |
| FRAMEDELAYMODE            | 0x50C    |          | Configuration register for the Frame Delay Timer                                      |
| PACKETPTR                 | 0x510    |          | Packet pointer for TXD and RXD data storage in Data RAM                               |
| MAXLEN                    | 0x514    |          | Size of the RAM buffer allocated to TXD and RXD data storage each                     |
| TXD.FRAMECONFIG           | 0x518    |          | Configuration of outgoing frames                                                      |
| TXD.AMOUNT                | 0x51C    |          | Size of outgoing frame                                                                |
| RXD.FRAMECONFIG           | 0x520    |          | Configuration of incoming frames                                                      |
| RXD.AMOUNT                | 0x524    |          | Size of last incoming frame                                                           |
| MODULATIONCTRL            | 0x52C    |          | Enables the modulation output to a GPIO pin which can be connected to a second        |
|                           |          |          | external antenna.                                                                     |
| MODULATIONPSEL            | 0x538    |          | Pin select for Modulation control                                                     |
| IFCID1 LAST               | 0x590    |          | Last NFCID1 part (4, 7 or 10 bytes ID)                                                |
| IFCID1_2ND_LAST           | 0x594    |          | Second last NFCID1 part (7 or 10 bytes ID)                                            |
| IFCID1_3RD_LAST           | 0x598    |          | Third last NFCID1 part (10 bytes ID)                                                  |
| AUTOCOLRESCONFIG          | 0x59C    |          | Controls the auto collision resolution function. This setting must be done before the |
|                           | 3,000    |          | NFCT peripheral is activated.                                                         |
| SENSRES                   | 0x5A0    |          | NFC-A SENS_RES auto-response settings                                                 |
| SELRES                    | 0x5A4    |          | NFC-A SEL_RES auto-response settings                                                  |

Table 101: Register overview



#### 7.20.14.1 TASKS\_ACTIVATE

Address offset: 0x000

Activate NFCT peripheral for incoming and outgoing frames, change state to activated



#### **7.20.14.2 TASKS DISABLE**

Address offset: 0x004

Disable NFCT peripheral



## 7.20.14.3 TASKS SENSE

Address offset: 0x008

Enable NFC sense field mode, change state to sense mode



# 7.20.14.4 TASKS\_STARTTX

Address offset: 0x00C

Start transmission of an outgoing frame, change state to transmit







# 7.20.14.5 TASKS\_ENABLERXDATA

Address offset: 0x01C

Initializes the EasyDMA for receive.



#### 7.20.14.6 TASKS GOIDLE

Address offset: 0x024

Force state machine to IDLE state

| Bit n | umber    |              |         | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|---------|------------------|-----------------------------------------------------------------------|
| ID    |          |              |         |                  | A                                                                     |
| Rese  | et 0x000 | 00000        |         | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |              |         |                  |                                                                       |
| Α     | W        | TASKS_GOIDLE |         |                  | Force state machine to IDLE state                                     |
|       |          |              | Trigger | 1                | Trigger task                                                          |

## 7.20.14.7 TASKS\_GOSLEEP

Address offset: 0x028

Force state machine to SLEEP\_A state

| Bit n | umber    |               |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|---------|------------------------|-----------------------------------------------------------------|
| ID    |          |               |         |                        | А                                                               |
| Rese  | et 0x000 | 00000         |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |               |         |                        | Description                                                     |
| Α     | W        | TASKS_GOSLEEP |         |                        | Force state machine to SLEEP_A state                            |
|       |          |               | Trigger | 1                      | Trigger task                                                    |

## 7.20.14.8 SUBSCRIBE\_ACTIVATE

Address offset: 0x080

Subscribe configuration for task ACTIVATE







#### 7.20.14.9 SUBSCRIBE\_DISABLE

Address offset: 0x084

Subscribe configuration for task DISABLE



## 7.20.14.10 SUBSCRIBE\_SENSE

Address offset: 0x088

Subscribe configuration for task SENSE



#### 7.20.14.11 SUBSCRIBE STARTTX

Address offset: 0x08C

Subscribe configuration for task STARTTX



## 7.20.14.12 SUBSCRIBE\_ENABLERXDATA

Address offset: 0x09C

Subscribe configuration for task ENABLERXDATA





## 7.20.14.13 SUBSCRIBE GOIDLE

Address offset: 0x0A4

Subscribe configuration for task GOIDLE



## 7.20.14.14 SUBSCRIBE GOSLEEP

Address offset: 0x0A8

Subscribe configuration for task GOSLEEP



#### 7.20.14.15 EVENTS READY

Address offset: 0x100

The NFCT peripheral is ready to receive and send frames







## 7.20.14.16 EVENTS\_FIELDDETECTED

Address offset: 0x104

Remote NFC field detected



#### 7.20.14.17 EVENTS FIELDLOST

Address offset: 0x108
Remote NFC field lost



## 7.20.14.18 EVENTS\_TXFRAMESTART

Address offset: 0x10C

Marks the start of the first symbol of a transmitted frame



#### 7.20.14.19 EVENTS TXFRAMEEND

Address offset: 0x110

Marks the end of the last transmitted on-air symbol of a frame





## 7.20.14.20 EVENTS RXFRAMESTART

Address offset: 0x114

Marks the end of the first symbol of a received frame



#### 7.20.14.21 EVENTS\_RXFRAMEEND

Address offset: 0x118

Received data has been checked (CRC, parity) and transferred to RAM, and EasyDMA has ended accessing the RX buffer



#### 7.20.14.22 EVENTS ERROR

Address offset: 0x11C

NFC error reported. The ERRORSTATUS register contains details on the source of the error.







## 7.20.14.23 EVENTS\_RXERROR

Address offset: 0x128

NFC RX frame error reported. The FRAMESTATUS.RX register contains details on the source of the error.



## 7.20.14.24 EVENTS\_ENDRX

Address offset: 0x12C

RX buffer (as defined by PACKETPTR and MAXLEN) in Data RAM full.



#### 7.20.14.25 EVENTS ENDTX

Address offset: 0x130

Transmission of data in RAM has ended, and EasyDMA has ended accessing the TX buffer



# 7.20.14.26 EVENTS\_AUTOCOLRESSTARTED

Address offset: 0x138

Auto collision resolution process has started





# 7.20.14.27 EVENTS\_COLLISION

Address offset: 0x148

NFC auto collision resolution error reported.

| Bit n | umber   |                  |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                  |              |                         | A                                                               |
| Rese  | t 0x000 | 00000            |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                  |              |                         |                                                                 |
| Α     | RW      | EVENTS_COLLISION |              |                         | NFC auto collision resolution error reported.                   |
|       |         |                  | NotGenerated | 0                       | Event not generated                                             |
|       |         |                  | Generated    | 1                       | Event generated                                                 |

# 7.20.14.28 EVENTS\_SELECTED

Address offset: 0x14C

NFC auto collision resolution successfully completed

| Bit n | umber    |                 |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                 |              |                         | А                                                               |
| Rese  | et 0x000 | 00000           |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                 |              |                         | Description                                                     |
| Α     | RW       | EVENTS_SELECTED |              |                         | NFC auto collision resolution successfully completed            |
|       |          |                 | NotGenerated | 0                       | Event not generated                                             |
|       |          |                 | Generated    | 1                       | Event generated                                                 |

# 7.20.14.29 EVENTS\_STARTED

Address offset: 0x150

EasyDMA is ready to receive or send frames.

| Bit r | umber    |                |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                |              |                         | А                                                               |
| Rese  | et 0x000 | 00000          |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                |              |                         | Description                                                     |
| Α     | RW       | EVENTS_STARTED |              |                         | EasyDMA is ready to receive or send frames.                     |
|       |          |                | NotGenerated | 0                       | Event not generated                                             |
|       |          |                | Generated    | 1                       | Event generated                                                 |

# 7.20.14.30 PUBLISH\_READY

Address offset: 0x180

Publish configuration for event READY





# 7.20.14.31 PUBLISH\_FIELDDETECTED

Address offset: 0x184

Publish configuration for event FIELDDETECTED



# 7.20.14.32 PUBLISH\_FIELDLOST

Address offset: 0x188

Publish configuration for event FIELDLOST

| Bit n | umber    |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 | 4 3 | 2 1 0 |
|-------|----------|--------|----------|-------------------------|-------------------------------------------------------|-----|-------|
| ID    |          |        |          | В                       | ААА                                                   | АА  | A A A |
| Rese  | et 0x000 | 00000  |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0               | 0 0 | 0 0 0 |
| ID    |          |        |          |                         |                                                       |     |       |
| Α     | DIA      | 0.1151 |          | [355 0]                 | BBBI I III I I FIFI DI OST III III I                  |     |       |
|       | RW       | CHIDX  |          | [2550]                  | DPPI channel that event FIELDLOST will publish to.    |     |       |
| В     | RW       | EN     |          | [2550]                  | DPPI channel that event FIELDLOST WIII publish to.    |     |       |
|       |          |        | Disabled | 0                       | Disable publishing                                    |     |       |

#### 7.20.14.33 PUBLISH TXFRAMESTART

Address offset: 0x18C

Publish configuration for event TXFRAMESTART







## 7.20.14.34 PUBLISH\_TXFRAMEEND

Address offset: 0x190

Publish configuration for event TXFRAMEEND



## 7.20.14.35 PUBLISH\_RXFRAMESTART

Address offset: 0x194

Publish configuration for event RXFRAMESTART



#### 7.20.14.36 PUBLISH RXFRAMEEND

Address offset: 0x198

Publish configuration for event RXFRAMEEND



## 7.20.14.37 PUBLISH\_ERROR

Address offset: 0x19C

Publish configuration for event ERROR





# 7.20.14.38 PUBLISH\_RXERROR

Address offset: 0x1A8

Publish configuration for event RXERROR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                     |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event RXERROR will publish to.                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

## 7.20.14.39 PUBLISH\_ENDRX

Address offset: 0x1AC

Publish configuration for event ENDRX

| Bit n | umber   |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |        |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 000000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |        |          |                         | Description                                                     |
| Α     | RW      | CHIDX  |          | [2550]                  | DPPI channel that event ENDRX will publish to.                  |
| В     | RW      | EN     |          |                         |                                                                 |
|       |         |        |          |                         |                                                                 |
|       |         |        | Disabled | 0                       | Disable publishing                                              |

## 7.20.14.40 PUBLISH\_ENDTX

Address offset: 0x1B0

Publish configuration for event ENDTX







## 7.20.14.41 PUBLISH\_AUTOCOLRESSTARTED

Address offset: 0x1B8

Publish configuration for event AUTOCOLRESSTARTED



#### 7.20.14.42 PUBLISH\_COLLISION

Address offset: 0x1C8

Publish configuration for event COLLISION



#### 7.20.14.43 PUBLISH SELECTED

Address offset: 0x1CC

Publish configuration for event **SELECTED** 



#### 7.20.14.44 PUBLISH\_STARTED

Address offset: 0x1D0

Publish configuration for event STARTED





## 7.20.14.45 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |          |                      |          |                         |                                                               |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|----------------------|----------|-------------------------|---------------------------------------------------------------|---|
| Reset 0x00000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bit n | umber    |                      |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | ) |
| A RW FIELDDETECTED_ACTIVATE  Disabled Enabled Disabled Disabled Disables shortcut Enabled Disabled Disables shortcut Enabled Disabled Disables shortcut Enables shortcut Enables shortcut Disables shortcut Enables shortcut Disables shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ID    |          |                      |          |                         | F B                                                           | 4 |
| A RW FIELDDETECTED_ACTIVATE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  B RW FIELDLOST_SENSE  Disabled 0 Disable shortcut  Shortcut between event FIELDLOST and task SENSE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA  Disabled 0 Disable shortcut  Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Rese  | et 0x000 | 00000                |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       | ) |
| ACTIVATE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  B RW FIELDLOST_SENSE Shortcut between event FIELDLOST and task SENSE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ID    |          |                      |          |                         |                                                               | ı |
| Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  B RW FIELDLOST_SENSE Shortcut between event FIELDLOST and task SENSE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Α     | RW       | FIELDDETECTED_ACTIVA | ATE      |                         | Shortcut between event FIELDDETECTED and task                 | _ |
| Enabled 1 Enable shortcut  B RW FIELDLOST_SENSE Shortcut between event FIELDLOST and task SENSE  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |          |                      |          |                         | ACTIVATE                                                      |   |
| B RW FIELDLOST_SENSE  Disabled  Disabled  Enabled  TXFRAMEEND_ENABLERXDATA  Disabled  Disabled |       |          |                      | Disabled | 0                       | Disable shortcut                                              |   |
| Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |          |                      | Enabled  | 1                       | Enable shortcut                                               |   |
| Enabled 1 Enable shortcut  F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | В     | RW       | FIELDLOST_SENSE      |          |                         | Shortcut between event FIELDLOST and task SENSE               |   |
| F RW TXFRAMEEND_ENABLERXDATA Shortcut between event TXFRAMEEND and task  ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |          |                      | Disabled | 0                       | Disable shortcut                                              |   |
| ENABLERXDATA  Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |          |                      | Enabled  | 1                       | Enable shortcut                                               |   |
| Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F     | RW       | TXFRAMEEND_ENABLE    | RXDATA   |                         | Shortcut between event TXFRAMEEND and task                    |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |          |                      |          |                         | ENABLERXDATA                                                  |   |
| Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |          |                      | Disabled | 0                       | Disable shortcut                                              |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |          |                      | Enabled  | 1                       | Enable shortcut                                               |   |

## 7.20.14.46 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit r | umber    |               |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |               |          |                         | TSR NMLK HGFEDCBA                                               |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |               |          |                         |                                                                 |
| Α     | RW       | READY         |          |                         | Enable or disable interrupt for event READY                     |
|       |          |               | Disabled | 0                       | Disable                                                         |
|       |          |               | Enabled  | 1                       | Enable                                                          |
| В     | RW       | FIELDDETECTED |          |                         | Enable or disable interrupt for event FIELDDETECTED             |
|       |          |               | Disabled | 0                       | Disable                                                         |
|       |          |               | Enabled  | 1                       | Enable                                                          |
| С     | RW       | FIELDLOST     |          |                         | Enable or disable interrupt for event FIELDLOST                 |
|       |          |               | Disabled | 0                       | Disable                                                         |
|       |          |               | Enabled  | 1                       | Enable                                                          |
| D     | RW       | TXFRAMESTART  |          |                         | Enable or disable interrupt for event TXFRAMESTART              |
|       |          |               | Disabled | 0                       | Disable                                                         |
|       |          |               | Enabled  | 1                       | Enable                                                          |
| E     | RW       | TXFRAMEEND    |          |                         | Enable or disable interrupt for event TXFRAMEEND                |
|       |          |               | Disabled | 0                       | Disable                                                         |





| Bit n | umber   |                   |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                   |          |                         | TSR NMLK HGFEDCBA                                               |
| Rese  | t 0x000 | 00000             |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |         |                   |          |                         |                                                                 |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| F     | RW      | RXFRAMESTART      |          |                         | Enable or disable interrupt for event RXFRAMESTART              |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| G     | RW      | RXFRAMEEND        |          |                         | Enable or disable interrupt for event RXFRAMEEND                |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| Н     | RW      | ERROR             |          |                         | Enable or disable interrupt for event ERROR                     |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| K     | RW      | RXERROR           |          |                         | Enable or disable interrupt for event RXERROR                   |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| L     | RW      | ENDRX             |          |                         | Enable or disable interrupt for event ENDRX                     |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| М     | RW      | ENDTX             |          |                         | Enable or disable interrupt for event ENDTX                     |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| N     | RW      | AUTOCOLRESSTARTED |          |                         | Enable or disable interrupt for event AUTOCOLRESSTARTED         |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| R     | RW      | COLLISION         |          |                         | Enable or disable interrupt for event COLLISION                 |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| S     | RW      | SELECTED          |          |                         | Enable or disable interrupt for event SELECTED                  |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| Т     | RW      | STARTED           |          |                         | Enable or disable interrupt for event STARTED                   |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |

# 7.20.14.47 INTENSET

Address offset: 0x304 Enable interrupt

| Bit n | umber   |               |          | 313 | 30 2 | 9 28 | 27 | 26 2 | 25 24 | 4 2 | 3 22  | 2 2 1 | 20 1 | 19  | 18 1 | 17 1 | 6 15 | 14   | 13   | 12 1 | .1 10 | 9   | 8    | 7  | 6 ! | 5 4 | 1 3 | 2 | 1 0 |
|-------|---------|---------------|----------|-----|------|------|----|------|-------|-----|-------|-------|------|-----|------|------|------|------|------|------|-------|-----|------|----|-----|-----|-----|---|-----|
| ID    |         |               |          |     |      |      |    |      |       |     |       |       | Т    | S   | R    |      |      | Ν    |      | M    | L K   |     |      | Н  | G I | F E | D   | С | ВА  |
| Rese  | t 0x000 | 00000         |          | 0   | 0 (  | 0 0  | 0  | 0    | 0 0   | C   | 0     | 0     | 0    | 0   | 0    | 0 (  | 0    | 0    | 0    | 0    | 0 0   | 0   | 0    | 0  | 0 ( | 0 ( | 0   | 0 | 0 0 |
| ID    |         |               |          |     |      |      |    |      |       |     |       |       |      |     |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
| Α     | RW      | READY         |          |     |      |      |    |      |       | ٧   | Vrite | e '1' | to e | ena | ble  | inte | erru | pt f | or e | ven  | t RE  | ADY | ,    |    |     |     |     |   |     |
|       |         |               | Set      | 1   |      |      |    |      |       | Ε   | nab   | le    |      |     |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
|       |         |               | Disabled | 0   |      |      |    |      |       | R   | ead   | : Di  | sabl | ed  |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
|       |         |               | Enabled  | 1   |      |      |    |      |       | R   | ead   | : En  | able | ed  |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
| В     | RW      | FIELDDETECTED |          |     |      |      |    |      |       | ٧   | Vrite | e '1' | to e | ena | ble  | inte | erru | pt f | or e | ven  | t FIE | LDE | DETE | СТ | ED  |     |     |   |     |
|       |         |               | Set      | 1   |      |      |    |      |       | Ε   | nab   | le    |      |     |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
|       |         |               | Disabled | 0   |      |      |    |      |       | R   | ead   | : Di  | sabl | ed  |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |
|       |         |               | Enabled  | 1   |      |      |    |      |       | R   | ead   | : En  | able | ed  |      |      |      |      |      |      |       |     |      |    |     |     |     |   |     |





| Bit n            | umber |                    |          | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |                                                       |
|------------------|-------|--------------------|----------|-------------------------------------------------------------|-------------------------------------------------------|
| ID               |       |                    |          |                                                             | TSR NMLK HGFEDCBA                                     |
| Reset 0x00000000 |       |                    |          | 0 0 0 0 0 0 0 0                                             | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0               |
|                  |       |                    |          |                                                             |                                                       |
| С                | RW    | FIELDLOST          |          |                                                             | Write '1' to enable interrupt for event FIELDLOST     |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| D                | RW    | TXFRAMESTART       |          |                                                             | Write '1' to enable interrupt for event TXFRAMESTART  |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| E                | RW    | TXFRAMEEND         |          |                                                             | Write '1' to enable interrupt for event TXFRAMEEND    |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| F                | RW    | RXFRAMESTART       |          |                                                             | Write '1' to enable interrupt for event RXFRAMESTART  |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| G                | RW    | RXFRAMEEND         |          |                                                             | Write '1' to enable interrupt for event RXFRAMEEND    |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| Н                | RW    | ERROR              |          |                                                             | Write '1' to enable interrupt for event ERROR         |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| K                | RW    | RXERROR            |          |                                                             | Write '1' to enable interrupt for event RXERROR       |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  | DVA   | FNDDV              | Enabled  | 1                                                           | Read: Enabled                                         |
| L                | RW    | ENDRX              | 6.1      |                                                             | Write '1' to enable interrupt for event ENDRX         |
|                  |       |                    | Set      | 1                                                           | Enable  Part Disabled                                 |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  | DVA   | FNDTV              | Enabled  | 1                                                           | Read: Enabled                                         |
| M                | RW    | ENDTX              | Set      | 1                                                           | Write '1' to enable interrupt for event ENDTX  Enable |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| N                | RW    | AUTOCOLRESSTARTED  | Eliabled | 1                                                           | Write '1' to enable interrupt for event               |
| N                | IVV   | AUTOCOLINESSTANTED |          |                                                             | AUTOCOLRESSTARTED                                     |
|                  |       |                    | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| R                | RW    | COLLISION          | Lilabica | -                                                           | Write '1' to enable interrupt for event COLLISION     |
| 11               | 1.44  | COLLISION          | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |
| S                | RW    | SELECTED           | Litabica | -                                                           | Write '1' to enable interrupt for event SELECTED      |
| 3                |       | CLLCTLD            | Set      | 1                                                           | Enable                                                |
|                  |       |                    | Disabled | 0                                                           | Read: Disabled                                        |
|                  |       |                    |          |                                                             |                                                       |
|                  |       |                    | Enabled  | 1                                                           | Read: Enabled                                         |



| Bit number       |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|----------------------|------------------------------------------------------------------|
| ID               |          |                      | TSR NMLK HGFEDCBA                                                |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field     |          |                      | Description                                                      |
|                  | Set      | 1                    | Enable                                                           |
|                  | Disabled | 0                    | Read: Disabled                                                   |
|                  |          |                      |                                                                  |

## 7.20.14.48 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit r | number   |               |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|----------------------|------------------------------------------------------------------|
| ID    |          |               |          |                      | TSR NMLK HGFEDCBA                                                |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |          |               |          |                      |                                                                  |
| Α     | RW       | READY         |          |                      | Write '1' to disable interrupt for event READY                   |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| В     | RW       | FIELDDETECTED |          |                      | Write '1' to disable interrupt for event FIELDDETECTED           |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| С     | RW       | FIELDLOST     |          |                      | Write '1' to disable interrupt for event FIELDLOST               |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| D     | RW       | TXFRAMESTART  |          |                      | Write '1' to disable interrupt for event TXFRAMESTART            |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| E     | RW       | TXFRAMEEND    |          |                      | Write '1' to disable interrupt for event TXFRAMEEND              |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| F     | RW       | RXFRAMESTART  |          |                      | Write '1' to disable interrupt for event RXFRAMESTART            |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| G     | RW       | RXFRAMEEND    |          |                      | Write '1' to disable interrupt for event RXFRAMEEND              |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| Н     | RW       | ERROR         |          |                      | Write '1' to disable interrupt for event ERROR                   |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |
| K     | RW       | RXERROR       |          |                      | Write '1' to disable interrupt for event RXERROR                 |
|       |          |               | Clear    | 1                    | Disable                                                          |
|       |          |               | Disabled | 0                    | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                    | Read: Enabled                                                    |





| Bit n | umber   |                   |          | 31 | 30 29 | 9 28 | 27 | 26 2 | 25 24 | 4 2 | 3 22  | 2 2 1 | . 20 | 19   | 18 | 3 17 | 16  | 15  | 14   | 13 | 12  | 11 | 10   | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 : | 1 0 |
|-------|---------|-------------------|----------|----|-------|------|----|------|-------|-----|-------|-------|------|------|----|------|-----|-----|------|----|-----|----|------|-----|-----|---|---|---|---|---|-----|-----|
| ID    |         |                   |          |    |       |      |    |      |       |     |       |       | Т    | S    | R  |      |     |     | N    |    | М   | L  | K    |     |     | Н | G | F | Ε | D | C I | 3 A |
| Rese  | t 0x000 | 00000             |          | 0  | 0 0   | 0    | 0  | 0    | 0 0   | ) ( | 0 0   | 0     | 0    | 0    | 0  | 0    | 0   | 0   | 0    | 0  | 0   | 0  | 0    | 0   | 0   | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 0 |
|       |         |                   |          |    |       |      |    |      |       |     |       |       |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| L     | RW      | ENDRX             |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt | ENE  | DRX | (   |   |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disak | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | ł  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| М     | RW      | ENDTX             |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt | END  | хтс |     |   |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disab | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | ł  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| N     | RW      | AUTOCOLRESSTARTED |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt |      |     |     |   |   |   |   |   |     |     |
|       |         |                   |          |    |       |      |    |      |       | Α   | AUTO  | OCC   | DLR  | ESS  | TA | RTE  | D   |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disab | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | t  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| R     | RW      | COLLISION         |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt | COL  | LIS | ION | ı |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disab | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | t  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| S     | RW      | SELECTED          |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt | SELI | ECT | ΓED |   |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disab | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | t  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
| T     | RW      | STARTED           |          |    |       |      |    |      |       | ٧   | Vrite | e '1  | ' to | dis  | ab | le i | nte | rru | pt 1 | or | eve | nt | STA  | RTE | ED  |   |   |   |   |   |     |     |
|       |         |                   | Clear    | 1  |       |      |    |      |       | D   | Disab | ole   |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Disabled | 0  |       |      |    |      |       | R   | Read  | : Di  | isal | bled | t  |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   | Enabled  | 1  |       |      |    |      |       | R   | Read  | : Er  | nab  | led  |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |
|       |         |                   |          |    |       |      |    |      |       |     |       |       |      |      |    |      |     |     |      |    |     |    |      |     |     |   |   |   |   |   |     |     |

#### 7.20.14.49 ERRORSTATUS

Address offset: 0x404 NFC Error Status register

**Note:** Write a bit to 1 to clear it. Writing 0 has no effect.



### 7.20.14.50 FRAMESTATUS.RX

Address offset: 0x40C

4406\_640 v1.3

Result of last incoming frame

Note: Write a bit to 1 to clear it. Writing 0 has no effect.

326





#### 7.20.14.51 NFCTAGSTATE

Address offset: 0x410

Current operating state of NFC tag



### 7.20.14.52 SLEEPSTATE

Address offset: 0x420

Sleep state during automatic collision resolution

| Bit n | umber   |            |        | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|--------|------------------|------------------------------------------------------------------------|
| ID    |         |            |        |                  | А                                                                      |
| Rese  | t 0x000 | 00000      |        | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |            |        |                  | Description                                                            |
| Α     | R       | SLEEPSTATE |        |                  | Reflects the sleep state during automatic collision                    |
|       |         |            |        |                  | resolution. Set to IDLE by a GOIDLE task. Set to SLEEP_A               |
|       |         |            |        |                  | when a valid SLEEP_REQ frame is received or by a GOSLEEP               |
|       |         |            |        |                  | task.                                                                  |
|       |         |            | Idle   | 0                | State is IDLE.                                                         |
|       |         |            | SleepA | 1                | State is SLEEP_A.                                                      |

#### **7.20.14.53 FIELDPRESENT**

Address offset: 0x43C

Indicates the presence or not of a valid field

NORDIC

| Bit n | umber   |              |              | 31 | 30 | 29 2 | 28 27 | 7 26 | 25 | 24 | 23  | 22    | 2 21 | 20   | 19   | 18   | 17   | 16   | 15   | 14  | 13  | 12   | 11:   | 10   | 9    | 8   | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------|--------------|--------------|----|----|------|-------|------|----|----|-----|-------|------|------|------|------|------|------|------|-----|-----|------|-------|------|------|-----|------|-----|---|---|---|---|---|---|
| ID    |         |              |              |    |    |      |       |      |    |    |     |       |      |      |      |      |      |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   | В | Α |
| Rese  | t 0x000 | 00000        |              | 0  | 0  | 0    | 0 0   | 0    | 0  | 0  | 0   | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0   | 0    | 0     | 0    | 0    | 0 ( | 0    | 0   | 0 | 0 | 0 | 0 | 0 | 0 |
| ID    |         |              |              |    |    |      |       |      |    |    | De: |       |      |      |      |      |      |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |
| Α     | R       | FIELDPRESENT |              |    |    |      |       |      |    |    | Ind | dica  | ates | if   | a va | lid  | fie  | ld i | s p  | res | ent | . A  | /aila | able | e o  | nly | in 1 | the |   |   |   |   |   |   |
|       |         |              |              |    |    |      |       |      |    |    | act | tiva  | ated | d st | ate. |      |      |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |
|       |         |              | NoField      | 0  |    |      |       |      |    |    | No  | va    | alid | fie  | ld d | ete  | cte  | d    |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |
|       |         |              | FieldPresent | 1  |    |      |       |      |    |    | Val | lid   | fiel | d d  | ete  | cte  | d    |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |
| В     | R       | LOCKDETECT   |              |    |    |      |       |      |    |    | Ind | dica  | ates | if   | the  | lov  | v le | ve   | l ha | s l | ock | ed 1 | o t   | he 1 | fiel | d   |      |     |   |   |   |   |   |   |
|       |         |              | NotLocked    | 0  |    |      |       |      |    |    | No  | ot lo | ock  | ed 1 | to f | ielo | ł    |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |
|       |         |              | Locked       | 1  |    |      |       |      |    |    | Loc | cke   | ed t | o fi | eld  |      |      |      |      |     |     |      |       |      |      |     |      |     |   |   |   |   |   |   |

### **7.20.14.54 FRAMEDELAYMIN**

Address offset: 0x504 Minimum frame delay

| Α     | RW       | FRAMEDELAYMIN |                        | Minimum frame delay       | in numb   | er of : | 13.56 | MHz | clo | ck c | ycles |   |   |     |
|-------|----------|---------------|------------------------|---------------------------|-----------|---------|-------|-----|-----|------|-------|---|---|-----|
| ID    |          |               |                        |                           |           |         |       |     |     |      |       |   |   |     |
| Rese  | et 0x000 | 00480         | 0 0 0 0 0 0 0          | 000000000                 | 0 0       | 0 0     | 0 1   | 0 0 | 1   | 0    | 0 0   | 0 | 0 | 0 0 |
| ID    |          |               |                        |                           | Α Α .     | 4 Α ,   | А А   | А А | Α   | Α .  | А А   | Α | Α | А А |
| Bit r | umber    |               | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 | 6 15 14 1 | .3 12 1 | 11 10 | 9 8 | 7   | 6    | 5 4   | 3 | 2 | 1 0 |

### 7.20.14.55 FRAMEDELAYMAX

Address offset: 0x508 Maximum frame delay

|        |         |               |     |       |      |      |    |      | -vcl |     |      |     |      |      |      |      |     |      |      |      |     |     |    |     |     |   |     |
|--------|---------|---------------|-----|-------|------|------|----|------|------|-----|------|-----|------|------|------|------|-----|------|------|------|-----|-----|----|-----|-----|---|-----|
| Α      | RW      | FRAMEDELAYMAX |     |       |      |      |    | -    | Max  | imi | um f | ram | ne d | elay | in   | nun  | nbe | r of | 13.5 | 66 N | 1Hz | clo | ck |     |     |   |     |
| ID     |         |               |     |       |      |      |    |      |      |     |      |     |      |      |      |      |     |      |      |      |     |     |    |     |     |   |     |
| Rese   | t 0x000 | 01000         | 0   | 0 0   | 0 (  | 0    | 0  | 0    | 0 (  | 0   | 0    | 0   | 0    | 0 (  | 0    | 0    | 0   | 1    | 0 0  | 0    | 0   | 0   | 0  | 0 ( | 0 0 | 0 | 0 0 |
| ID     |         |               |     |       |      |      |    |      |      |     |      | Α   | A    | Δ ,  | A A  | Α    | Α   | Α.   | A A  | A    | Α   | Α   | Α  | Α / | A A | Α | A A |
| Bit nu | umber   |               | 313 | 30 29 | 28 2 | 7 26 | 25 | 24 2 | 23 2 | 2 2 | 1 20 | 19  | 18 1 | .7 1 | 6 15 | 5 14 | 13  | 12 1 | 11 1 | 0 9  | 8   | 7   | 6  | 5 4 | 4 3 | 2 | 1 0 |

### 7.20.14.56 FRAMEDELAYMODE

Address offset: 0x50C

Configuration register for the Frame Delay Timer

| Bit n | umber   |                |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|------------|------------------------|-----------------------------------------------------------------|
| ID    |         |                |            |                        | A A                                                             |
| Rese  | t 0x000 | 00001          |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |            |                        |                                                                 |
| Α     | RW      | FRAMEDELAYMODE |            |                        | Configuration register for the Frame Delay Timer                |
|       |         |                | FreeRun    | 0                      | Transmission is independent of frame timer and will start       |
|       |         |                |            |                        | when the STARTTX task is triggered. No timeout.                 |
|       |         |                | Window     | 1                      | Frame is transmitted between FRAMEDELAYMIN and                  |
|       |         |                |            |                        | FRAMEDELAYMAX                                                   |
|       |         |                | ExactVal   | 2                      | Frame is transmitted exactly at FRAMEDELAYMAX                   |
|       |         |                | WindowGrid | 3                      | Frame is transmitted on a bit grid between                      |
|       |         |                |            |                        | FRAMEDELAYMIN and FRAMEDELAYMAX                                 |



#### 7.20.14.57 PACKETPTR

Address offset: 0x510

Packet pointer for TXD and RXD data storage in Data RAM



#### 7.20.14.58 MAXLEN

Address offset: 0x514

Size of the RAM buffer allocated to TXD and RXD data storage each



#### 7.20.14.59 TXD.FRAMECONFIG

Address offset: 0x518

Configuration of outgoing frames

| Bit n | umber    |             |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |          |             |              |                        | D CBA                                                           |
| Rese  | et 0x000 | 00017       |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |             |              |                        |                                                                 |
| Α     | RW       | PARITY      |              |                        | Indicates if parity is added to the frame                       |
|       |          |             | NoParity     | 0                      | Parity is not added to TX frames                                |
|       |          |             | Parity       | 1                      | Parity is added to TX frames                                    |
| В     | RW       | DISCARDMODE |              |                        | Discarding unused bits at start or end of a frame               |
|       |          |             | DiscardEnd   | 0                      | Unused bits are discarded at end of frame (EoF)                 |
|       |          |             | DiscardStart | 1                      | Unused bits are discarded at start of frame (SoF)               |
| С     | RW       | SOF         |              |                        | Adding SoF or not in TX frames                                  |
|       |          |             | NoSoF        | 0                      | SoF symbol not added                                            |
|       |          |             | SoF          | 1                      | SoF symbol added                                                |
| D     | RW       | CRCMODETX   |              |                        | CRC mode for outgoing frames                                    |
|       |          |             | NoCRCTX      | 0                      | CRC is not added to the frame                                   |
|       |          |             | CRC16TX      | 1                      | 16 bit CRC added to the frame based on all the data read        |
|       |          |             |              |                        | from RAM that is used in the frame                              |



## 7.20.14.60 TXD.AMOUNT

Address offset: 0x51C Size of outgoing frame

| Bit n | umber   |             | 31 30 | 29 28 | 8 27 : | 26 25 | 24 | 23 2               | 22 21         | . 20 1                  | 19 1                 | 8 17            | 16 1                | L5 14                | 113                    | 12 11                                    | . 10         | 9                  | 8 7          | 6                   | 5  | 4  | 3 2 | 1 | 0 |
|-------|---------|-------------|-------|-------|--------|-------|----|--------------------|---------------|-------------------------|----------------------|-----------------|---------------------|----------------------|------------------------|------------------------------------------|--------------|--------------------|--------------|---------------------|----|----|-----|---|---|
| ID    |         |             |       |       |        |       |    |                    |               |                         |                      |                 |                     |                      |                        | В                                        | В            | В                  | ВЕ           | В                   | В  | В  | 3 A | Α | Α |
| Rese  | t 0x000 | 00000       | 0 0   | 0 0   | 0      | 0 0   | 0  | 0 (                | 0 0           | 0                       | 0 0                  | 0               | 0                   | 0 0                  | 0                      | 0 0                                      | 0            | 0                  | 0 (          | 0                   | 0  | 0  | 0   | 0 | 0 |
| ID    |         |             |       |       |        |       |    | Des                |               |                         |                      |                 |                     |                      |                        |                                          |              |                    |              |                     |    |    |     |   |   |
| A     | RW      | TXDATABITS  | [07]  |       |        |       |    | shal<br>The<br>unu | II be<br>DISC | inclu<br>CARE<br>bits i | uded<br>DMC<br>is di | l in tl<br>DE f | ne f<br>ield<br>led | ram<br>in F<br>at th | e (ex<br>RAM<br>ie sta | byte<br>cludi<br>IECO<br>art oi<br>d 0 d | ng p<br>NFIC | arit<br>6.TX<br>he | y bi<br>sele | t).<br>ects<br>of a | if | at |     |   |   |
| В     | RW      | TXDATABYTES | [02   | 57]   |        |       |    |                    |               |                         |                      |                 | •                   |                      |                        | hall b                                   |              | clu                | ded          | in tl               | ne |    |     |   |   |

### 7.20.14.61 RXD.FRAMECONFIG

Address offset: 0x520

Configuration of incoming frames

| Bit r | number   |           |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------|---------------------------------------------------------------------|
| ID    |          |           |          |                   | C B A                                                               |
| Res   | et 0x000 | 00015     |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
|       |          |           |          |                   |                                                                     |
| Α     | RW       | PARITY    |          |                   | Indicates if parity expected in RX frame                            |
|       |          |           | NoParity | 0                 | Parity is not expected in RX frames                                 |
|       |          |           | Parity   | 1                 | Parity is expected in RX frames                                     |
| В     | RW       | SOF       |          |                   | SoF expected or not in RX frames                                    |
|       |          |           | NoSoF    | 0                 | SoF symbol is not expected in RX frames                             |
|       |          |           | SoF      | 1                 | SoF symbol is expected in RX frames                                 |
| С     | RW       | CRCMODERX |          |                   | CRC mode for incoming frames                                        |
|       |          |           | NoCRCRX  | 0                 | CRC is not expected in RX frames                                    |
|       |          |           | CRC16RX  | 1                 | Last 16 bits in RX frame is CRC, CRC is checked and                 |
|       |          |           |          |                   | CRCSTATUS updated                                                   |

### 7.20.14.62 RXD.AMOUNT

Address offset: 0x524

Size of last incoming frame





#### 7.20.14.63 MODULATIONCTRL

Address offset: 0x52C

Enables the modulation output to a GPIO pin which can be connected to a second external antenna.

See MODULATIONPSEL for GPIO configuration.



#### 7.20.14.64 MODULATIONPSEL

Address offset: 0x538

Pin select for Modulation control



### 7.20.14.65 NFCID1\_LAST

Address offset: 0x590

Last NFCID1 part (4, 7 or 10 bytes ID)





## 7.20.14.66 NFCID1\_2ND\_LAST

Address offset: 0x594

Second last NFCID1 part (7 or 10 bytes ID)

| Bit n | umber   |          | 31 30 29 | 28 27 2 | 26 25 24 | 4 23 22 | 21   | 20 1 | 9 18 | 17 1 | 6 15 | 14 1 | 3 12 | 11 1 | .0 9 | 8 | 7  | 6 5 | 4 | 3 | 2 1 | . 0 |
|-------|---------|----------|----------|---------|----------|---------|------|------|------|------|------|------|------|------|------|---|----|-----|---|---|-----|-----|
| ID    |         |          |          |         |          | СС      | С    | С (  | СС   | C (  | СВ   | ВЕ   | ВВ   | В    | ВВ   | В | Α. | ДД  | A | Α | ΑА  | A   |
| Rese  | t 0x000 | 00000    | 0 0 0    | 0 0 0   | 0 0 0    | 0 0     | 0    | 0 (  | 0 0  | 0 (  | 0 0  | 0 0  | 0    | 0    | 0 0  | 0 | 0  | 0 0 | 0 | 0 | 0 0 | 0   |
| ID    |         |          |          |         |          |         |      |      |      |      |      |      |      |      |      |   |    |     |   |   |     |     |
| Α     | RW      | NFCID1_V |          |         |          | NFCII   | D1 b | yte  | V    |      |      |      |      |      |      |   |    |     |   |   |     |     |
| В     | RW      | NFCID1_U |          |         |          | NFCII   | D1 b | yte  | U    |      |      |      |      |      |      |   |    |     |   |   |     |     |
| С     | RW      | NFCID1_T |          |         |          | NFCII   | D1 b | yte  | Т    |      |      |      |      |      |      |   |    |     |   |   |     |     |

### 7.20.14.67 NFCID1\_3RD\_LAST

Address offset: 0x598

Third last NFCID1 part (10 bytes ID)



#### 7.20.14.68 AUTOCOLRESCONFIG

Address offset: 0x59C

Controls the auto collision resolution function. This setting must be done before the NFCT peripheral is activated.

**Note:** When modifying this register, bit 1 must be written to 1.





## 7.20.14.69 SENSRES

Address offset: 0x5A0

NFC-A SENS\_RES auto-response settings

| Bit r | umber    |             |              | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |                                                            |  |  |  |  |  |  |  |  |  |
|-------|----------|-------------|--------------|-------------------------------------------------------------------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| ID    |          |             |              |                                                                                     | E E E D D D D C C B A A A A                                |  |  |  |  |  |  |  |  |  |
| Rese  | et 0x000 | 000001      |              | 0 0 0 0 0 0 0                                                                       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                    |  |  |  |  |  |  |  |  |  |
| ID    |          |             |              |                                                                                     | Description                                                |  |  |  |  |  |  |  |  |  |
| Α     | RW       | BITFRAMESDD |              |                                                                                     | Bit frame SDD as defined by the b5:b1 of byte 1 in         |  |  |  |  |  |  |  |  |  |
|       |          |             |              |                                                                                     | SENS_RES response in the NFC Forum, NFC Digital Protocol   |  |  |  |  |  |  |  |  |  |
|       |          |             |              |                                                                                     | Technical Specification                                    |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD00000     | 0                                                                                   | SDD pattern 00000                                          |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD00001     | 1                                                                                   | SDD pattern 00001                                          |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD00010     | 2                                                                                   | SDD pattern 00010                                          |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD00100     | 4                                                                                   | SDD pattern 00100                                          |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD01000     | 8                                                                                   | SDD pattern 01000                                          |  |  |  |  |  |  |  |  |  |
|       |          |             | SDD10000     | 16                                                                                  | SDD pattern 10000                                          |  |  |  |  |  |  |  |  |  |
| В     | RW       | RFU5        |              |                                                                                     | Reserved for future use. Shall be 0.                       |  |  |  |  |  |  |  |  |  |
| С     | RW       | NFCIDSIZE   |              |                                                                                     | NFCID1 size. This value is used by the auto collision      |  |  |  |  |  |  |  |  |  |
|       |          |             |              |                                                                                     | resolution engine.                                         |  |  |  |  |  |  |  |  |  |
|       |          |             | NFCID1Single | 0                                                                                   | NFCID1 size: single (4 bytes)                              |  |  |  |  |  |  |  |  |  |
|       |          |             | NFCID1Double | 1                                                                                   | NFCID1 size: double (7 bytes)                              |  |  |  |  |  |  |  |  |  |
|       |          |             | NFCID1Triple | 2                                                                                   | NFCID1 size: triple (10 bytes)                             |  |  |  |  |  |  |  |  |  |
| D     | RW       | PLATFCONFIG |              |                                                                                     | Tag platform configuration as defined by the b4:b1 of byte |  |  |  |  |  |  |  |  |  |
|       |          |             |              |                                                                                     | 2 in SENS_RES response in the NFC Forum, NFC Digital       |  |  |  |  |  |  |  |  |  |
|       |          |             |              |                                                                                     | Protocol Technical Specification                           |  |  |  |  |  |  |  |  |  |
| Ε     | RW       | RFU74       |              |                                                                                     | Reserved for future use. Shall be 0.                       |  |  |  |  |  |  |  |  |  |

## 7.20.14.70 SELRES

Address offset: 0x5A4

NFC-A SEL\_RES auto-response settings

| Bit n | umber   |          | 313 | 30 29 | 28 2 | 27 26 | 25 2 | 4 23 | 22 2  | 1 20  | 19   | 18 17 | 16    | 15 1 | L4 13  | 12   | 11 1  | .0 9  | 8 7   | 7 6   | 5     | 4  | 3   | 2 1 | . 0 |
|-------|---------|----------|-----|-------|------|-------|------|------|-------|-------|------|-------|-------|------|--------|------|-------|-------|-------|-------|-------|----|-----|-----|-----|
| ID    |         |          |     |       |      |       |      |      |       |       |      |       |       |      |        |      |       |       | E     | D     | D     | С  | C I | ВА  | A   |
| Rese  | t 0x000 | 00000    | 0   | 0 0   | 0    | 0 0   | 0 0  | 0    | 0 (   | 0 0   | 0    | 0 0   | 0     | 0    | 0 0    | 0    | 0 (   | 0 0   | 0 (   | 0     | 0     | 0  | 0 ( | 0 0 | 0   |
| ID    |         |          |     |       |      |       |      |      |       |       |      |       |       |      |        |      |       |       |       |       |       |    |     |     |     |
| Α     | RW      | RFU10    |     |       |      |       |      | Re   | serv  | ed fo | r fu | ture  | use.  | Sha  | all be | 0.   |       |       |       |       |       |    |     |     |     |
| В     | RW      | CASCADE  |     |       |      |       |      | Ca   | scad  | e as  | defi | ned   | by tl | ne b | 3 of   | SEL  | _RES  | resp  | ons   | e in  | the   |    |     |     |     |
|       |         |          |     |       |      |       |      | NF   | C Fo  | rum,  | , NF | C Dig | ital  | Prot | tocol  | Tec  | hnic  | al Sp | ecifi | cati  | on    |    |     |     |     |
|       |         |          |     |       |      |       |      | (cc  | ontro | lled  | by ł | ardv  | vare  | , sh | all b  | e 0) |       |       |       |       |       |    |     |     |     |
| С     | RW      | RFU43    |     |       |      |       |      | Re   | serv  | ed fo | r fu | ture  | use.  | Sha  | all be | 0.   |       |       |       |       |       |    |     |     |     |
| D     | RW      | PROTOCOL |     |       |      |       |      | Pro  | otoc  | ol as | def  | ned   | by t  | he b | 7:b6   | of   | SEL_  | RES   | esp   | onse  | e in  |    |     |     |     |
|       |         |          |     |       |      |       |      | the  | e NF  | C For | rum  | NFC   | Dig   | ital | Prot   | осо  | l Tec | hnica | l Sp  | ecifi | icati | on |     |     |     |
| Е     | RW      | RFU7     |     |       |      |       |      | Re   | serv  | ed fo | r fu | ture  | use.  | Sha  | all be | 0.   |       |       |       |       |       |    |     |     |     |



## 7.20.15 Electrical specification

### 7.20.15.1 NFCT Electrical Specification

| Symbol             | Description                                                  | Min. | Тур.  | Max. | Units |
|--------------------|--------------------------------------------------------------|------|-------|------|-------|
| f <sub>c</sub>     | Frequency of operation                                       |      | 13.56 |      | MHz   |
| C <sub>MI</sub>    | Carrier modulation index                                     | 95   |       |      | %     |
| DR                 | Data Rate                                                    |      | 106   |      | kbps  |
| V <sub>sense</sub> | Peak differential field detect threshold level on NFC1-NFC2, |      | 1.2   |      | Vp    |
|                    | with input being high impedance in sense mode                |      |       |      |       |
| I <sub>max</sub>   | Maximum input current on NFCT pins                           |      |       | 80   | mA    |

### 7.20.15.2 NFCT Timing Parameters

| Symbol                | Description                                            | Min. | Тур. | Max. | Units |
|-----------------------|--------------------------------------------------------|------|------|------|-------|
| t <sub>activate</sub> | Time from task_ACTIVATE in SENSE or DISABLE state to   |      |      | 500  | μs    |
|                       | ACTIVATE_A or IDLE state, excluding voltage supply and |      |      |      |       |
|                       | oscillator startup times                               |      |      |      |       |
| t <sub>sense</sub>    | Time from remote field is present in SENSE mode to     |      |      | 20   | μs    |
|                       | FIELDDETECTED event is asserted                        |      |      |      |       |



Figure 99: NFCT timing parameters (Shortcuts for FIELDDETECTED and FIELDLOST are disabled)

# 7.21 NVMC — Non-volatile memory controller

The non-volatile memory controller (NVMC) is used for writing and erasing of the internal flash memory and the user information configuration register (UICR).

The NVMC is a split security peripheral. This means that when the NVMC is configured as non-secure, only a subset of the registers is available from the non-secure code. See SPU — System protection unit on page 590 and Registers on page 337 for more details.

When the NVMC is configured to be a secure peripheral, only secure code has access.

Before a write can be performed, the NVMC must be enabled for writing in CONFIG.WEN. Similarly, before an erase can be performed, the NVMC must be enabled for erasing in CONFIG.EEN, see CONFIG on page 338. The user must make sure that writing and erasing are not enabled at the same time. Failing to do so may result in unpredictable behavior.

# 7.21.1 Writing to flash

When writing is enabled, in CONFIG register for secure region, or in CONFIGNS register for non-secure region, flash is written by writing a full 32-bit word to a word-aligned address in flash.



Secure code has access to both secure and non-secure regions, by using the appropriate configuration of CONFIG and CONFIGNS registers. Non-secure code, in constrast, has access to non-secure regions only. Thus, non-secure code only needs CONFIGNS.

The NVMC is only able to write 0 to erased bits in flash, that is bits set to 1. It cannot write a bit back to 1.

As illustrated in Memory on page 19, flash is divided into multiple pages. The same address in flash can only be written nwRITE number of times before a page erase must be performed.

Only full 32-bit words can be written to flash using the NVMC interface. To write less than 32 bits to flash, write the data as a word, and set all the bits that should remain unchanged in the word to 1. The restriction about the number of writes (see above) still applies in this case.

The time it takes to write a word to flash is specified by  $t_{WRITE}$ . If CPU executes code from flash while the NVMC is writing to flash, the CPU will be stalled.

Only word-aligned writes are allowed. Byte or half-word-aligned writes will result in a bus fault.

## 7.21.2 Erasing a secure page in flash

When secure region erase is enabled (in CONFIG register), a flash page can be erased by writing <code>0xFFFFFFF</code> into the first 32-bit word in a flash page.

Page erase is only applicable to the code area in the flash and does not work with UICR.

After erasing a flash page, all bits in the page are set to 1. The time it takes to erase a page is specified by  $t_{\text{ERASEPAGE}}$ . The CPU is stalled if the CPU executes code from the flash while the NVMC performs the erase operation.

See Partial erase of a page in flash for information on splitting the erase time in smaller chunks.

## 7.21.3 Erasing a non-secure page in flash

Page erase is only applicable to the code area in the flash and does not work with UICR.

After erasing a flash page, all bits in the page are set to 1. The time it takes to erase a page is specified by  $t_{\sf ERASEPAGE}$ . The CPU is stalled if the CPU executes code from the flash while the NVMC performs the erase operation.

# 7.21.4 Writing to user information configuration registers (UICR)

User information configuration registers (UICR) are written in the same way as flash. After UICR has been written, the new UICR configuration will only take effect after a reset.

UICR is only accessible by secure code. Any write from non-secure code will be faulted.

To lock the chip after uploading non-secure code, do the follolwing steps:

- 1. Block access to secure code by setting UICR register to protected.
- 2. Use the register WRITEUICRNS on page 340, via non-secure debugger, to set APPROTECT (APPROTECT is automatically written to  $0 \times 000000000$  by the NVMC).

UICR can only be written nwRITE number of times before an erase must be performed using ERASEALL.

The time it takes to write a word to the UICR is specified by  $t_{WRITE}$ . The CPU is stalled if the CPU executes code from the flash while the NVMC is writing to the UICR.

#### 7.21.5 Frase all

When erase is enabled, the whole flash and UICR can be erased in one operation by using the ERASEALL register. ERASEALL will not erase the factory information configuration registers (FICR).



This functionality can be blocked by some configuration of the UICR protection bits, see the table NVMC protection on page 336.

The time it takes to perform an ERASEALL on page 338 command is specified by t<sub>ERASEALL</sub>. The CPU is stalled if the CPU executes code from the flash while the NVMC performs the erase operation.

### 7.21.6 NVMC protection mechanisms

This chapter describes the different protection mechanisms for the non-volatile memory.

### 7.21.6.1 NVMC blocking

NVM integrity is assured through use of multiple levels of protection. Protection mechanisms can be configured to allow or block certain operations.

The table below shows the different status of protection bits, and which operations are allowed or blocked.

| Pı                                        | rotection bit sta | ntus             | NVMC protection  |               |  |  |  |  |  |  |  |
|-------------------------------------------|-------------------|------------------|------------------|---------------|--|--|--|--|--|--|--|
| SECURE<br>APPROTECT                       | APPROTECT         | ERASE<br>PROTECT | CTRL-AP ERASEALL | NVMC ERASEALL |  |  |  |  |  |  |  |
| 0                                         | 0                 | 0                | Available        | Available     |  |  |  |  |  |  |  |
| 1                                         | Χ                 | 0                | Available        | Blocked       |  |  |  |  |  |  |  |
| X                                         | 1                 | 0                | Available        | Blocked       |  |  |  |  |  |  |  |
| X                                         | X                 | 1                | Blocked          | Blocked       |  |  |  |  |  |  |  |
| 1 - Enabled, 0 - Disabled, X - Don't care |                   |                  |                  |               |  |  |  |  |  |  |  |

Table 102: NVMC protection

#### Uploading code with secure debugging blocked

Non-secure code can program non-secure flash regions. To perform these operations, the NVMC has the following non-secure registers: CONFIGNS, READY, and READYNEXT.

CONFIGNS on page 340 works as the CONFIG register but it is used only for non-secure transactions. Both page erase and writing inside the flash require a write transaction (see Erasing a secure page in flash on page 335 or Erasing a non-secure page in flash on page 335). Because of this, the SPU — System protection unit on page 590 will guarantee that the non-secure code cannot write inside a secure page, since the transaction will never reach the NVMC controller.

#### 7.21.6.2 NVMC power failure protection

NVMC power failure protection is possible through the use of a power-fail comparator that is monitoring power supply.

If the power-fail comparator is enabled, and the power supply voltage is below  $V_{POF}$  threshold, the power-fail comparator will prevent the NVMC from performing erase or write operations in non-volatile memory (NVM).

If a power failure warning is present at the start of an NVM write or erase operation, the NVMC will block the operation and a bus error will be signalled. If a power failure warning occurs during an ongoing NVM write operation, the NVMC will try to finish the operation. And if the power failure warning persists, consecutive NVM write operations will be blocked by the NVMC, and a bus error will be signalled.



## 7.21.7 Cache

An instruction cache (I-Cache) can be enabled for the ICODE bus in the NVMC.

See Memory on page 19 for the location of flash.

A cache hit is an instruction fetch from the cache, and it has a 0 wait-state delay. The number of wait-states for a cache miss, where the instruction is not available in the cache and needs to be fetched from flash, depends on the processor frequency, see CPU parameter W\_FLASHCACHE.

Enabling the cache can increase the CPU performance, and reduce power consumption by reducing the number of wait cycles and the number of flash accesses. This will depend on the cache hit rate. Cache draws current when enabled. If the reduction in average current due to reduced flash accesses is larger than the cache power requirement, the average current to execute the program code will be reduced.

When disabled, the cache does not draw current and its content is not retained.

It is possible to enable cache profiling to analyze the performance of the cache for your program using the register ICACHECNF. When profiling is enabled, registers IHIT and IMISS are incremented for every instruction cache hit or miss respectively.

### 7.21.8 Registers

| Base address Domain                  | Peripheral | Instance              | Secure mapping | DMA security | Description                       | Configuration                                                                  |
|--------------------------------------|------------|-----------------------|----------------|--------------|-----------------------------------|--------------------------------------------------------------------------------|
| 0x50039000<br>0x40039000<br>APPLICAT | ION NVMC   | NVMC : S<br>NVMC : NS | SPLIT          | NA           | Non-volatile memory controller    | NVMC built-in cache not<br>supported (ICACHECNF,<br>IHIT and IMISS registers). |
| 0x41080000 NETWOR                    | K NVMC     | NVMC                  | NS             | NA           | Non-Volatile Memory<br>Controller | NVMC TrustZone registers (WRITEUICRNS and CONFIGNS) not supported.             |

Table 103: Instances

| Register            | Offset | Security | Description                                       |
|---------------------|--------|----------|---------------------------------------------------|
| READY               | 0x400  | NS       | Ready flag                                        |
| READYNEXT           | 0x408  | NS       | Ready flag                                        |
| CONFIG              | 0x504  | S        | Configuration register                            |
| ERASEALL            | 0x50C  | S        | Register for erasing all non-volatile user memory |
| ERASEPAGEPARTIALCFG | 0x51C  | S        | Register for partial erase configuration          |
| ICACHECNF           | 0x540  | S        | I-code cache configuration register               |
| IHIT                | 0x548  | S        | I-code cache hit counter                          |
| IMISS               | 0x54C  | S        | I-code cache miss counter                         |
| CONFIGNS            | 0x584  | NS       | Non-secure configuration register                 |
| WRITEUICRNS         | 0x588  | NS       | Non-secure APPROTECT enable register              |

Table 104: Register overview

#### 7.21.8.1 READY

Address offset: 0x400

Ready flag





#### **7.21.8.2 READYNEXT**

Address offset: 0x408

Ready flag

| Bit n | umber   |           |       | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|-------|----------------|------------------------------------------------------------------------|
| ID    |         |           |       |                | А                                                                      |
| Rese  | t 0x000 | 000001    |       | 0 0 0 0 0      | $\begin{smallmatrix} 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 $           |
| ID    |         |           |       |                | Description                                                            |
| Α     | R       | READYNEXT |       |                | NVMC can accept a new write operation                                  |
|       |         |           | Busy  | 0              | NVMC cannot accept any write operation                                 |
|       |         |           | Ready | 1              | NVMC is ready                                                          |

#### 7.21.8.3 CONFIG

Address offset: 0x504 Configuration register



#### 7.21.8.4 ERASEALL

Address offset: 0x50C

Register for erasing all non-volatile user memory





#### 7.21.8.5 ERASEPAGEPARTIALCFG

Address offset: 0x51C

Register for partial erase configuration



#### **7.21.8.6 ICACHECNF**

Address offset: 0x540

I-code cache configuration register



#### 7.21.8.7 IHIT

Address offset: 0x548

I-code cache hit counter

| Bit number            | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|---------------------------------------------------------------------------------------|
| ID                    | A A A A A A A A A A A A A A A A A A A                                                 |
| Reset 0x00000000      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| ID R/W Field Value ID | Value Description                                                                     |
| A RW HITS             | Number of cache hits                                                                  |

Write zero to clear



#### 7.21.8.8 IMISS

Address offset: 0x54C

I-code cache miss counter



Write zero to clear

### 7.21.8.9 CONFIGNS

Address offset: 0x584

Non-secure configuration register



#### **7.21.8.10 WRITEUICRNS**

Address offset: 0x588

Non-secure APPROTECT enable register

| Bit n | umber   |       |          | 31 | 30  | 29   | 28 | 27 2 | 6 25 | 24 | 23  | 22 2 | 21 2 | 0 1  | 9 18 | 17  | 16   | 15   | 14 1 | .3 1 | 2 1: | 1 10 | 9  | 8   | 7    | 6 | 5 4 | 4 3 | 2 | 1 0 |
|-------|---------|-------|----------|----|-----|------|----|------|------|----|-----|------|------|------|------|-----|------|------|------|------|------|------|----|-----|------|---|-----|-----|---|-----|
| ID    |         |       |          | В  | В   | В    | В  | В    | ВВ   | В  | В   | В    | В    | ВЕ   | 3 B  | В   | В    | В    | В    | ВЕ   | 3 B  | В    | В  | В   | В    | В | В   | 3   |   | А   |
| Rese  | t 0x000 | 00000 |          | 0  | 0   | 0    | 0  | 0 (  | 0 0  | 0  | 0   | 0    | 0 (  | 0 0  | 0    | 0   | 0    | 0    | 0    | 0 (  | 0    | 0    | 0  | 0   | 0    | 0 | 0 ( | 0   | 0 | 0 0 |
| ID    |         |       |          |    |     |      |    |      |      |    |     |      |      |      |      |     |      |      |      |      |      |      |    |     |      |   |     |     |   |     |
| Α     | W       | SET   |          |    |     |      |    |      |      |    | All | wc   | non  | -se  | cure | co  | de t | :O S | et A | PPI  | ROT  | ECT  | •  |     |      |   |     |     |   |     |
|       |         |       | Set      | 1  |     |      |    |      |      |    | Set | val  | lue  |      |      |     |      |      |      |      |      |      |    |     |      |   |     |     |   |     |
| В     | W       | KEY   |          |    |     |      |    |      |      |    | Key | / to | wri  | te i | n or | der | to   | vali | dat  | e th | e w  | rite | ор | era | tior | 1 |     |     |   |     |
|       |         |       | Keyvalid | 0x | AFE | 3E5/ | 47 |      |      |    | Key | / va | lue  |      |      |     |      |      |      |      |      |      |    |     |      |   |     |     |   |     |





## 7.21.9 Electrical specification

### 7.21.9.1 Flash programming

| Symbol                         | Description                                               | М  | in.  | Тур. | Max.              | Units |
|--------------------------------|-----------------------------------------------------------|----|------|------|-------------------|-------|
| n <sub>WRITE</sub>             | Number of times a 32-bit word can be written before erase |    |      |      | 2                 |       |
| n <sub>endurance</sub>         | Erase cycles per page                                     | 10 | 0000 |      |                   |       |
| t <sub>WRITE</sub>             | Time to write one 32-bit word                             |    |      |      | 43 <sup>9</sup>   | μs    |
| t <sub>ERASEPAGE</sub>         | Time to erase one page                                    |    |      |      | 87.5 <sup>9</sup> | ms    |
| t <sub>ERASEALL</sub>          | Time to erase all flash                                   |    |      |      | 173 <sup>9</sup>  | ms    |
| t <sub>ERASEPAGEPARTIAL,</sub> | setu <sub>l</sub> Setup time for one partial erase        |    |      |      |                   | ms    |

#### 7.21.9.2 Cache size

| Symbol                | Description       | Min. | Тур.               | Max. | Units |
|-----------------------|-------------------|------|--------------------|------|-------|
| Size <sub>ICODE</sub> | I-Code cache size |      | 2048 <sup>10</sup> |      | Bytes |

# 7.22 PDM — Pulse density modulation interface

The pulse density modulation (PDM) module enables input of pulse density modulated signals from external audio frontends, for example, digital microphones. The PDM module generates the PDM clock and supports single-channel or dual-channel (left and right) data input. Data is transferred directly to RAM buffers using EasyDMA.

Listed here are the main features for PDM:

- Up to two PDM microphones configured as a left/right pair using the same data input
- 16 kHz output sample rate, 16-bit samples
- EasyDMA support for sample buffering
- HW decimation filters
- Selectable ratio of 64 or 80 between PDM\_CLK and output sample rate

The PDM module illustrated below is interfacing up to two digital microphones with the PDM interface. EasyDMA is implemented to relieve the real-time requirements associated with controlling of the PDM slave from a low priority CPU execution context. It also includes all the necessary digital filter elements to produce pulse code modulation (PCM) samples. The PDM module allows continuous audio streaming.



<sup>&</sup>lt;sup>9</sup> Applies when HFXO is used. Timing varies according to HFINT accuracy when HFINT is used.

Only applicable for network core. Application core has a separate cache, see CACHE — Instruction/data cache on page 113.



Figure 100: PDM module

### 7.22.1 Master clock source selection

The master clock source can be configured in register MCLKCONFIG on page 354. Choose one of the following as the master clock source:

- 32 MHz peripheral clock (PCLK32M), synchronous to HFCLK.
- Audio PLL clock (ACLK) with configurable frequency.

The peripheral must be stopped before selecting the master clock source. The use of the STOP task and the STOPPED event is described in Module operation on page 343.

To improve the master clock accuracy and jitter performance, it is recommended (but not mandatory) that the PCLK32M source is running off the HFXO instead of the HFINT oscillator. The ACLK source requires the use of HFXO. See CLOCK — Clock control on page 73 for more information about starting HFXO for the relevant clock source.

## 7.22.2 Master clock generator

The master clock generator's PDMCLKCTRL register allows adjusting the PDM clock's frequency.

The master clock generator does not add any jitter to the HFCLK source chosen. It is recommended (but not mandatory) to use the Xtal as HFCLK source.

The following equation can be used to calculate the value of the PDMCLKCTRL register for a given PDM clock- and master clock source frequency:

$$PDMCLKCTRL = 4096 \cdot \left[ \frac{f_{pdm} \cdot 1048576}{f_{source} + \frac{f_{pdm}}{2}} \right]$$

Figure 101: PDM clock frequency equation

Where  $f_{pdm}$  is the requested PDM clock frequency in Hz, and  $f_{source}$  is the master clock generator source in Hz. Because of rounding errors, an accurate PDM clock may not be achievable. The actual PDM frequency can be calculated using the equation below.

$$f_{actual} = \frac{f_{source}}{\left\lfloor \frac{1048576 \cdot 4096}{PDMCLKCTRL} \right\rfloor}$$

Figure 102: Actual PDM frequency

The clock error can be calculated using the equation below. The error e is the percentage difference from the requested  $f_{pdm}$  frequency.



$$e = 100 \cdot \frac{f_{actual} - f_{pdm}}{f_{pdm}} = 100 \cdot \frac{\frac{f_{source}}{1048576 \cdot 4096}}{f_{pdm}} - f_{pdm}$$

Figure 103: PDM frequency error equation

The PDM frequency can be adjusted while the clock generator is running.

- For PCLK32M, by using PDMCLKCTRL
- For ACLK, by adjusting the audio clock source, see CLOCK Clock control on page 73.

| Requested<br>PDM<br>frequency<br>f <sub>pdm</sub> [Hz] | f <sub>source</sub> [Hz] | RATIO | PDMCLKCTRL | Actual PDM<br>frequency<br>f <sub>actual</sub> [Hz] | Sample<br>frequency<br>[Hz] | Error [%] |
|--------------------------------------------------------|--------------------------|-------|------------|-----------------------------------------------------|-----------------------------|-----------|
| 1024000                                                | 32000000<br>(PCLK32M)    | 64    | 135274496  | 1032258.1                                           | 16129.0                     | 0.81      |
| 1280000                                                | 32000000<br>(PCLK32M)    | 80    | 168427520  | 1280000                                             | 16000                       | 0         |
| 1024000                                                | 12288000<br>(ACLK)       | 64    | 343597056  | 1024000                                             | 16000                       | 0         |

Table 105: Configuration examples

### 7.22.3 Module operation

By default, bits from the left PDM microphone are sampled on PDM\_CLK falling edge, and bits for the right are sampled on the rising edge of PDM\_CLK, resulting in two bitstreams. Each bitstream is fed into a digital filter which converts the PDM stream into 16-bit PCM samples, then filters and down-samples them to reach the appropriate sample rate.

The EDGE field in the MODE register allows swapping left and right, so that left will be sampled on rising edge, and right on falling.

The PDM module uses EasyDMA to store the samples coming out from the filters into one buffer in RAM. Depending on the mode chosen in the OPERATION field in the MODE register, memory either contains alternating left and right 16-bit samples (Stereo), or only left 16-bit samples (Mono). To ensure continuous PDM sampling, it is up to the application to update the EasyDMA destination address pointer as the previous buffer is filled.

The continuous transfer can be started or stopped by sending the START and STOP tasks. STOP becomes effective after the current frame has finished transferring, which will generate the STOPPED event. The STOPPED event indicates that all activity in the module is finished, and that the data is available in RAM (EasyDMA has finished transferring as well). Attempting to restart before receiving the STOPPED event may result in unpredictable behavior.

#### 7.22.4 Decimation filter

In order to convert the incoming data stream into PCM audio samples, a decimation filter is included in the PDM interface module.

The input of the filter is the two-channel PDM serial stream (with left channel on clock high, right channel on clock low). Depending on the RATIO selected, its output is  $2 \times 16$ -bit PCM samples at a sample rate either 64 times or 80 times (depending on the RATIO register) lower than the PDM clock rate.



The filter stage of each channel is followed by a digital volume control, to attenuate or amplify the output samples in a range of -20 dB to +20 dB around the default (reset) setting, defined by  $G_{PDM,default}$ . The gain is controlled by the GAINL and GAINR registers.

As an example, if the goal is to achieve 2500 RMS output samples (16-bit) with a 1 kHz 90 dBA signal into a -26 dBFS sensitivity PDM microphone, do the following:

- Sum the PDM module's default gain (G<sub>PDM,default</sub>) and the gain introduced by the microphone and acoustic path of his implementation (an attenuation would translate into a negative gain)
- Adjust GAINL and GAINR by the above summed amount. Assuming that only the PDM module influences the gain, GAINL and GAINR must be set to -G<sub>PDM,default</sub> dB to achieve the requirement.

With  $G_{PDM,default}$  = 3.2 dB, and as GAINL and GAINR are expressed in 0.5 dB steps, the closest value to program would be 3.0 dB, which can be calculated as:

```
GAINL = GAINR = (DefaultGain - (2 * 3))
```

Remember to check that the resulting values programmed into GAINL and GAINR fall within MinGain and MaxGain.

# 7.22.5 EasyDMA

Samples will be written directly to RAM, and EasyDMA must be configured accordingly.

The address pointer for the EasyDMA channel is set in SAMPLE.PTR register. If the destination address set in SAMPLE.PTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

The DMA transfer supports Stereo (left and right 16-bit samples) and Mono (left only) data transfer as configured in the OPERATION field of the MODE register. The samples are stored little endian.

| MODE.OPERATION | Bits per sample | Result stored per RAM | Physical RAM allocated | Result boundary indexes Note  |  |
|----------------|-----------------|-----------------------|------------------------|-------------------------------|--|
|                |                 | word                  | (32-bit words)         | in RAM                        |  |
| Stereo         | 32 (2x16)       | L+R                   | ceil(SAMPLE.MAXCNT/2)  | R0=[31:16]; L0=[15:0] Default |  |
| Mono           | 16              | 2xL                   | ceil(SAMPLE.MAXCNT/2)  | L1=[31:16]; L0=[15:0]         |  |

Table 106: DMA sample storage

The destination buffer in RAM consists of one block, the size of which is set in SAMPLE.MAXCNT register. Format is number of 16-bit samples. The physical RAM allocated is always:

```
(RAM allocation, in bytes) = SAMPLE.MAXCNT * 2;
```

(but the mapping of the samples depends on MODE.OPERATION.

If OPERATION=Stereo, RAM will contain a succession of left and right samples.

If OPERATION=Mono, RAM will contain a succession of left only samples.

For a given value of SAMPLE.MAXCNT, the buffer in RAM can contain half the stereo sampling time as compared to the mono sampling time.

The PDM acquisition can be started by the START task, after the SAMPLE.PTR and SAMPLE.MAXCNT registers have been written. When starting the module, it will take some time for the filters to start outputting valid data. Transients from the PDM microphone itself may also occur. The first few samples (typically around 50) might hence contain invalid values or transients. It is therefore advised to discard the first few samples after a PDM start.

As soon as the STARTED event is received, the firmware can write the next SAMPLE.PTR value (this register is double-buffered), to ensure continuous operation.



When the buffer in RAM is filled with samples, an END event is triggered. The firmware can start processing the data in the buffer. Meanwhile, the PDM module starts acquiring data into the new buffer pointed to by SAMPLE.PTR, and sends a new STARTED event, so that the firmware can update SAMPLE.PTR to the next buffer address.

### 7.22.6 Hardware example

PDM can be configured with a single microphone (mono), or with two microphones.

When a single microphone is used, connect the microphone clock to CLK, and data to DIN.



Figure 104: Example of a single PDM microphone, wired as left



Figure 105: Example of a single PDM microphone, wired as right

Note that in a single microphone (mono) configuration, depending on the microphone's implementation, either the left or the right channel (sampled at falling or rising CLK edge respectively) will contain reliable data.

If two microphones are used, one of them has to be set as left, the other as right (L/R pin tied high or to GND on the respective microphone). It is strongly recommended to use two microphones of exactly the same brand and type so that their timings in left and right operation match.



Figure 106: Example of two PDM microphones

# 7.22.7 Pin configuration

The CLK and DIN signals associated to the PDM module are mapped to physical pins according to the configuration specified in the PSEL.CLK and PSEL.DIN registers respectively. If the CONNECT field in any PSEL register is set to Disconnected, the associated PDM module signal will not be connected to the required physical pins, and will not operate properly.

The PSEL.CLK and PSEL.DIN registers and their configurations are only used as long as the PDM module is enabled, and retained only as long as the device is in System ON mode. See POWER — Power control on page 46 for more information about power modes. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register.

To ensure correct behavior in the PDM module, the pins used by the PDM module must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 346

NORDIC SEMICONDUCTOR

before enabling the PDM module. This is to ensure that the pins used by the PDM module are driven correctly if the PDM module itself is temporarily disabled or the device temporarily enters System OFF. This configuration must be retained in the GPIO for the selected I/Os as long as the PDM module is supposed to be connected to an external PDM circuit.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| PDM signal | PDM pin                  | Direction | Output value   | Comment |
|------------|--------------------------|-----------|----------------|---------|
| CLK        | As specified in PSEL.CLK | Output    | 0              |         |
| DIN        | As specified in PSEL.DIN | Input     | Not applicable |         |

Table 107: GPIO configuration before enabling peripheral

# 7.22.8 Registers

| Base address Domain | Peripheral | Instance  | Secure mapping | DMA security | Description              | Configuration |
|---------------------|------------|-----------|----------------|--------------|--------------------------|---------------|
| 0                   |            | DDMO - C  |                |              | Pulse density modulation |               |
|                     | TION PDM   | PDM0 : S  | US             | SA           | (digital microphone)     |               |
| 0x40026000          |            | PDM0 : NS |                |              | interface                |               |

Table 108: Instances

| Register        | Offset | Security | Description                                                                 |
|-----------------|--------|----------|-----------------------------------------------------------------------------|
| TASKS_START     | 0x000  |          | Starts continuous PDM transfer                                              |
| TASKS_STOP      | 0x004  |          | Stops PDM transfer                                                          |
| SUBSCRIBE_START | 0x080  |          | Subscribe configuration for task START                                      |
| SUBSCRIBE_STOP  | 0x084  |          | Subscribe configuration for task STOP                                       |
| EVENTS_STARTED  | 0x100  |          | PDM transfer has started                                                    |
| EVENTS_STOPPED  | 0x104  |          | PDM transfer has finished                                                   |
| EVENTS_END      | 0x108  |          | The PDM has written the last sample specified by SAMPLE.MAXCNT (or the last |
|                 |        |          | sample after a STOP task has been received) to Data RAM                     |
| PUBLISH_STARTED | 0x180  |          | Publish configuration for event STARTED                                     |
| PUBLISH_STOPPED | 0x184  |          | Publish configuration for event STOPPED                                     |
| PUBLISH_END     | 0x188  |          | Publish configuration for event END                                         |
| INTEN           | 0x300  |          | Enable or disable interrupt                                                 |
| INTENSET        | 0x304  |          | Enable interrupt                                                            |
| INTENCLR        | 0x308  |          | Disable interrupt                                                           |
| ENABLE          | 0x500  |          | PDM module enable register                                                  |
| PDMCLKCTRL      | 0x504  |          | PDM clock generator control                                                 |
| MODE            | 0x508  |          | Defines the routing of the connected PDM microphones' signals               |
| GAINL           | 0x518  |          | Left output gain adjustment                                                 |
| GAINR           | 0x51C  |          | Right output gain adjustment                                                |
| RATIO           | 0x520  |          | Selects the ratio between PDM_CLK and output sample rate. Change PDMCLKCTRL |
|                 |        |          | accordingly.                                                                |
| PSEL.CLK        | 0x540  |          | Pin number configuration for PDM CLK signal                                 |
| PSEL.DIN        | 0x544  |          | Pin number configuration for PDM DIN signal                                 |
| MCLKCONFIG      | 0x54C  |          | Master clock generator configuration                                        |
| SAMPLE.PTR      | 0x560  |          | RAM address pointer to write samples to with EasyDMA                        |
| SAMPLE.MAXCNT   | 0x564  |          | Number of samples to allocate memory for in EasyDMA mode                    |
|                 |        |          |                                                                             |

Table 109: Register overview



# 7.22.8.1 TASKS\_START

Address offset: 0x000

Starts continuous PDM transfer



### 7.22.8.2 TASKS\_STOP

Address offset: 0x004 Stops PDM transfer

| Bit n | umber    |            |         | 31 30 29 28 27 20 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------|---------|-------------------|-----------------------------------------------------------------------|
| ID    |          |            |         |                   | A                                                                     |
| Rese  | et 0x000 | 00000      |         | 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |            |         |                   |                                                                       |
| Α     | W        | TASKS_STOP |         |                   | Stops PDM transfer                                                    |
|       |          |            | Trigger | 1                 | Trigger task                                                          |

## 7.22.8.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task START will subscribe to                  |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.22.8.4 SUBSCRIBE\_STOP

Address offset: 0x084

Subscribe configuration for task STOP

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------|-----|
| ID    |         |       |          | В                       | A A A A A A                                               | А А |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   | 0 0 |
| ID    |         |       |          |                         |                                                           |     |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to             |     |
| В     | RW      | EN    |          |                         |                                                           |     |
|       |         |       | Disabled | 0                       | Disable subscription                                      |     |
|       |         |       | Enabled  | 1                       | Enable subscription                                       |     |





### 7.22.8.5 EVENTS\_STARTED

Address offset: 0x100

PDM transfer has started



### 7.22.8.6 EVENTS STOPPED

Address offset: 0x104

PDM transfer has finished



### 7.22.8.7 **EVENTS\_END**

Address offset: 0x108

The PDM has written the last sample specified by SAMPLE.MAXCNT (or the last sample after a STOP task has been received) to Data RAM



### 7.22.8.8 PUBLISH\_STARTED

Address offset: 0x180

Publish configuration for event STARTED





## 7.22.8.9 PUBLISH\_STOPPED

Address offset: 0x184

Publish configuration for event STOPPED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event STOPPED will publish to.                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

### 7.22.8.10 PUBLISH\_END

Address offset: 0x188

Publish configuration for event END

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event END will publish to.                  |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 4                       | Enable publishing                                             |

### 7.22.8.11 INTEN

Address offset: 0x300

Enable or disable interrupt







| Bit number            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|------------------------|-----------------------------------------------------------------|
| ID                    |                        | СВА                                                             |
| Reset 0x00000000      | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field Value ID |                        | Description                                                     |
| C RW END              |                        | Enable or disable interrupt for event END                       |
| Disabled              | 0                      | Disable                                                         |
| Enabled               | 1                      | Enable                                                          |

## 7.22.8.12 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber    |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |          |                         | СВА                                                             |
| Rese  | et 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |          |                         |                                                                 |
| Α     | RW       | STARTED |          |                         | Write '1' to enable interrupt for event STARTED                 |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | STOPPED |          |                         | Write '1' to enable interrupt for event STOPPED                 |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | END     |          |                         | Write '1' to enable interrupt for event END                     |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |

## 7.22.8.13 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit number |         |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------|---------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID         |         |         |          |                         | СВА                                                             |
| Rese       | t 0x000 | 000000  |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID         |         |         |          |                         |                                                                 |
| Α          | RW      | STARTED |          |                         | Write '1' to disable interrupt for event STARTED                |
|            |         |         | Clear    | 1                       | Disable                                                         |
|            |         |         | Disabled | 0                       | Read: Disabled                                                  |
|            |         |         | Enabled  | 1                       | Read: Enabled                                                   |
| В          | RW      | STOPPED |          |                         | Write '1' to disable interrupt for event STOPPED                |
|            |         |         | Clear    | 1                       | Disable                                                         |
|            |         |         | Disabled | 0                       | Read: Disabled                                                  |
|            |         |         | Enabled  | 1                       | Read: Enabled                                                   |
| С          | RW      | END     |          |                         | Write '1' to disable interrupt for event END                    |
|            |         |         | Clear    | 1                       | Disable                                                         |
|            |         |         | Disabled | 0                       | Read: Disabled                                                  |
|            |         |         | Enabled  | 1                       | Read: Enabled                                                   |



#### 7.22.8.14 ENABLE

Address offset: 0x500

PDM module enable register



#### 7.22.8.15 PDMCLKCTRL

Address offset: 0x504

PDM clock generator control



#### 7.22.8.16 MODE

Address offset: 0x508

Defines the routing of the connected PDM microphones' signals



| Bit number       |    |           |             |                                                         | 30  | 29 2 | 8 2 | 7 26 | 25     | 24 | 23  | 22 2  | 21 2 | 20 1 | 9 1  | 8 1 | 7 1  | 5 15 | 5 14 | 113  | 12   | 11    | 10   | 9 :  | 8 7   | 7 6 | 5   | 4   | 3 | 2   | 1 0 |
|------------------|----|-----------|-------------|---------------------------------------------------------|-----|------|-----|------|--------|----|-----|-------|------|------|------|-----|------|------|------|------|------|-------|------|------|-------|-----|-----|-----|---|-----|-----|
| ID               |    |           |             |                                                         |     |      |     |      |        |    |     |       |      |      |      |     |      |      |      |      |      |       |      |      |       |     |     |     |   |     | ВА  |
| Reset 0x00000000 |    |           | 0           | 0                                                       | 0 ( | ) (  | 0   | 0    | 0      | 0  | 0   | 0     | 0 (  | ) (  | ) (  | 0   | 0    | 0    | 0    | 0    | 0    | 0     | 0    | 0 (  | 0     | 0   | 0   | 0   | 0 | 0 0 |     |
| ID               |    |           |             |                                                         |     |      |     |      |        |    | De  |       |      |      |      |     |      |      |      |      |      |       |      |      |       |     |     |     |   |     |     |
| Α                | RW | OPERATION |             |                                                         |     |      |     |      |        |    | Mo  | ono   | or   | ster | eo   | оре | erat | ion  |      |      |      |       |      |      |       |     |     |     |   |     |     |
|                  |    |           | Stereo      | 0 Sample and store one pair (left + right) of 16-bit sa |     |      |     |      | amples |    |     |       |      |      |      |     |      |      |      |      |      |       |      |      |       |     |     |     |   |     |     |
|                  |    |           |             |                                                         |     |      |     |      |        |    | pe  | r RA  | М    | wor  | d F  | =[3 | 1:1  | .6]; | L=   | 15:  | 0]   |       |      |      |       |     |     |     |   |     |     |
|                  |    |           | Mono        | 1 Sample and store two successive left samples (16 bits |     |      |     |      |        |    |     |       |      |      |      |     |      |      |      |      |      |       |      |      |       |     |     |     |   |     |     |
|                  |    |           |             |                                                         |     |      |     |      |        |    | ea  | ch) ¡ | per  | RAI  | M١   | vor | d L  | 1=[  | 31:  | 16]  | LO   | =[1   | 5:0] |      |       |     |     |     |   |     |     |
| В                | RW | EDGE      |             |                                                         |     |      |     |      |        |    | De  | fine  | s o  | n w  | hic  | h P | DM   | _CI  | .К е | edg  | e le | ft (c | or m | on   | o) is | sa  | mpl | led |   |     |     |
|                  |    |           | LeftFalling | 0                                                       |     |      |     |      |        |    | Let | ft (o | r m  | onc  | ) is | sa  | mp   | led  | on   | fal  | ing  | edg   | ge c | f PI | DM.   | _CL | K   |     |   |     |     |
|                  |    |           | LeftRising  | 1                                                       |     |      |     |      |        |    | Let | ft (o | r m  | onc  | ) is | sa  | mp   | led  | on   | risi | ng   | edg   | e o  | f PD | M_    | CLF | (   |     |   |     |     |

## 7.22.8.17 GAINL

Address offset: 0x518

Left output gain adjustment

| Bit r | umber    |       |             | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|-------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |             |                         | A A A A A A                                                     |
| Rese  | et 0x000 | 00028 |             | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |       |             |                         | Description                                                     |
| Α     | RW       | GAINL |             |                         | Left output gain adjustment, in 0.5 dB steps, around the        |
|       |          |       |             |                         | default module gain (see electrical parameters)                 |
|       |          |       |             |                         | 0x00 -20 dB gain adjust                                         |
|       |          |       |             |                         | 0x01 -19.5 dB gain adjust                                       |
|       |          |       |             |                         | ()                                                              |
|       |          |       |             |                         | 0x27 -0.5 dB gain adjust                                        |
|       |          |       |             |                         | 0x28 0 dB gain adjust                                           |
|       |          |       |             |                         | 0x29 +0.5 dB gain adjust                                        |
|       |          |       |             |                         | ()                                                              |
|       |          |       |             |                         | 0x4F +19.5 dB gain adjust                                       |
|       |          |       |             |                         | 0x50 +20 dB gain adjust                                         |
|       |          |       | MinGain     | 0x00                    | -20 dB gain adjustment (minimum)                                |
|       |          |       | DefaultGain | 0x28                    | 0 dB gain adjustment                                            |
|       |          |       | MaxGain     | 0x50                    | +20 dB gain adjustment (maximum)                                |

### 7.22.8.18 GAINR

Address offset: 0x51C

Right output gain adjustment





#### 7.22.8.19 RATIO

Address offset: 0x520

Selects the ratio between PDM CLK and output sample rate. Change PDMCLKCTRL accordingly.



#### 7.22.8.20 PSEL.CLK

Address offset: 0x540

Pin number configuration for PDM CLK signal



### 7.22.8.21 PSEL.DIN

Address offset: 0x544

Pin number configuration for PDM DIN signal





#### **7.22.8.22 MCLKCONFIG**

Address offset: 0x54C

Master clock generator configuration



### 7.22.8.23 SAMPLE.PTR

Address offset: 0x560

RAM address pointer to write samples to with EasyDMA



**Note:** See the memory chapter for details about which memories are available for EasyDMA.

### 7.22.8.24 SAMPLE.MAXCNT

Address offset: 0x564

Number of samples to allocate memory for in EasyDMA mode







# 7.22.9 Electrical specification

# 7.22.9.1 PDM Electrical Specification

| Symbol                   | Description                                               | Min. | Тур.  | Max. | Units |
|--------------------------|-----------------------------------------------------------|------|-------|------|-------|
| f <sub>PDM,CLK,64</sub>  | PDM clock speed. PDMCLKCTRL = Default (Setting needed     |      | 1.032 |      | MHz   |
|                          | for 16 MHz sample frequency @ RATIO = Ratio64)            |      |       |      |       |
| f <sub>PDM,CLK,80</sub>  | PDM clock speed. PDMCLKCTRL = 1280K (Setting needed       |      | 1.280 |      | MHz   |
|                          | for 16 MHz sample frequency @ RATIO = Ratio80)            |      |       |      |       |
| t <sub>PDM,JITTER</sub>  | Jitter in PDM clock output                                |      |       | 20   | ns    |
| T <sub>dPDM,CLK</sub>    | PDM clock duty cycle                                      | 40   | 50    | 60   | %     |
| t <sub>PDM,DATA</sub>    | Decimation filter delay                                   |      |       | 5    | ms    |
| t <sub>PDM,cv</sub>      | Allowed clock edge to data valid                          |      |       | 125  | ns    |
| t <sub>PDM,ci</sub>      | Allowed (other) clock edge to data invalid                | 0    |       |      | ns    |
| t <sub>PDM,s</sub>       | Data setup time at $f_{PDM,CLK}$ = 1.024 MHz or 1.280 MHz | 65   |       |      | ns    |
| t <sub>PDM,h</sub>       | Data hold time at $f_{PDM,CLK}$ = 1.024 MHz or 1.280 MHz  | 0    |       |      | ns    |
| G <sub>PDM,default</sub> | Default (reset) absolute gain of the PDM module           |      | 3.2   |      | dB    |



Figure 107: PDM timing diagram

# 7.23 PWM — Pulse width modulation

The pulse width modulation (PWM) module enables the generation of pulse width modulated signals on GPIO. The module implements an up or up-and-down counter with four PWM channels that drive assigned GPIOs.

The following are the main features of a PWM module:

- Programmable PWM frequency
- Up to four PWM channels with individual polarity and duty cycle values
- Edge or center-aligned pulses across PWM channels
- Multiple duty cycle arrays (sequences) defined in RAM
- Autonomous and glitch-free update of duty cycle values directly from memory through EasyDMA (no CPU involvement)
- Change of polarity, duty cycle, and base frequency possibly on every PWM period
- RAM sequences can be repeated or connected into loops





Figure 108: PWM module

#### 7.23.1 Wave counter

The wave counter is responsible for generating the pulses at a duty cycle that depends on the compare values, and at a frequency that depends on COUNTERTOP.

There is one common 15-bit counter with four compare channels. Thus, all four channels will share the same period (PWM frequency), but can have individual duty cycle and polarity. The polarity is set by a value read from RAM (see figure Decoder memory access modes on page 359). Whether the counter counts up, or up and down, is controlled by the MODE register.

The timer top value is controlled by the COUNTERTOP register. This register value, in conjunction with the selected PRESCALER of the PWM\_CLK, will result in a given PWM period. A COUNTERTOP value smaller than the compare setting will result in a state where no PWM edges are generated. OUT[n] is held high, given that the polarity is set to FallingEdge. All compare registers are internal and can only be configured through decoder presented later. COUNTERTOP can be safely written at any time.

Sampling follows the START task. If DECODER.LOAD=WaveForm, the register value is ignored and taken from RAM instead (see section Decoder with EasyDMA on page 359 for more details). If DECODER.LOAD is anything else than the WaveForm, it is sampled following a STARTSEQ[n] task and when loading a new value from RAM during a sequence playback.

The following figure shows the counter operating in up mode (MODE=PWM\_MODE\_Up), with three PWM channels with the same frequency but different duty cycle:





Figure 109: PWM counter in up mode example - FallingEdge polarity

The counter is automatically reset to zero when COUNTERTOP is reached and OUT[n] will invert. OUT[n] is held low if the compare value is 0 and held high if set to COUNTERTOP, given that the polarity is set to FallingEdge. Counter running in up mode results in pulse widths that are edge-aligned. The following is the code for the counter in up mode example:

```
uint16_t pwm_seq[4] = {PWM_CH0_DUTY, PWM_CH1_DUTY, PWM CH2 DUTY, PWM CH3 DUTY};
NRF PWM0->PSEL.OUT[0] = (first pin << PWM PSEL OUT PIN Pos) |
                        (PWM_PSEL_OUT_CONNECT_Connected <<
                                                PWM PSEL OUT CONNECT Pos);
NRF PWM0->PSEL.OUT[1] = (second pin << PWM PSEL OUT PIN Pos) |
                        (PWM PSEL OUT CONNECT Connected <<
                                                PWM PSEL OUT CONNECT Pos);
NRF PWM0->ENABLE
                   = (PWM_ENABLE_ENABLE_Enabled << PWM_ENABLE_ENABLE_Pos);
NRF PWM0->MODE = (PWM_MODE_UPDOWN_Up << PWM_MODE_UPDOWN_Pos);
NRF PWM0->PRESCALER = (PWM_PRESCALER_PRESCALER_DIV_1 <<
                                                PWM PRESCALER PRESCALER Pos);
NRF PWM0->COUNTERTOP = (16000 << PWM COUNTERTOP COUNTERTOP Pos); //1 msec
                     = (PWM LOOP CNT Disabled << PWM LOOP CNT Pos);
NRF PWM0->LOOP
NRF_PWM0->DECODER = (PWM_DECODER_LOAD_Individual << PWM_DECODER_LOAD_Pos) |
                     (PWM DECODER MODE RefreshCount << PWM DECODER MODE Pos);
NRF PWM0->SEQ[0].PTR = ((uint32 t) (pwm seq) << PWM SEQ PTR PTR Pos);
NRF PWM0->SEQ[0].CNT = ((sizeof(pwm seq) / sizeof(uint16 t)) <<
                                                PWM SEQ CNT CNT Pos);
NRF_PWM0->SEQ[0].REFRESH = 0;
NRF PWM0->SEQ[0].ENDDELAY = 0;
NRF PWM0->TASKS SEQSTART[0] = 1;
```

When the counter is running in up mode, the following formula can be used to compute the PWM period and the step size:

```
PWM period: T_{PWM (Up)} = T_{PWM CLK} * COUNTERTOP
```



Step width/Resolution:  $T_{\text{steps}} = T_{\text{PWM CLK}}$ 

The following figure shows the counter operating in up-and-down mode (MODE=PWM\_MODE\_UpAndDown), with two PWM channels with the same frequency but different duty cycle and output polarity:



Figure 110: PWM counter in up-and-down mode example

The counter starts decrementing to zero when COUNTERTOP is reached and will invert the OUT[n] when compare value is hit for the second time. This results in a set of pulses that are center-aligned. The following is the code for the counter in up-and-down mode example:

```
uint16 t pwm seq[4] = {PWM CH0 DUTY, PWM CH1 DUTY, PWM CH2 DUTY, PWM CH3 DUTY};
NRF PWM0->PSEL.OUT[0] = (first pin << PWM PSEL OUT PIN Pos) |
                       (PWM PSEL OUT CONNECT Connected <<
                                              PWM PSEL OUT CONNECT Pos);
NRF PWM0->PSEL.OUT[1] = (second pin << PWM PSEL OUT PIN Pos) |
                       (PWM PSEL OUT CONNECT Connected <<
                                              PWM PSEL OUT CONNECT Pos);
NRF PWM0->ENABLE
                    = (PWM ENABLE ENABLE Enabled << PWM ENABLE ENABLE Pos);
NRF_PWM0->MODE
                    = (PWM_MODE_UPDOWN_UpAndDown << PWM_MODE_UPDOWN_Pos);</pre>
NRF PWM0->PRESCALER = (PWM PRESCALER PRESCALER DIV 1 <<
                                              PWM PRESCALER PRESCALER Pos);
NRF PWM0->COUNTERTOP = (16000 << PWM COUNTERTOP COUNTERTOP Pos); //1 msec
               = (PWM LOOP CNT Disabled << PWM LOOP CNT Pos);
NRF PWM0->LOOP
NRF PWM0->DECODER = (PWM DECODER LOAD Individual << PWM DECODER LOAD Pos) |
                    (PWM_DECODER_MODE_RefreshCount << PWM_DECODER_MODE_Pos);</pre>
NRF PWM0->SEQ[0].PTR = ((uint32 t) (pwm seq) << PWM SEQ PTR PTR Pos);
PWM SEQ CNT CNT Pos);
NRF PWM0->SEQ[0].REFRESH = 0;
NRF_PWM0->SEQ[0].ENDDELAY = 0;
NRF PWM0->TASKS SEQSTART[0] = 1;
```



When the counter is running in up-and-down mode, the following formula can be used to compute the PWM period and the step size:

```
T_{PWM\,(Up\ And\ Down)} = T_{PWM\_CLK} * 2 * COUNTERTOP
Step width/Resolution: T_{steps} = T_{PWM\ CLK} * 2
```

### 7.23.2 Decoder with EasyDMA

The decoder uses EasyDMA to take PWM parameters stored in RAM and update the internal compare registers of the wave counter, based on the mode of operation.

PWM parameters are organized into a sequence containing at least one half word (16 bit). Its most significant bit[15] denotes the polarity of the OUT[n] while bit[14:0] is the 15-bit compare value.



The DECODER register controls how the RAM content is interpreted and loaded into the internal compare registers. The LOAD field controls if the RAM values are loaded to all compare channels, or to update a group or all channels with individual values. The following figure illustrates how parameters stored in RAM are organized and routed to various compare channels in different modes:



Figure 111: Decoder memory access modes

A special mode of operation is available when DECODER.LOAD is set to WaveForm. In this mode, up to three PWM channels can be enabled - OUT[0] to OUT[2]. In RAM, four values are loaded at a time: the first, second and third location are used to load the values, and the fourth RAM location is used to load



the COUNTERTOP register. This way one can have up to three PWM channels with a frequency base that changes on a per PWM period basis. This mode of operation is useful for arbitrary wave form generation in applications, such as LED lighting.

The register SEQ[n].REFRESH=N (one per sequence n=0 or 1) will instruct a new RAM stored pulse width value on every (N+1)<sup>th</sup> PWM period. Setting the register to zero will result in a new duty cycle update every PWM period, as long as the minimum PWM period is observed.

Note that registers SEQ[n].REFRESH and SEQ[n].ENDDELAY are ignored when DECODER.MODE=NextStep. The next value is loaded upon every received NEXTSTEP task.

SEQ[n].PTR is the pointer used to fetch COMPARE values from RAM. If the SEQ[n].PTR is not pointing to a RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions. After the SEQ[n].PTR is set to the desired RAM location, the SEQ[n].CNT register must be set to the number of 16-bit half words in the sequence. It is important to observe that the Grouped mode requires one half word per group, while the Single mode requires one half word per channel, thus increasing the RAM size occupation. If PWM generation is not running when the SEQSTART[n] task is triggered, the task will load the first value from RAM and then start the PWM generation. A SEQSTARTED[n] event is generated as soon as the EasyDMA has read the first PWM parameter from RAM and the wave counter has started executing it. When LOOP.CNT=0, sequence n=0 or 1 is played back once. After the last value in the sequence has been loaded and started executing, a SEQEND[n] event is generated. The PWM generation will then continue with the last loaded value. The following figure illustrates an example of a simple playback.



Figure 112: Simple sequence example



The following source code is used for configuration and timing details in a sequence where only sequence 0 is used and only run once with a new PWM duty cycle for each period.

```
NRF PWM0->PSEL.OUT[0] = (first pin << PWM PSEL OUT PIN Pos) |
                         (PWM PSEL OUT CONNECT Connected <<
                                                   PWM PSEL OUT CONNECT Pos);
NRF_PWM0->ENABLE = (PWM_ENABLE_ENABLE_Enabled << PWM_ENABLE_ENABLE_Pos);
NRF_PWM0->MODE = (PWM_MODE_UPDOWN_Up << PWM_MODE_UPDOWN_Pos);</pre>
NRF PWM0->PRESCALER = (PWM PRESCALER PRESCALER DIV 1 <<
                                                    PWM PRESCALER PRESCALER Pos);
NRF_PWM0->COUNTERTOP = (16000 << PWM_COUNTERTOP_COUNTERTOP_Pos); //1 msec
NRF_PWM0->LOOP = (PWM_LOOP_CNT_Disabled << PWM_LOOP_CNT_Pos);
NRF_PWM0->DECODER = (PWM_DECODER_LOAD_Common << PWM_DECODER_LOAD_Pos) |
                       (PWM DECODER MODE RefreshCount << PWM DECODER MODE Pos);
NRF_PWM0->SEQ[0].PTR = ((uint32_t)(seq0_ram) << PWM_SEQ_PTR_PTR_Pos);
NRF PWM0->SEQ[0].CNT = ((sizeof(seq0 ram) / sizeof(uint16 t)) <<
                                                    PWM SEQ CNT CNT Pos);
NRF_PWM0->SEQ[0].REFRESH = 0;
NRF PWM0->SEQ[0].ENDDELAY = 0;
NRF PWM0->TASKS SEQSTART[0] = 1;
```

To completely stop the PWM generation and force the associated pins to a defined state, a STOP task can be triggered at any time. A STOPPED event is generated when the PWM generation has stopped at the end of the currently running PWM period, and the pins go into their idle state as defined in GPIO OUT register. PWM generation can then only be restarted through a SEQSTART[n] task. SEQSTART[n] will resume PWM generation after having loaded the first value from the RAM buffer defined in the SEQ[n].PTR register.

The following table indicates when specific registers get sampled by the hardware. Care should be taken when updating these registers to avoid that values are applied earlier than expected.



| Register        | Taken into account by hardware                                | Recommended (safe) update                                       |
|-----------------|---------------------------------------------------------------|-----------------------------------------------------------------|
| SEQ[n].PTR      | When sending the SEQSTART[n] task                             | After having received the SEQSTARTED[n] event                   |
| SEQ[n].CNT      | When sending the SEQSTART[n] task                             | After having received the SEQSTARTED[n] event                   |
| SEQ[0].ENDDELAY | When sending the SEQSTART[0] task                             | Before starting sequence [0] through a SEQSTART[0] task         |
|                 | Every time a new value from sequence [0] has been loaded from | When no more value from sequence [0] gets loaded from RAM       |
|                 | RAM and gets applied to the Wave Counter (indicated by the    | (indicated by the SEQEND[0] event)                              |
|                 | PWMPERIODEND event)                                           | At any time during sequence [1] (which starts when the          |
|                 |                                                               | SEQSTARTED[1] event is generated)                               |
| SEQ[1].ENDDELAY | When sending the SEQSTART[1] task                             | Before starting sequence [1] through a SEQSTART[1] task         |
|                 | Every time a new value from sequence [1] has been loaded from | When no more value from sequence [1] gets loaded from RAM       |
|                 | RAM and gets applied to the Wave Counter (indicated by the    | (indicated by the SEQEND[1] event)                              |
|                 | PWMPERIODEND event)                                           | At any time during sequence [0] (which starts when the          |
|                 |                                                               | SEQSTARTED[0] event is generated)                               |
| SEQ[0].REFRESH  | When sending the SEQSTART[0] task                             | Before starting sequence [0] through a SEQSTART[0] task         |
|                 | Every time a new value from sequence [0] has been loaded from | At any time during sequence [1] (which starts when the          |
|                 | RAM and gets applied to the Wave Counter (indicated by the    | SEQSTARTED[1] event is generated)                               |
|                 | PWMPERIODEND event)                                           |                                                                 |
| SEQ[1].REFRESH  | When sending the SEQSTART[1] task                             | Before starting sequence [1] through a SEQSTART[1] task         |
|                 | Every time a new value from sequence [1] has been loaded from | At any time during sequence [0] (which starts when the          |
|                 | RAM and gets applied to the Wave Counter (indicated by the    | SEQSTARTED[0] event is generated)                               |
|                 | PWMPERIODEND event)                                           |                                                                 |
| COUNTERTOP      | In DECODER.LOAD=WaveForm: this register is ignored.           | Before starting PWM generation through a SEQSTART[n] task       |
|                 | In all other LOAD modes: at the end of current PWM period     | After a STOP task has been triggered, and the STOPPED event has |
|                 | (indicated by the PWMPERIODEND event)                         | been received.                                                  |
| MODE            | Immediately                                                   | Before starting PWM generation through a SEQSTART[n] task       |
|                 |                                                               | After a STOP task has been triggered, and the STOPPED event has |
|                 |                                                               | been received.                                                  |
| DECODER         | Immediately                                                   | Before starting PWM generation through a SEQSTART[n] task       |
|                 |                                                               | After a STOP task has been triggered, and the STOPPED event has |
|                 |                                                               | been received.                                                  |
| PRESCALER       | Immediately                                                   | Before starting PWM generation through a SEQSTART[n] task       |
|                 |                                                               | After a STOP task has been triggered, and the STOPPED event has |
|                 |                                                               | been received.                                                  |
| LOOP            | Immediately                                                   | Before starting PWM generation through a SEQSTART[n] task       |
|                 |                                                               | After a STOP task has been triggered, and the STOPPED event has |
|                 |                                                               | been received.                                                  |
| PSEL.OUT[n]     | Immediately                                                   | Before enabling the PWM instance through the ENABLE register    |
|                 |                                                               |                                                                 |

Table 110: When to safely update PWM registers

**Note:** SEQ[n].REFRESH and SEQ[n].ENDDELAY are ignored at the end of a complex sequence, indicated by a LOOPSDONE event. The reason for this is that the last value loaded from RAM is maintained until further action from software (restarting a new sequence, or stopping PWM generation).

The following figure shows a more complex example using the register LOOP on page 377.



Figure 113: Example using two sequences

In this case, an automated playback takes place, consisting of SEQ[0], delay 0, SEQ[1], delay 1, then again SEQ[0], etc. The user can choose to start a complex playback with SEQ[0] or SEQ[1] through sending the SEQSTART[0] or SEQSTART[1] task. The complex playback always ends with delay 1.

The two sequences 0 and 1 are defined by the addresses of value tables in RAM (pointed to by SEQ[n].PTR) and the buffer size (SEQ[n].CNT). The rate at which a new value is loaded is defined individually for each sequence by SEQ[n].REFRESH. The chaining of sequence 1 following the sequence 0 is implicit, the LOOP.CNT register allows the chaining of sequence 1 to sequence 0 for a determined number of times. In other words, it allows to repeat a complex sequence a number of times in a fully automated way.

In the following code example, sequence 0 is defined with SEQ[0].REFRESH set to 1, meaning that a new PWM duty cycle is pushed every second PWM period. This complex sequence is started with the SEQSTART[0] task, so SEQ[0] is played first. Since SEQ[0].ENDDELAY=1 there will be one PWM period delay between last period on sequence 0 and the first period on sequence 1. Since SEQ[1].ENDDELAY=0 there is no delay 1, so SEQ[0] would be started immediately after the end of SEQ[1]. However, as LOOP.CNT is



1, the playback stops after having played SEQ[1] only once, and both SEQEND[1] and LOOPSDONE are generated (their order is not guaranteed in this case).

```
NRF PWM0->PSEL.OUT[0] = (first pin << PWM PSEL OUT PIN Pos) |
                         (PWM PSEL OUT CONNECT Connected <<
                                                   PWM PSEL OUT CONNECT Pos);
NRF_PWM0->ENABLE = (PWM_ENABLE_ENABLE_Enabled << PWM_ENABLE_ENABLE_Pos);
NRF_PWM0->MODE = (PWM_MODE_UPDOWN_Up << PWM_MODE_UPDOWN_Pos);</pre>
NRF_PWM0->PRESCALER = (PWM_PRESCALER_PRESCALER DIV 1 <<
                                                   PWM PRESCALER PRESCALER Pos);
NRF_PWM0->COUNTERTOP = (16000 << PWM_COUNTERTOP_COUNTERTOP_Pos); //1 msec
NRF PWM0->LOOP = (1 << PWM_LOOP_CNT_Pos);
NRF_PWM0->DECODER = (PWM_DECODER_LOAD_Common << PWM_DECODER_LOAD_Pos) |
                       (PWM DECODER MODE RefreshCount << PWM DECODER MODE Pos);
NRF_PWM0->SEQ[0].PTR = ((uint32_t)(seq0_ram) << PWM_SEQ_PTR_PTR_Pos);
NRF PWM0->SEQ[0].CNT = ((sizeof(seq0 ram) / sizeof(uint16 t)) <<
                                                   PWM SEQ CNT CNT Pos);
NRF_PWM0->SEQ[0].REFRESH = 1;
NRF PWM0->SEQ[0].ENDDELAY = 1;
NRF PWM0->SEQ[1].PTR = ((uint32 t)(seq1 ram) << PWM SEQ PTR PTR Pos);
NRF_PWM0->SEQ[1].CNT = ((sizeof(seq1_ram) / sizeof(uint16_t)) <<
                                                  PWM SEQ CNT CNT Pos);
NRF PWM0->SEQ[1].REFRESH = 0;
NRF PWM0->SEQ[1].ENDDELAY = 0;
NRF PWM0->TASKS SEQSTART[0] = 1;
```

The decoder can also be configured to asynchronously load new PWM duty cycle. If the DECODER.MODE register is set to NextStep, then the NEXTSTEP task will cause an update of internal compare registers on the next PWM period.

The following figures provide an overview of each part of an arbitrary sequence, in various modes (LOOP.CNT=0 and LOOP.CNT>0). In particular, the following are represented:

- Initial and final duty cycle on the PWM output(s)
- Chaining of SEQ[0] and SEQ[1] if LOOP.CNT>0
- Influence of registers on the sequence
- Events generated during a sequence
- DMA activity (loading of next value and applying it to the output(s))





Figure 114: Single shot (LOOP.CNT=0)

**Note:** The single-shot example also applies to SEQ[1]. Only SEQ[0] is represented for simplicity.



Figure 115: Complex sequence (LOOP.CNT>0) starting with SEQ[0]





Figure 116: Complex sequence (LOOP.CNT>0) starting with SEQ[1]

**Note:** If a sequence is in use in a simple or complex sequence, it must have a length of SEQ[n].CNT > 0.

This example shows how the PWM module can be configured to repeat a single sequence until stopped.

```
NRF PWM0->PSEL.OUT[0] = (first pin << PWM PSEL OUT PIN Pos) |
                       (PWM PSEL OUT CONNECT Connected <<
                                              PWM PSEL OUT CONNECT Pos);
NRF PWM0->ENABLE
                    = (PWM ENABLE ENABLE Enabled << PWM ENABLE ENABLE Pos);
                    = (PWM MODE UPDOWN Up << PWM MODE UPDOWN Pos);
NRF PWM0->MODE
NRF PWM0->PRESCALER = (PWM PRESCALER PRESCALER DIV 1 <<
                                              PWM_PRESCALER_PRESCALER_Pos);
NRF PWM0->COUNTERTOP = (16000 << PWM COUNTERTOP COUNTERTOP Pos); //1 msec
// Enable the shortcut from LOOPSDONE event to SEQSTART1 task for infinite loop
                    = (PWM_SHORTS_LOOPSDONE_SEQSTART1_Enabled <<
NRF PWM0->SHORTS
                                        PWM SHORTS LOOPSDONE SEQSTART1 Pos);
// LOOP CNT must be greater than 0 for the LOOPSDONE event to trigger and enable looping
NRF PWM0->LOOP
                    = (1 << PWM_LOOP_CNT_Pos);
NRF PWM0->DECODER
                    = (PWM DECODER LOAD Common << PWM DECODER LOAD Pos) |
                     (PWM DECODER MODE RefreshCount << PWM DECODER MODE Pos);
// To repeat a single sequence until stopped, it must be configured in SEQ[1]
NRF PWM0->SEQ[1].PTR = ((uint32 t)(seq0 ram) << PWM SEQ PTR PTR Pos);
PWM SEQ CNT CNT Pos);
NRF PWM0->SEQ[1].REFRESH = 0;
NRF PWM0->SEQ[1].ENDDELAY = 0;
NRF PWM0->TASKS SEQSTART[1] = 1;
```



#### 7.23.3 Limitations

The previous compare value is repeated if the PWM period is shorter than the time it takes for the EasyDMA to retrieve from RAM and update the internal compare registers. This is to ensure a glitch-free operation even for very short PWM periods.

Only SEQ[1] can trigger the LOOPSDONE event upon completion, not SEQ[0]. This requires looping to be enabled (LOOP > 0) and SEQ[1].CNT > 0 when sequence playback starts.

### 7.23.4 Pin configuration

The OUT[n] (n=0..3) signals associated with each PWM channel are mapped to physical pins according to the configuration of PSEL.OUT[n] registers. If PSEL.OUT[n].CONNECT is set to Disconnected, the associated PWM module signal will not be connected to any physical pins.

The PSEL.OUT[n] registers and their configurations are used as long as the PWM module is enabled and the PWM generation active (wave counter started). They are retained only as long as the device is in System ON mode (see the POWER section for more information about power modes).

To ensure correct behavior in the PWM module, the pins that are used must be configured in the GPIO peripheral in the following way before the PWM module is enabled:

| PWM signal | PWM pin                     | Direction | Output value | Comment                        |
|------------|-----------------------------|-----------|--------------|--------------------------------|
| OUT[n]     | As specified in PSEL.OUT[n] | Output    | 0            | Idle state defined in GPIO OUT |
|            | (n=03)                      |           |              | register                       |

Table 111: Recommended GPIO configuration before starting PWM generation

The idle state of a pin is defined by the OUT register in the GPIO module, to ensure that the pins used by the PWM module are driven correctly. If PWM generation is stopped by triggering a STOP task, the PWM module itself is temporarily disabled or the device temporarily enters System OFF. This configuration must be retained in the GPIO for the selected pins (I/Os) for as long as the PWM module is supposed to be connected to an external PWM circuit.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

# 7.23.5 Registers

| Base address Domain | Peripheral | Instance  | Secure mapping | DMA security | Description            | Configuration |
|---------------------|------------|-----------|----------------|--------------|------------------------|---------------|
| 0x50021000          | ION PWM    | PWM0:S    | US             | SA           | Pulse width modulation |               |
| 0x40021000          | ION PWW    | PWM0 : NS | 03             | ЗА           | unit 0                 |               |
| 0x50022000          | ION PWM    | PWM1:S    | US             | SA           | Pulse width modulation |               |
| 0x40022000          | ION PWW    | PWM1: NS  | 03             | эА           | unit 1                 |               |
| 0x50023000          | ION PWM    | PWM2:S    | US             | SA           | Pulse width modulation |               |
| 0x40023000          | ION PWW    | PWM2:NS   | 03             | ЗА           | unit 2                 |               |
| 0x50024000          | ION PWM    | PWM3:S    | US             | SA           | Pulse width modulation |               |
| 0x40024000          | ION PWW    | PWM3:NS   | US             | SA           | unit 3                 |               |

Table 112: Instances

| Register   | Offset | Security | Description                                                                      |
|------------|--------|----------|----------------------------------------------------------------------------------|
| TASKS_STOP | 0x004  |          | Stops PWM pulse generation on all channels at the end of current PWM period, and |
|            |        |          | stops sequence playback                                                          |



| Register             | Offset | Security | Description                                                                           |
|----------------------|--------|----------|---------------------------------------------------------------------------------------|
| TASKS_SEQSTART[n]    | 0x008  |          | Loads the first PWM value on all enabled channels from sequence n, and starts playing |
|                      |        |          | that sequence at the rate defined in SEQ[n]REFRESH and/or DECODER.MODE. Causes        |
|                      |        |          | PWM generation to start if not running.                                               |
| TASKS_NEXTSTEP       | 0x010  |          | Steps by one value in the current sequence on all enabled channels if                 |
|                      |        |          | DECODER.MODE=NextStep. Does not cause PWM generation to start if not running.         |
| SUBSCRIBE_STOP       | 0x084  |          | Subscribe configuration for task STOP                                                 |
| UBSCRIBE_SEQSTART[n] | 0x088  |          | Subscribe configuration for task SEQSTART[n]                                          |
| UBSCRIBE_NEXTSTEP    | 0x090  |          | Subscribe configuration for task NEXTSTEP                                             |
| VENTS_STOPPED        | 0x104  |          | Response to STOP task, emitted when PWM pulses are no longer generated                |
| VENTS_SEQSTARTED[n]  | 0x108  |          | First PWM period started on sequence n                                                |
| EVENTS_SEQEND[n]     | 0x110  |          | Emitted at end of every sequence n, when last value from RAM has been applied to      |
|                      |        |          | wave counter                                                                          |
| VENTS_PWMPERIODEND   | 0x118  |          | Emitted at the end of each PWM period                                                 |
| VENTS_LOOPSDONE      | 0x11C  |          | Concatenated sequences have been played the amount of times defined in LOOP.CNT       |
| UBLISH_STOPPED       | 0x184  |          | Publish configuration for event STOPPED                                               |
| UBLISH_SEQSTARTED[n] | 0x188  |          | Publish configuration for event SEQSTARTED[n]                                         |
| UBLISH_SEQEND[n]     | 0x190  |          | Publish configuration for event SEQEND[n]                                             |
| UBLISH_PWMPERIODEND  | 0x198  |          | Publish configuration for event PWMPERIODEND                                          |
| UBLISH_LOOPSDONE     | 0x19C  |          | Publish configuration for event LOOPSDONE                                             |
| HORTS                | 0x200  |          | Shortcuts between local events and tasks                                              |
| NTEN                 | 0x300  |          | Enable or disable interrupt                                                           |
| NTENSET              | 0x304  |          | Enable interrupt                                                                      |
| NTENCLR              | 0x308  |          | Disable interrupt                                                                     |
| NABLE                | 0x500  |          | PWM module enable register                                                            |
| MODE                 | 0x504  |          | Selects operating mode of the wave counter                                            |
| OUNTERTOP            | 0x508  |          | Value up to which the pulse generator counter counts                                  |
| RESCALER             | 0x50C  |          | Configuration for PWM_CLK                                                             |
| DECODER              | 0x510  |          | Configuration of the decoder                                                          |
| OOP                  | 0x514  |          | Number of playbacks of a loop                                                         |
| EQ[n].PTR            | 0x520  |          | Beginning address in RAM of this sequence                                             |
| EQ[n].CNT            | 0x524  |          | Number of values (duty cycles) in this sequence                                       |
| EQ[n].REFRESH        | 0x528  |          | Number of additional PWM periods between samples loaded into compare register         |
| EQ[n].ENDDELAY       | 0x52C  |          | Time added after the sequence                                                         |
| PSEL.OUT[n]          | 0x560  |          | Output pin select for PWM channel n                                                   |

Table 113: Register overview

# 7.23.5.1 TASKS\_STOP

Address offset: 0x004

Stops PWM pulse generation on all channels at the end of current PWM period, and stops sequence playback





# 7.23.5.2 TASKS\_SEQSTART[n] (n=0..1)

Address offset:  $0x008 + (n \times 0x4)$ 

Loads the first PWM value on all enabled channels from sequence n, and starts playing that sequence at the rate defined in SEQ[n]REFRESH and/or DECODER.MODE. Causes PWM generation to start if not running.



#### 7.23.5.3 TASKS NEXTSTEP

Address offset: 0x010

Steps by one value in the current sequence on all enabled channels if DECODER.MODE=NextStep. Does not cause PWM generation to start if not running.



#### 7.23.5.4 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP



# 7.23.5.5 SUBSCRIBE\_SEQSTART[n] (n=0..1)

Address offset:  $0x088 + (n \times 0x4)$ 

Subscribe configuration for task SEQSTART[n]





### 7.23.5.6 SUBSCRIBE NEXTSTEP

Address offset: 0x090

Subscribe configuration for task NEXTSTEP



### 7.23.5.7 EVENTS STOPPED

Address offset: 0x104

Response to STOP task, emitted when PWM pulses are no longer generated



### 7.23.5.8 EVENTS\_SEQSTARTED[n] (n=0..1)

Address offset:  $0x108 + (n \times 0x4)$ 

First PWM period started on sequence n







### 7.23.5.9 EVENTS\_SEQEND[n] (n=0..1)

Address offset:  $0x110 + (n \times 0x4)$ 

Emitted at end of every sequence n, when last value from RAM has been applied to wave counter



### 7.23.5.10 EVENTS\_PWMPERIODEND

Address offset: 0x118

Emitted at the end of each PWM period



#### 7.23.5.11 EVENTS\_LOOPSDONE

Address offset: 0x11C

Concatenated sequences have been played the amount of times defined in LOOP.CNT

This event triggers after the last SEQ[1] completion of the loop, and only if looping was enabled (LOOP > 0) when the sequence playback was started.



### 7.23.5.12 PUBLISH\_STOPPED

Address offset: 0x184

Publish configuration for event STOPPED





## 7.23.5.13 PUBLISH\_SEQSTARTED[n] (n=0..1)

Address offset:  $0x188 + (n \times 0x4)$ 

Publish configuration for event SEQSTARTED[n]



# 7.23.5.14 PUBLISH\_SEQEND[n] (n=0..1)

Address offset:  $0x190 + (n \times 0x4)$ 

Publish configuration for event SEQEND[n]

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event SEQEND[n] will publish to.            |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 1                       | Enable publishing                                             |

## 7.23.5.15 PUBLISH\_PWMPERIODEND

Address offset: 0x198

Publish configuration for event PWMPERIODEND







# 7.23.5.16 PUBLISH\_LOOPSDONE

Address offset: 0x19C

Publish configuration for event LOOPSDONE

This event triggers after the last SEQ[1] completion of the loop, and only if looping was enabled (LOOP > 0) when the sequence playback was started.



#### 7.23.5.17 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit r | number   |                   |          | 31 | 30 2 | 9 28 | 8 27 | 7 26 | 25 2 | 24 2 | 23 2 | 22 2 | 21 : | 20 : | 19 : | 18 1 | .7 1 | 6 1! | 5 14 | 13  | 12  | 11 1 | 0 9  | 8    | 7  | 6 | 5 | 4 3 | 3 2 | 1 | 0 |
|-------|----------|-------------------|----------|----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|-----|-----|------|------|------|----|---|---|-----|-----|---|---|
| ID    |          |                   |          |    |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |      |      |      |    |   |   | E [ | ) C | В | Α |
| Res   | et 0x000 | 00000             |          | 0  | 0 (  | 0 0  | 0    | 0    | 0    | 0 (  | 0    | 0    | 0    | 0    | 0    | 0    | 0 (  | 0    | 0    | 0   | 0   | 0 (  | 0    | 0    | 0  | 0 | 0 | 0 ( | 0   | 0 | 0 |
|       |          |                   |          |    |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
| Α     | RW       | SEQENDO_STOP      |          |    |      |      |      |      |      | S    | Sho  | rtc  | ut   | bet  | we   | en   | eve  | nt S | EQI  | ND  | [0] | and  | tas  | k ST | OP |   |   |     |     |   |   |
|       |          |                   | Disabled | 0  |      |      |      |      |      |      | Disa | able | e sl | hor  | tcu  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Enabled  | 1  |      |      |      |      |      | E    | Ena  | ble  | e sh | ort  | cut  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
| В     | RW       | SEQEND1_STOP      |          |    |      |      |      |      |      | S    | Sho  | rtc  | ut   | bet  | we   | en   | eve  | nt S | EQI  | END | [1] | and  | tas  | k ST | OP |   |   |     |     |   |   |
|       |          |                   | Disabled | 0  |      |      |      |      |      |      | Disa | able | e sl | hor  | tcu  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Enabled  | 1  |      |      |      |      |      | E    | Ena  | ble  | e sh | ort  | cut  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
| С     | RW       | LOOPSDONE_SEQSTAR | го       |    |      |      |      |      |      | S    | Sho  | rtc  | ut   | bet  | we   | en   | eve  | nt L | 00   | PSD | ON  | E an | d ta | sk   |    |   |   |     |     |   |   |
|       |          |                   |          |    |      |      |      |      |      | S    | SEC  | QST  | AR   | T[0] | ]    |      |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Disabled | 0  |      |      |      |      |      |      | Disa | able | e sl | hor  | tcu  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Enabled  | 1  |      |      |      |      |      | Е    | Ena  | ble  | e sh | ort  | cut  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
| D     | RW       | LOOPSDONE_SEQSTAR | Γ:       |    |      |      |      |      |      | S    | Sho  | rtc  | ut   | bet  | we   | en   | eve  | nt L | 00   | PSD | ON  | E an | d ta | sk   |    |   |   |     |     |   |   |
|       |          |                   |          |    |      |      |      |      |      | S    | SEC  | QST/ | AR   | T[1] | ]    |      |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Disabled | 0  |      |      |      |      |      | [    | Disa | able | e sl | hor  | tcu  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Enabled  | 1  |      |      |      |      |      | E    | Ena  | ble  | e sh | ort  | cut  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
| E     | RW       | LOOPSDONE_STOP    |          |    |      |      |      |      |      | S    | Sho  | rtc  | ut   | bet  | we   | en   | eve  | nt L | 00   | PSD | ON  | E an | d ta | sk S | то | Р |   |     |     |   |   |
|       |          |                   | Disabled | 0  |      |      |      |      |      |      | Disa | able | e sl | hor  | tcu  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |
|       |          |                   | Enabled  | 1  |      |      |      |      |      | Е    | Ena  | ble  | e sh | ort  | cut  | t    |      |      |      |     |     |      |      |      |    |   |   |     |     |   |   |

#### 7.23.5.18 INTEN

Address offset: 0x300

Enable or disable interrupt



| Bit n | umber   |                      |          | 31 | 30 | 29 2 | 28 27 | 7 26 | 25 | 24 | 23  | 22 2  | 21 2 | 20 1  | 9 18   | 17   | 16   | 15 : | 14 : | 13 1 | 12 1 | 1 10 | 9   | 8   | 7   | 6   | 5    | 4  | 3 2 | 2 1 | 0 |
|-------|---------|----------------------|----------|----|----|------|-------|------|----|----|-----|-------|------|-------|--------|------|------|------|------|------|------|------|-----|-----|-----|-----|------|----|-----|-----|---|
| ID    |         |                      |          |    |    |      |       |      |    |    |     |       |      |       |        |      |      |      |      |      |      |      |     |     | Н   | G   | F    | Ε  | D ( | C E | } |
| Rese  | t 0x000 | 00000                |          | 0  | 0  | 0    | 0 0   | 0    | 0  | 0  | 0   | 0     | 0 (  | 0 0   | 0      | 0    | 0    | 0    | 0    | 0    | 0 (  | 0    | 0   | 0   | 0   | 0   | 0    | 0  | 0 ( | 0   | 0 |
|       |         |                      |          |    |    |      |       |      |    |    | De: |       |      |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
| В     | RW      | STOPPED              |          |    |    |      |       |      |    |    | Ena | able  | or   | disa  | able   | inte | erru | ıpt  | for  | eve  | ent  | STO  | PPE | D   |     |     |      |    |     |     |   |
|       |         |                      | Disabled | 0  |    |      |       |      |    |    | Dis | sabl  | e    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Enabled  | 1  |    |      |       |      |    |    | Ena | able  | 9    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
| C-D   | RW      | SEQSTARTED[i] (i=01) |          |    |    |      |       |      |    |    | Ena | able  | or   | disa  | able   | inte | erru | ıpt  | for  | eve  | ent  | SEQ  | STA | RTE | D[i | ]   |      |    |     |     |   |
|       |         |                      | Disabled | 0  |    |      |       |      |    |    | Dis | sabl  | e    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Enabled  | 1  |    |      |       |      |    |    | Ena | able  | 9    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
| E-F   | RW      | SEQEND[i] (i=01)     |          |    |    |      |       |      |    |    | Ena | able  | or   | disa  | able   | int  | erru | ıpt  | for  | eve  | ent  | SEQ  | END | [i] |     |     |      |    |     |     |   |
|       |         |                      | Disabled | 0  |    |      |       |      |    |    | Dis | sabl  | e    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Enabled  | 1  |    |      |       |      |    |    | Ena | able  | è    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
| G     | RW      | PWMPERIODEND         |          |    |    |      |       |      |    |    | Ena | able  | or   | disa  | able   | int  | erru | ıpt  | for  | eve  | ent  | PWI  | MPE | RIC | DDE | ND  | )    |    |     |     |   |
|       |         |                      | Disabled | 0  |    |      |       |      |    |    | Dis | sabl  | e    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Enabled  | 1  |    |      |       |      |    |    | Ena | able  | 9    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
| Н     | RW      | LOOPSDONE            |          |    |    |      |       |      |    |    | Ena | able  | or   | disa  | able   | int  | erru | ıpt  | for  | eve  | ent  | LOO  | PSE | ON  | ΙE  |     |      |    |     |     |   |
|       |         |                      |          |    |    |      |       |      |    |    | Thi | is ev | /ent | t tri | gger   | s af | ter  | the  | las  | st S | EQ[  | 1] c | omp | let | ion | of  | the  | 9  |     |     |   |
|       |         |                      |          |    |    |      |       |      |    |    | loo | p, a  | and  | onl   | y if I | oop  | ing  | wa   | s e  | nal  | oled | (LO  | OP  | > 0 | ) w | her | n th | ie |     |     |   |
|       |         |                      |          |    |    |      |       |      |    |    | sec | quei  | nce  | pla   | yba    | ck w | as   | star | tec  | d.   |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Disabled | 0  |    |      |       |      |    |    | Dis | sabl  | e    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      | Enabled  | 1  |    |      |       |      |    |    | Ena | able  | è    |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |
|       |         |                      |          |    |    |      |       |      |    |    |     |       |      |       |        |      |      |      |      |      |      |      |     |     |     |     |      |    |     |     |   |

# 7.23.5.19 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber   |                      |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |                      |          |                        | HGFEDCB                                                         |
| Rese  | t 0x000 | 00000                |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                      |          |                        | Description                                                     |
| В     | RW      | STOPPED              |          |                        | Write '1' to enable interrupt for event STOPPED                 |
|       |         |                      | Set      | 1                      | Enable                                                          |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| C-D   | RW      | SEQSTARTED[i] (i=01) |          |                        | Write '1' to enable interrupt for event SEQSTARTED[i]           |
|       |         |                      | Set      | 1                      | Enable                                                          |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| E-F   | RW      | SEQEND[i] (i=01)     |          |                        | Write '1' to enable interrupt for event SEQEND[i]               |
|       |         |                      | Set      | 1                      | Enable                                                          |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| G     | RW      | PWMPERIODEND         |          |                        | Write '1' to enable interrupt for event PWMPERIODEND            |
|       |         |                      | Set      | 1                      | Enable                                                          |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| Н     | RW      | LOOPSDONE            |          |                        | Write '1' to enable interrupt for event LOOPSDONE               |
|       |         |                      |          |                        | This event triggers after the last SEQ[1] completion of the     |
|       |         |                      |          |                        | loop, and only if looping was enabled (LOOP > 0) when the       |
|       |         |                      |          |                        | sequence playback was started.                                  |
|       |         |                      | Set      | 1                      | Enable                                                          |
|       |         |                      |          |                        |                                                                 |





|                  | Disabled | 0                    | Read: Disabled                                                   |
|------------------|----------|----------------------|------------------------------------------------------------------|
| ID R/W Field     |          |                      | Description                                                      |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0        | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                        |
| ID               |          |                      | H G F E D C B                                                    |
| Bit number       |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

### 7.23.5.20 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber   |                      |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |                      |          |                        | HGFEDCB                                                         |
| Rese  | t 0x000 | 00000                |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |         |                      |          |                        |                                                                 |
| В     | RW      | STOPPED              |          |                        | Write '1' to disable interrupt for event STOPPED                |
|       |         |                      | Clear    | 1                      | Disable                                                         |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| C-D   | RW      | SEQSTARTED[i] (i=01) |          |                        | Write '1' to disable interrupt for event SEQSTARTED[i]          |
|       |         |                      | Clear    | 1                      | Disable                                                         |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| E-F   | RW      | SEQEND[i] (i=01)     |          |                        | Write '1' to disable interrupt for event SEQEND[i]              |
|       |         |                      | Clear    | 1                      | Disable                                                         |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| G     | RW      | PWMPERIODEND         |          |                        | Write '1' to disable interrupt for event PWMPERIODEND           |
|       |         |                      | Clear    | 1                      | Disable                                                         |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
| Н     | RW      | LOOPSDONE            |          |                        | Write '1' to disable interrupt for event LOOPSDONE              |
|       |         |                      |          |                        | This event triggers after the last SEQ[1] completion of the     |
|       |         |                      |          |                        | loop, and only if looping was enabled (LOOP > 0) when the       |
|       |         |                      |          |                        | sequence playback was started.                                  |
|       |         |                      | Clear    | 1                      | Disable                                                         |
|       |         |                      | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                      | Enabled  | 1                      | Read: Enabled                                                   |
|       |         |                      |          |                        |                                                                 |

# 7.23.5.21 ENABLE

Address offset: 0x500

PWM module enable register

| Bit nui | mber  |        |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|---------|-------|--------|----------|-------------------|---------------------------------------------------------------------|
| ID      |       |        |          |                   | A                                                                   |
| Reset   | 0x000 | 00000  |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID      |       |        |          |                   |                                                                     |
| Α       | RW    | ENABLE |          |                   | Enable or disable PWM module                                        |
|         |       |        | Disabled | 0                 | Disabled                                                            |
|         |       |        | Enabled  | 1                 | Enable                                                              |





#### 7.23.5.22 MODE

Address offset: 0x504

Selects operating mode of the wave counter



#### **7.23.5.23 COUNTERTOP**

Address offset: 0x508

Value up to which the pulse generator counter counts



#### 7.23.5.24 PRESCALER

Address offset: 0x50C

Configuration for PWM\_CLK



#### 7.23.5.25 DECODER

Address offset: 0x510

Configuration of the decoder





#### 7.23.5.26 LOOP

Address offset: 0x514

Number of playbacks of a loop



### 7.23.5.27 SEQ[n].PTR (n=0..1)

Address offset:  $0x520 + (n \times 0x20)$ 

Beginning address in RAM of this sequence



**Note:** See the memory chapter for details about which memories are available for EasyDMA.

# 7.23.5.28 SEQ[n].CNT (n=0..1)

Address offset:  $0x524 + (n \times 0x20)$ 

Number of values (duty cycles) in this sequence





### 7.23.5.29 SEQ[n].REFRESH (n=0..1)

Address offset:  $0x528 + (n \times 0x20)$ 

Number of additional PWM periods between samples loaded into compare register



### 7.23.5.30 SEQ[n].ENDDELAY (n=0..1)

Address offset:  $0x52C + (n \times 0x20)$ Time added after the sequence



# 7.23.5.31 PSEL.OUT[n] (n=0..3)

Address offset:  $0x560 + (n \times 0x4)$ 

Output pin select for PWM channel n



# 7.24 QDEC — Quadrature decoder

The Quadrature decoder (QDEC) provides buffered decoding of quadrature-encoded sensor signals. It is suitable for mechanical and optical sensors.





The sample period and accumulation are configurable to match application requirements. The QDEC provides the following:

- Decoding of digital waveform from off-chip quadrature encoder.
- Sample accumulation eliminating hard real-time requirements to be enforced on application.
- Optional input de-bounce filters.
- Optional LED output signal for optical encoders.



Figure 117: Quadrature decoder configuration

# 7.24.1 Sampling and decoding

The QDEC decodes the output from an incremental motion encoder by sampling the QDEC phase input pins (A and B).

The off-chip quadrature encoder is an incremental motion encoder outputting two waveforms, phase A and phase B. The two output waveforms are always 90 degrees out of phase, meaning that one always changes level before the other. The direction of movement is indicated by the waveform that changes level first. Invalid transitions may occur, meaning the two waveforms simultaneously switch. This may occur if the wheel rotates too fast relative to the sample rate set for the decoder.

The QDEC decodes the output from the off-chip encoder by sampling the QDEC phase input pins (A and B) at a fixed rate as specified in the SAMPLEPER register.

If the SAMPLEPER value needs to be changed, the QDEC shall be stopped using the STOP task. SAMPLEPER can be then changed upon receiving the STOPPED event, and QDEC can be restarted using the START task. Failing to do so may result in unpredictable behavior.



It is good practice to only change registers LEDPOL, REPORTPER, DBFEN, and LEDPRE when the QDEC is stopped.

When started, the decoder continuously samples the two input waveforms and decodes these by comparing the current sample pair (n) with the previous sample pair (n-1).

The decoding of the sample pairs is described in the table below.

| Previo       | ous<br>le pair(n | Curre  |   | SAMPLE<br>register | ACC operation | ACCDBL<br>operation | Description                    |
|--------------|------------------|--------|---|--------------------|---------------|---------------------|--------------------------------|
| - <b>1</b> ) | ic pair(ii       | pair(n |   | register           |               | орегиноп            |                                |
| Α            | В                | Α      | В |                    |               |                     |                                |
| 0            | 0                | 0      | 0 | 0                  | No change     | No change           | No movement                    |
| 0            | 0                | 0      | 1 | 1                  | Increment     | No change           | Movement in positive direction |
| 0            | 0                | 1      | 0 | -1                 | Decrement     | No change           | Movement in negative direction |
| 0            | 0                | 1      | 1 | 2                  | No change     | Increment           | Error: Double transition       |
| 0            | 1                | 0      | 0 | -1                 | Decrement     | No change           | Movement in negative direction |
| 0            | 1                | 0      | 1 | 0                  | No change     | No change           | No movement                    |
| 0            | 1                | 1      | 0 | 2                  | No change     | Increment           | Error: Double transition       |
| 0            | 1                | 1      | 1 | 1                  | Increment     | No change           | Movement in positive direction |
| 1            | 0                | 0      | 0 | 1                  | Increment     | No change           | Movement in positive direction |
| 1            | 0                | 0      | 1 | 2                  | No change     | Increment           | Error: Double transition       |
| 1            | 0                | 1      | 0 | 0                  | No change     | No change           | No movement                    |
| 1            | 0                | 1      | 1 | -1                 | Decrement     | No change           | Movement in negative direction |
| 1            | 1                | 0      | 0 | 2                  | No change     | Increment           | Error: Double transition       |
| 1            | 1                | 0      | 1 | -1                 | Decrement     | No change           | Movement in negative direction |
| 1            | 1                | 1      | 0 | 1                  | Increment     | No change           | Movement in positive direction |
| 1            | 1                | 1      | 1 | 0                  | No change     | No change           | No movement                    |

Table 114: Sampled value encoding

## 7.24.2 LED output

The LED output follows the sample period. The LED is switched on for a set period before sampling and then switched off immediately after. The period the LED is switched on before sampling is given in the LEDPRE register.

The LED output pin polarity is specified in the LEDPOL register.

When using off-chip mechanical encoders not requiring an LED, the LED output can be disabled by writing value 'Disconnected' to the CONNECT field of the PSEL.LED register. In this case, the QDEC will not acquire access to a pin for the LED output.

### 7.24.3 Debounce filters

Each of the two-phase inputs have digital debounce filters.

When enabled through the DBFEN register, the filter inputs are sampled at a fixed 1 MHz frequency during the entire sample period (which is specified in the SAMPLEPER register). The filters require all of the samples within this sample period to equal before the input signal is accepted and transferred to the output of the filter.

As a result, only input signal with a steady state longer than twice the period specified in SAMPLEPER are guaranteed to pass through the filter. Any signal with a steady state shorter than SAMPLEPER will always be suppressed by the filter. It is assumed that the frequency during the debounce period never exceeds 500 kHz (as required by the Nyquist theorem when using a 1 MHz sample frequency).

The LED will always be ON when the debounce filters are enabled, as the inputs in this case will be sampled continuously.

NORDIC\*

When the debounce filters are enabled, displacements reported by the QDEC peripheral are delayed by one SAMPLEPER period.

#### 7.24.4 Accumulators

The quadrature decoder contains two accumulator registers, ACC and ACCDBL. These registers accumulate valid motion sample values and the number of detected invalid samples (double transitions), respectively.

The ACC register accumulates all valid values (1/-1) written to the SAMPLE register. This can be useful for preventing hard real-time requirements from being enforced on the application. When using the ACC register, the application can fetch data when necessary instead of reading all SAMPLE register output. The ACC register holds the relative movement of the external mechanical device from the previous clearing of the ACC register. Sample values indicating a double transition (2) will not be accumulated in the ACC register.

An ACCOF event is generated if the ACC receives a SAMPLE value that would cause the register to overflow or underflow. Any SAMPLE value that would cause an ACC overflow or underflow will be discarded, but any samples that do not cause the ACC to overflow or underflow will still be accepted.

The accumulator ACCDBL accumulates the number of detected double transitions since the previous clearing of the ACCDBL register.

The ACC and ACCDBL registers can be cleared by the READCLRACC and subsequently read using the ACCREAD and ACCDBLREAD registers.

The ACC register can be separately cleared by the RDCLRACC and subsequently read using the ACCREAD registers.

The ACCDBL register can be separately cleared by the RDCLRDBL and subsequently read using the ACCDBLREAD registers.

The REPORTPER register allows automated capture of multiple samples before sending an event. When a non-null displacement is captured and accumulated, a REPORTRDY event is sent. When one or more double-displacements are captured and accumulated, a DBLRDY event is sent. The REPORTPER field in this register determines how many samples must be accumulated before the contents are evaluated and a REPORTRDY or DBLRDY event is sent.

Using the RDCLRACC task (manually sent upon receiving the event, or using the DBLRDY\_RDCLRACC shortcut), ACCREAD can then be read.

When a double transition has been captured and accumulated, a DBLRDY event is sent. Using the RDCLRDBL task (manually sent upon receiving the event, or using the DBLRDY\_RDCLRDBL shortcut), ACCDBLRFAD can then be read.

# 7.24.5 Output/input pins

The QDEC uses a three-pin interface to the off-chip quadrature encoder.

These pins are acquired when the QDEC is enabled in the ENABLE register. The pins acquired by the QDEC cannot be written by the CPU, but they can still be read by the CPU.

The pin numbers used for the QDEC are selected using the PSEL.n registers.

# 7.24.6 Pin configuration

The Phase A, Phase B, and LED signals are mapped to physical pins according to the configuration specified in the PSEL.A, PSEL.B, and PSEL.LED registers respectively.

If the CONNECT field value 'Disconnected' is specified in any of these registers, the associated signal will not be connected to any physical pin. The PSEL.A, PSEL.B, and PSEL.LED registers and their configurations are only used as long as the QDEC is enabled, and retained only as long as the device is in ON mode.



When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register.

To secure correct behavior in the QDEC, the pins used by the QDEC must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 382 before enabling the QDEC. This configuration must be retained in the GPIO for the selected I/Os as long as the QDEC is enabled.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| QDEC signal | QDEC pin                 | Direction | Output value   | Comment |
|-------------|--------------------------|-----------|----------------|---------|
| Phase A     | As specified in PSEL.A   | Input     | Not applicable |         |
| Phase B     | As specified in PSEL.B   | Input     | Not applicable |         |
| LED         | As specified in PSEL.LED | Input     | Not applicable |         |

Table 115: GPIO configuration before enabling peripheral

# 7.24.7 Registers

| Base address | Domain                      | Peripheral | Instance   | Secure mapping | DMA security | Description          | Configuration |
|--------------|-----------------------------|------------|------------|----------------|--------------|----------------------|---------------|
| 0x50033000   | APPLICATION                 | LODEC      | QDEC0 : S  | US             | NA           | Quadrature decoder 0 |               |
| 0x40033000   | APPLICATION                 | QUEC       | QDEC0 : NS | 03             | IVA          | Quadrature decoder o |               |
| 0x50034000   | A DDI ICATION               | LODEC      | QDEC1:S    | LIC            | NA           | Quadrature decoder 1 |               |
| 0x40034000   | APPLICATION QDI<br>40034000 |            | QDEC1 : NS | US             | NA           | Quadrature decoder 1 |               |

Table 116: Instances

| Register             | Offset | Security | Description                                                                     |
|----------------------|--------|----------|---------------------------------------------------------------------------------|
| TASKS_START          | 0x000  |          | Task starting the quadrature decoder                                            |
| TASKS_STOP           | 0x004  |          | Task stopping the quadrature decoder                                            |
| TASKS_READCLRACC     | 0x008  |          | Read and clear ACC and ACCDBL                                                   |
| TASKS_RDCLRACC       | 0x00C  |          | Read and clear ACC                                                              |
| TASKS_RDCLRDBL       | 0x010  |          | Read and clear ACCDBL                                                           |
| SUBSCRIBE_START      | 0x080  |          | Subscribe configuration for task START                                          |
| SUBSCRIBE_STOP       | 0x084  |          | Subscribe configuration for task STOP                                           |
| SUBSCRIBE_READCLRACC | 0x088  |          | Subscribe configuration for task READCLRACC                                     |
| SUBSCRIBE_RDCLRACC   | 0x08C  |          | Subscribe configuration for task RDCLRACC                                       |
| SUBSCRIBE_RDCLRDBL   | 0x090  |          | Subscribe configuration for task RDCLRDBL                                       |
| EVENTS_SAMPLERDY     | 0x100  |          | Event being generated for every new sample value written to the SAMPLE register |
| EVENTS_REPORTRDY     | 0x104  |          | Non-null report ready                                                           |
| EVENTS_ACCOF         | 0x108  |          | ACC or ACCDBL register overflow                                                 |
| EVENTS_DBLRDY        | 0x10C  |          | Double displacement(s) detected                                                 |
| EVENTS_STOPPED       | 0x110  |          | QDEC has been stopped                                                           |
| PUBLISH_SAMPLERDY    | 0x180  |          | Publish configuration for event SAMPLERDY                                       |
| PUBLISH_REPORTRDY    | 0x184  |          | Publish configuration for event REPORTRDY                                       |
| PUBLISH_ACCOF        | 0x188  |          | Publish configuration for event ACCOF                                           |
| PUBLISH_DBLRDY       | 0x18C  |          | Publish configuration for event DBLRDY                                          |
| PUBLISH_STOPPED      | 0x190  |          | Publish configuration for event STOPPED                                         |
| SHORTS               | 0x200  |          | Shortcuts between local events and tasks                                        |
| INTENSET             | 0x304  |          | Enable interrupt                                                                |
| INTENCLR             | 0x308  |          | Disable interrupt                                                               |
| ENABLE               | 0x500  |          | Enable the quadrature decoder                                                   |
| LEDPOL               | 0x504  |          | LED output pin polarity                                                         |



| Register   | Offset | Security | Description                                                              |
|------------|--------|----------|--------------------------------------------------------------------------|
| SAMPLEPER  | 0x508  |          | Sample period                                                            |
| SAMPLE     | 0x50C  |          | Motion sample value                                                      |
| REPORTPER  | 0x510  |          | Number of samples to be taken before REPORTRDY and DBLRDY events can be  |
|            |        |          | generated                                                                |
| ACC        | 0x514  |          | Register accumulating the valid transitions                              |
| ACCREAD    | 0x518  |          | Snapshot of the ACC register, updated by the READCLRACC or RDCLRACC task |
| PSEL.LED   | 0x51C  |          | Pin select for LED signal                                                |
| PSEL.A     | 0x520  |          | Pin select for A signal                                                  |
| PSEL.B     | 0x524  |          | Pin select for B signal                                                  |
| DBFEN      | 0x528  |          | Enable input debounce filters                                            |
| LEDPRE     | 0x540  |          | Time period the LED is switched ON prior to sampling                     |
| ACCDBL     | 0x544  |          | Register accumulating the number of detected double transitions          |
| ACCDBLREAD | 0x548  |          | Snapshot of the ACCDBL, updated by the READCLRACC or RDCLRDBL task       |

Table 117: Register overview

### 7.24.7.1 TASKS\_START

Address offset: 0x000

Task starting the quadrature decoder

When started, the SAMPLE register will be continuously updated at the rate given in the SAMPLEPER register.



#### 7.24.7.2 TASKS STOP

Address offset: 0x004

Task stopping the quadrature decoder



### 7.24.7.3 TASKS\_READCLRACC

Address offset: 0x008

Read and clear ACC and ACCDBL

Task transferring the content of ACC to ACCREAD and the content of ACCDBL to ACCDBLREAD, and then clearing the ACC and ACCDBL registers. These read-and-clear operations will be done atomically.





### 7.24.7.4 TASKS\_RDCLRACC

Address offset: 0x00C Read and clear ACC

Task transferring the content of ACC to ACCREAD, and then clearing the ACC register. This read-and-clear operation will be done atomically.



### 7.24.7.5 TASKS RDCLRDBL

Address offset: 0x010

Read and clear ACCDBL

Task transferring the content of ACCDBL to ACCDBLREAD, and then clearing the ACCDBL register. This readand-clear operation will be done atomically.



#### 7.24.7.6 SUBSCRIBE START

Address offset: 0x080

Subscribe configuration for task START

NORDIC\*

When started, the SAMPLE register will be continuously updated at the rate given in the SAMPLEPER register.



#### 7.24.7.7 SUBSCRIBE\_STOP

Address offset: 0x084

Subscribe configuration for task STOP



### 7.24.7.8 SUBSCRIBE READCLRACC

Address offset: 0x088

Subscribe configuration for task READCLRACC

Task transferring the content of ACC to ACCREAD and the content of ACCDBL to ACCDBLREAD, and then clearing the ACC and ACCDBL registers. These read-and-clear operations will be done atomically.



#### 7.24.7.9 SUBSCRIBE RDCLRACC

Address offset: 0x08C

Subscribe configuration for task RDCLRACC

Task transferring the content of ACC to ACCREAD, and then clearing the ACC register. This read-and-clear operation will be done atomically.





#### 7.24.7.10 SUBSCRIBE RDCLRDBL

Address offset: 0x090

Subscribe configuration for task RDCLRDBL

Task transferring the content of ACCDBL to ACCDBLREAD, and then clearing the ACCDBL register. This readand-clear operation will be done atomically.



#### 7.24.7.11 EVENTS SAMPLERDY

Address offset: 0x100

Event being generated for every new sample value written to the SAMPLE register



### 7.24.7.12 EVENTS\_REPORTRDY

Address offset: 0x104 Non-null report ready

Event generated when REPORTPER number of samples has been accumulated in the ACC register and the content of the ACC register is not equal to 0. (Thus, this event is only generated if a motion is detected since the previous clearing of the ACC register).





#### 7.24.7.13 EVENTS ACCOF

Address offset: 0x108

ACC or ACCDBL register overflow



#### **7.24.7.14 EVENTS DBLRDY**

Address offset: 0x10C

Double displacement(s) detected

Event generated when REPORTPER number of samples has been accumulated and the content of the ACCDBL register is not equal to 0. (Thus, this event is only generated if a double transition is detected since the previous clearing of the ACCDBL register).



#### 7.24.7.15 EVENTS STOPPED

Address offset: 0x110

QDEC has been stopped





### 7.24.7.16 PUBLISH\_SAMPLERDY

Address offset: 0x180

Publish configuration for event SAMPLERDY



### 7.24.7.17 PUBLISH\_REPORTRDY

Address offset: 0x184

Publish configuration for event REPORTRDY

Event generated when REPORTPER number of samples has been accumulated in the ACC register and the content of the ACC register is not equal to 0. (Thus, this event is only generated if a motion is detected since the previous clearing of the ACC register).



### 7.24.7.18 PUBLISH ACCOF

Address offset: 0x188

Publish configuration for event ACCOF





### 7.24.7.19 PUBLISH\_DBLRDY

Address offset: 0x18C

Publish configuration for event DBLRDY

Event generated when REPORTPER number of samples has been accumulated and the content of the ACCDBL register is not equal to 0. (Thus, this event is only generated if a double transition is detected since the previous clearing of the ACCDBL register).

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event DBLRDY will publish to.                 |
| В     | RW      | EN    |          |                         |                                                                 |
| _     |         | LIN   |          |                         |                                                                 |
| _     |         | LIV   | Disabled | 0                       | Disable publishing                                              |

### 7.24.7.20 PUBLISH STOPPED

Address offset: 0x190

Publish configuration for event STOPPED



#### 7.24.7.21 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Α     | RW       | REPORTRDY_RE | ADCLRACC |                  | Shortcut between event REPORTRDY and task                            |
|-------|----------|--------------|----------|------------------|----------------------------------------------------------------------|
| ID    |          |              |          |                  |                                                                      |
| Res   | et 0x000 | 00000        |          | 0 0 0 0 0        | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                            |
| ID    |          |              |          |                  | G F E D C B /                                                        |
| Bit r | number   |              |          | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |

Shortcut between event REPORTRDY and task

READCLRACC



| Reset bx 00000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |                   |          |    |     |      |      |      |      |      |      |       |      |      |     |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|-------------------|----------|----|-----|------|------|------|------|------|------|-------|------|------|-----|-----|------|------|-----|-----|------|------|-----|------|-----|-----|----|-----|-----|---|---|
| Reset bx 00000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Bit n | umber   |                   |          | 31 | 130 | 29 2 | 8 27 | 26 2 | 25 2 | 24 2 | 23 2 | 22 2  | 1 20 | 0 19 | 18  | 17  | 16 : | 15 1 | 4 1 | 3 1 | 2 1: | 1 10 | 9   | 8    | 7   | 6   | 5  | 4 3 | 3 2 | 1 | 0 |
| Description   Disabled   Disabl | ID    |         |                   |          |    |     |      |      |      |      |      |      |       |      |      |     |     |      |      |     |     |      |      |     |      |     | G   | F  | E [ | ) C | В | Α |
| Disabled 0 Disable shortcut Enabled 1 Enable shortcut  B RW SAMPLERDY_STOP Shortcut between event SAMPLERDY and task STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut  C RW REPORTRDY_RDCLRACC Shortcut between event REPORTRDY and task RDCLRACC Disabled 0 Disable shortcut Enabled 1 Enables shortcut  D RW REPORTRDY_STOP Shortcut between event REPORTRDY and task STOP Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_RDCLRDBL Shortcut Disabled 0 Disable shortcut Enabled 1 Enable shortcut  F RW DBLRDY_STOP Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut  F RW DBLRDY_STOP Shortcut between event DBLRDY and task STOP Disabled 0 Disable shortcut  F RW DBLRDY_STOP Shortcut between event DBLRDY and task STOP Disabled 0 Disable shortcut  Enable shortcut Enable shortcut Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Rese  | t 0x000 | 00000             |          | 0  | 0   | 0 0  | 0    | 0    | 0    | 0 (  | 0    | 0 0   | 0    | 0    | 0   | 0   | 0    | 0    | 0 ( | ) ( | 0    | 0    | 0   | 0    | 0   | 0   | 0  | 0 ( | 0   | 0 | 0 |
| Enabled 1 Enable shortcut  B RW SAMPLERDY_STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enable shortcut  Enable shortcut  C RW REPORTRDY_RDCLRACC Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  D RW REPORTRDY_STOP Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enable shortcut  Enable shortcut  Enable shortcut  Enable shortcut  Enable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut  Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |                   |          |    |     |      |      |      |      |      |      |       |      |      |     |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| B RW SAMPLERDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  C RW REPORTRDY_RDCLRACC  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enable shortcut  Enable shortcut  Enable shortcut  D RW REPORTRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_RDCLRDBL  Disabled 0 Disable shortcut  Enable shortcut  Enable shortcut  Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |                   | Disabled | 0  |     |      |      |      |      | С    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut Enabled 1 Enable shortcut  REPORTRDY_RDCLRACC Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  RW REPORTRDY_STOP Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enable shortcut  Enable shortcut  Enable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut  Enable shortcut  FRW DBLRDY_STOP Enabled 1 Enable shortcut  For able shortcut  Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |                   | Enabled  | 1  |     |      |      |      |      | E    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut  C RW REPORTRDY_RDCLRACC  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  D RW REPORTRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_RDCLRDBL  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enable shortcut  Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | В     | RW      | SAMPLERDY_STOP    |          |    |     |      |      |      |      | S    | Sho  | ortcu | ıt b | etw  | een | eve | ent  | SAI  | MPI | .ER | DY   | and  | tas | k S1 | ГОР | )   |    |     |     |   |   |
| C RW REPORTRDY_RDCLRACC  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  D RW REPORTRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Shortcut between event REPORTRDY and task STOP  Disable shortcut  Enable shortcut  Enable shortcut  F RW DBLRDY_RDCLRDBL  Disabled 0 Disable shortcut  Enable shortcut  Shortcut between event DBLRDY and task RDCLRDBL  Disabled 1 Enable shortcut  F Shortcut between event DBLRDY and task STOP  Disabled 0 Disable shortcut  Enable shortcut  Enable shortcut  Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |                   | Disabled | 0  |     |      |      |      |      | С    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  D RW REPORTRDY_STOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |                   | Enabled  | 1  |     |      |      |      |      | E    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut  D RW REPORTRDY_STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 0 Disable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_STOP Disabled 0 Disable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 1 Enable shortcut  Shortcut between event DBLRDY and task STOP Disabled 0 Disable shortcut  Enable shortcut Enable shortcut Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | С     | RW      | REPORTRDY_RDCLRAC | С        |    |     |      |      |      |      | S    | Sho  | rtcu  | ıt b | etw  | een | eve | ent  | REI  | POR | TR  | DY a | and  | tas | k RI | DCL | .RA | CC |     |     |   |   |
| D RW REPORTRDY_STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut  Enabled 0 Disable shortcut  Enabled 0 Disable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  F RW DBLRDY_STOP Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Shortcut between event DBLRDY and task RDCLRDBL Disabled 1 Enable shortcut  Enable shortcut Enable shortcut Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |                   | Disabled | 0  |     |      |      |      |      | С    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  ENW DBLRDY_RDCLRDBL Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  FRW DBLRDY_STOP Disabled 0 Disable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut  Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |                   | Enabled  | 1  |     |      |      |      |      | Е    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut  E RW DBLRDY_RDCLRDBL Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut Enabled 1 Enable shortcut  F RW DBLRDY_STOP Shortcut between event DBLRDY and task STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | D     | RW      | REPORTRDY_STOP    |          |    |     |      |      |      |      | S    | Sho  | ortcu | ıt b | etw  | een | eve | ent  | REI  | POR | TR  | DY a | and  | tas | k ST | ОР  | )   |    |     |     |   |   |
| Shortcut between event DBLRDY and task RDCLRDBL Disabled 0 Disable shortcut Enabled 1 Enable shortcut  F RW DBLRDY_STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut Enabled 1 Enable shortcut Enabled 1 Enable shortcut Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |                   | Disabled | 0  |     |      |      |      |      | С    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut Enabled 1 Enable shortcut  F RW DBLRDY_STOP Disabled 0 Disable shortcut  Shortcut between event DBLRDY and task STOP Disabled 0 Disable shortcut Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |                   | Enabled  | 1  |     |      |      |      |      | E    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut  F RW DBLRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Ε     | RW      | DBLRDY_RDCLRDBL   |          |    |     |      |      |      |      | S    | Sho  | rtcu  | ıt b | etw  | een | eve | ent  | DB   | LRD | Y a | nd   | task | RD  | CLF  | RDE | BL  |    |     |     |   |   |
| F RW DBLRDY_STOP  Disabled 0 Disable shortcut  Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |                   | Disabled | 0  |     |      |      |      |      | С    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |         |                   | Enabled  | 1  |     |      |      |      |      | E    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | F     | RW      | DBLRDY_STOP       |          |    |     |      |      |      |      | S    | Sho  | ortcu | ıt b | etw  | een | eve | ent  | DB   | LRD | Y a | nd   | task | ST  | OP   |     |     |    |     |     |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |                   | Disabled | 0  |     |      |      |      |      | C    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| G RW SAMPLERDY READCLRACC Shortcut between event SAMPLERDY and task                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |         |                   | Enabled  | 1  |     |      |      |      |      | E    | Ena  | ble   | shc  | rtcı | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| <del>-</del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | G     | RW      | SAMPLERDY_READCLR | ACC      |    |     |      |      |      |      | S    | Sho  | ortcu | ıt b | etw  | een | eve | ent  | SAI  | MPI | .ER | DY   | and  | tas | k    |     |     |    |     |     |   |   |
| READCLRACC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |                   |          |    |     |      |      |      |      | F    | REA  | ADCI  | LRA  | CC   |     |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Disabled 0 Disable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |                   | Disabled | 0  |     |      |      |      |      | 0    | Disa | able  | sh   | ortc | ut  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |
| Enabled 1 Enable shortcut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |                   | Enabled  | 1  |     |      |      |      |      | Е    | Ena  | ble   | shc  | rtcı | ıt  |     |      |      |     |     |      |      |     |      |     |     |    |     |     |   |   |

# 7.24.7.22 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | number   |           |          | 31 | 30 | 29 2 | 28 2 | 27 2 | 6 25 | 5 24 | 23  | 22    | 21   | 20   | 19  | 18 1 | 7 1  | 6 1  | 5 14 | 13   | 12   | 11 :  | 10 9 | 9 8   | 7    | 6   | 5    | 4  | 3 2 | 2 1 | 0   |
|-------|----------|-----------|----------|----|----|------|------|------|------|------|-----|-------|------|------|-----|------|------|------|------|------|------|-------|------|-------|------|-----|------|----|-----|-----|-----|
| ID    |          |           |          |    |    |      |      |      |      |      |     |       |      |      |     |      |      |      |      |      |      |       |      |       |      |     |      | Ε  | D ( | C E | 3 A |
| Rese  | et 0x000 | 00000     |          | 0  | 0  | 0    | 0    | 0 0  | 0 0  | 0    | 0   | 0     | 0    | 0    | 0   | 0    | 0 (  | ) (  | 0    | 0    | 0    | 0     | 0 (  | 0 0   | 0    | 0   | 0    | 0  | 0 ( | ) ( | 0   |
| ID    |          |           |          |    |    |      |      |      |      |      |     |       |      |      |     |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
| Α     | RW       | SAMPLERDY |          |    |    |      |      |      |      |      | W   | rite  | '1'  | to   | ena | ble  | int  | errı | ıpt  | for  | eve  | nt S  | AM   | PLEI  | RDY  | ,   |      |    |     |     |     |
|       |          |           | Set      | 1  |    |      |      |      |      |      | En  | nabl  | le   |      |     |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Disabled | 0  |    |      |      |      |      |      | Re  | ad    | : Di | sab  | led |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Enabled  | 1  |    |      |      |      |      |      | Re  | ad    | : En | abl  | ed  |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
| В     | RW       | REPORTRDY |          |    |    |      |      |      |      |      | W   | rite  | '1'  | to   | ena | ble  | int  | errı | ıpt  | for  | eve  | nt R  | EPC  | ORTE  | RDY  |     |      |    |     |     |     |
|       |          |           |          |    |    |      |      |      |      |      | Ev  | ent   | ge   | ner  | ate | d w  | her  | n RE | PO   | RTP  | ER   | num   | ıbeı | of    | sam  | ple | :S   |    |     |     |     |
|       |          |           |          |    |    |      |      |      |      |      | ha  | ıs b  | eer  | n ac | cun | nula | itec | l in | the  | AC   | C re | gist  | er a | and t | the  | cor | nter | nt |     |     |     |
|       |          |           |          |    |    |      |      |      |      |      | of  | the   | e AC | n DC | egi | ster | is r | not  | equ  | al t | о 0  | . (Th | ıus, | this  | eve  | ent | is   |    |     |     |     |
|       |          |           |          |    |    |      |      |      |      |      | on  | nly g | gen  | era  | ted | if a | mc   | tio  | n is | det  | ect  | ed s  | ince | e the | e pr | evi | ous  |    |     |     |     |
|       |          |           |          |    |    |      |      |      |      |      | cle | eari  | ng   | of t | he  | ACC  | re   | gist | er). |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Set      | 1  |    |      |      |      |      |      | En  | nabl  | le   |      |     |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Disabled | 0  |    |      |      |      |      |      | Re  | ad:   | : Di | sab  | led |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Enabled  | 1  |    |      |      |      |      |      | Re  | ad    | : En | abl  | ed  |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
| С     | RW       | ACCOF     |          |    |    |      |      |      |      |      | W   | rite  | '1'  | to   | ena | ble  | int  | errı | ıpt  | for  | eve  | nt A  | CCC  | OF    |      |     |      |    |     |     |     |
|       |          |           | Set      | 1  |    |      |      |      |      |      | En  | nabl  | le   |      |     |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Disabled | 0  |    |      |      |      |      |      | Re  | ead:  | : Di | sab  | led |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |
|       |          |           | Enabled  | 1  |    |      |      |      |      |      | Re  | ad:   | : En | abl  | ed  |      |      |      |      |      |      |       |      |       |      |     |      |    |     |     |     |



| Bit n | umber    |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |          |                         | E D C B A                                                       |
| Rese  | et 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |          |                         | Description                                                     |
| D     | RW       | DBLRDY  |          |                         | Write '1' to enable interrupt for event DBLRDY                  |
|       |          |         |          |                         | Event generated when REPORTPER number of samples has            |
|       |          |         |          |                         | been accumulated and the content of the ACCDBL register         |
|       |          |         |          |                         | is not equal to 0. (Thus, this event is only generated if a     |
|       |          |         |          |                         | double transition is detected since the previous clearing of    |
|       |          |         |          |                         | the ACCDBL register).                                           |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| E     | RW       | STOPPED |          |                         | Write '1' to enable interrupt for event STOPPED                 |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |

# 7.24.7.23 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber   |           |          | 31 | .30 | 29 2 | 28 2 | 27 2 | 6 2 | 5 24 | 4 2 | 3 22  | 2 2: | 1 2  | 0 1  | 9 1  | 18 :              | L7 1 | .6   | 15   | 14   | 13    | 12   | 11   | 10   | 9    | 8    | 7   | 6 5   | 5 4  | 3 | 2 | 1 | 0 |
|-------|---------|-----------|----------|----|-----|------|------|------|-----|------|-----|-------|------|------|------|------|-------------------|------|------|------|------|-------|------|------|------|------|------|-----|-------|------|---|---|---|---|
| ID    |         |           |          |    |     |      |      |      |     |      |     |       |      |      |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       | E    | D | С | В | Α |
| Rese  | t 0x000 | 00000     |          | 0  | 0   | 0    | 0    | 0 0  | 0   | 0    | ) ( | 0 0   | 0    | 0 (  | ) (  | ) ו  | 0                 | 0    | 0    | 0    | 0    | 0     | 0    | 0    | 0    | 0    | 0    | 0   | 0 0   | ) (  | 0 | 0 | 0 | 0 |
| ID    |         |           |          |    |     |      |      |      |     |      |     |       |      |      |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
| Α     | RW      | SAMPLERDY |          |    |     |      |      |      |     |      | ٧   | Vrite | e '1 | 1' t | o d  | isa  | ble               | int  | er   | rup  | t f  | or e  | eve  | nt   | SAN  | ΛPI  | ERI  | ΟY  |       |      |   |   |   | _ |
|       |         |           | Clear    | 1  |     |      |      |      |     |      | D   | Disab | ole  | 2    |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Disabled | 0  |     |      |      |      |     |      | R   | lead  | l: D | Disa | ble  | ed   |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Enabled  | 1  |     |      |      |      |     |      | R   | lead  | l: E | na   | ble  | d    |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
| В     | RW      | REPORTRDY |          |    |     |      |      |      |     |      | ٧   | Vrite | e '1 | 1' t | o d  | isa  | ble               | int  | er   | rup  | t f  | or e  | eve  | nt   | REP  | OF   | TRE  | Υ   |       |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | Ε   | ven   | t g  | gen  | era  | tec  | d w               | her  | ո R  | EΡ   | OR   | TPE   | ER i | nur  | nbe  | er c | f sa | mp  | les   |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | h   | as b  | oee  | en   | асс  | um   | nula              | ateo | d ir | ı th | ie / | ACC   | c re | gis  | ter  | an   | d th | e c | onte  | ent  |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | 0   | f th  | e A  | AC(  | c re | gis  | ter               | isı  | no   | e    | qua  | al to | 0.   | . (T | hus  | , th | is e | vei | nt is |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | 0   | nly   | gei  | ne   | rate | ed i | if a              | mo   | otio | on   | is c | lete  | ect  | ed   | sinc | e t  | he p | ore | viou  | IS   |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | С   | lear  | ing  | g o  | f th | e A  | ACC               | re   | gis  | ter  | ).   |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Clear    | 1  |     |      |      |      |     |      | D   | Disab | ole  |      |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Disabled | 0  |     |      |      |      |     |      | R   | lead  | l: D | Disa | ble  | ed   |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Enabled  | 1  |     |      |      |      |     |      | R   | lead  | l: E | na   | ble  | d    |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
| С     | RW      | ACCOF     |          |    |     |      |      |      |     |      | ٧   | Vrite | e '1 | 1' t | o d  | isa  | ble               | int  | er   | rup  | t f  | or e  | eve  | nt   | ACC  | OF   |      |     |       |      |   |   |   |   |
|       |         |           | Clear    | 1  |     |      |      |      |     |      | D   | Disak | ole  | 9    |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Disabled | 0  |     |      |      |      |     |      | R   | lead  | l: D | Disa | ble  | ed   |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Enabled  | 1  |     |      |      |      |     |      | R   | lead  | l: E | na   | ble  | d    |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
| D     | RW      | DBLRDY    |          |    |     |      |      |      |     |      | ٧   | Vrite | e '1 | 1' t | o d  | isa  | ble               | int  | er   | rup  | t f  | or e  | eve  | nt   | DBL  | .RD  | Υ    |     |       |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | Е   | ven   | t g  | gen  | era  | tec  | w b               | her  | n R  | EΡ   | OR   | TPE   | ER i | nur  | nbe  | er c | f sa | mp  | les   | has  |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | b   | een   | ac   | ccu  | mι   | ılat | ed                | an   | d t  | he   | со   | nte   | nt   | of t | he   | AC   | CDB  | Lr  | egis  | ter  |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | is  | s no  | t e  | qu   | al t | o C  | ). ( <sup>-</sup> | Γhu  | s, t | this | e e  | ven   | t is | or   | ly g | gen  | erat | ed  | if a  |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | d   | loub  | ole  | tra  | nsi  | tio  | n i               | s de | ete  | cte  | d s  | sinc  | e t  | he   | pre  | vic  | us c | lea | aring | g of |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      | tl  | he A  | ACC  | CDI  | 3L r | eg   | iste              | er). |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Clear    | 1  |     |      |      |      |     |      | D   | Disak | ole  | 2    |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           | Disabled | 0  |     |      |      |      |     |      | R   | lead  | l: D | Disa | ble  | ed   |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |
|       |         |           |          |    |     |      |      |      |     |      |     |       |      |      |      |      |                   |      |      |      |      |       |      |      |      |      |      |     |       |      |   |   |   |   |



| Bit n | umber   |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |         |          |                         | E D C B A                                                       |
| Rese  | t 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |         |          |                         | Description                                                     |
|       |         |         | Enabled  | 1                       | Read: Enabled                                                   |
| Е     | RW      | STOPPED |          |                         | Write '1' to disable interrupt for event STOPPED                |
|       |         |         | Clear    | 1                       | Disable                                                         |
|       |         |         | Disabled | 0                       | Read: Disabled                                                  |
|       |         |         | Enabled  | 1                       | Read: Enabled                                                   |

# 7.24.7.24 ENABLE

Address offset: 0x500

Enable the quadrature decoder

| Bit nu | ımber |        |          | 31 30 29 28 27 | 26 25 | 24 2 | 23 22 | 21   | 20 1  | .9 18 | 3 17 | 16 1 | .5 1 | 4 13 | 12    | 11 1 | .0 9  | 8     | 7    | 6    | 5  | 4 3 | 2 | 1 | 0 |
|--------|-------|--------|----------|----------------|-------|------|-------|------|-------|-------|------|------|------|------|-------|------|-------|-------|------|------|----|-----|---|---|---|
| ID     |       |        |          |                |       |      |       |      |       |       |      |      |      |      |       |      |       |       |      |      |    |     |   |   | Α |
| Reset  | 0x000 | 00000  |          | 0 0 0 0 0      | 0 0   | 0    | 0 0   | 0    | 0 (   | 0 0   | 0    | 0    | 0 (  | 0    | 0     | 0    | 0 0   | 0     | 0    | 0    | 0  | 0 ( | 0 | 0 | 0 |
| ID     |       |        |          |                |       |      |       |      |       |       |      |      |      |      |       |      |       |       |      |      |    |     |   |   |   |
| Α      | RW    | ENABLE |          |                |       | ı    | Enabl | le o | r dis | able  | the  | qua  | dra  | ture | de    | cod  | er    |       |      |      |    |     |   |   |   |
|        |       |        |          |                |       | ,    | Wher  | n er | nable | d th  | ne d | ecoc | ler  | oins | wil   | l be | activ | ve. ۱ | Wh   | en   |    |     |   |   |   |
|        |       |        |          |                |       | (    | disab | led  | the   | qua   | drat | ure  | dec  | odei | r pii | ns a | e no  | ot a  | ctiv | e ar | nd |     |   |   |   |
|        |       |        |          |                |       | (    | can b | e u  | sed a | as G  | PIO  |      |      |      |       |      |       |       |      |      |    |     |   |   |   |
|        |       |        | Disabled | 0              |       | ı    | Disab | le   |       |       |      |      |      |      |       |      |       |       |      |      |    |     |   |   |   |
|        |       |        | Enabled  | 1              |       | 1    | Enabl | le   |       |       |      |      |      |      |       |      |       |       |      |      |    |     |   |   |   |

### 7.24.7.25 LEDPOL

Address offset: 0x504 LED output pin polarity

| Bit r | number   |        |            | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|------------|----------------------|------------------------------------------------------------------|
| ID    |          |        |            |                      | А                                                                |
| Res   | et 0x000 | 00000  |            | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |          |        |            |                      | Description                                                      |
| Α     | RW       | LEDPOL |            |                      | LED output pin polarity                                          |
|       |          |        | ActiveLow  | 0                    | Led active on output pin low                                     |
|       |          |        | ActiveHigh | 1                    | Led active on output pin high                                    |

# 7.24.7.26 SAMPLEPER

Address offset: 0x508

Sample period

| Bit n | umber   |           |       | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|-------|------------------|-----------------------------------------------------------------------|
| ID    |         |           |       |                  | ААА                                                                   |
| Rese  | t 0x000 | 00000     |       | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
|       |         |           |       |                  |                                                                       |
| Α     | RW      | SAMPLEPER |       |                  | Sample period. The SAMPLE register will be updated for                |
|       |         |           |       |                  | every new sample                                                      |
|       |         |           | 128us | 0                | 128 μs                                                                |







#### 7.24.7.27 SAMPLE

Address offset: 0x50C Motion sample value



transition.

#### **7.24.7.28 REPORTPER**

Address offset: 0x510

Number of samples to be taken before REPORTRDY and DBLRDY events can be generated



| Bit number       |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|---------|------------------------|-----------------------------------------------------------------|
| ID               |         |                        | АААА                                                            |
| Reset 0x00000000 |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field     |         |                        | Description                                                     |
| A RW REPORTPER   |         |                        | Specifies the number of samples to be accumulated in the        |
|                  |         |                        | ACC register before the REPORTRDY and DBLRDY events             |
|                  |         |                        | can be generated.                                               |
|                  |         |                        | The report period in [μs] is given as: RPUS = SP * RP           |
|                  |         |                        | Where RPUS is the report period in [ $\mu$ s/report], SP is the |
|                  |         |                        | sample period in [µs/sample] specified in SAMPLEPER, and        |
|                  |         |                        | RP is the report period in [samples/report] specified in        |
|                  |         |                        | REPORTPER.                                                      |
|                  | 10Smpl  | 0                      | 10 samples/report                                               |
|                  | 40Smpl  | 1                      | 40 samples/report                                               |
|                  | 80Smpl  | 2                      | 80 samples/report                                               |
|                  | 120Smpl | 3                      | 120 samples/report                                              |
|                  | 160Smpl | 4                      | 160 samples/report                                              |
|                  | 200Smpl | 5                      | 200 samples/report                                              |
|                  | 240Smpl | 6                      | 240 samples/report                                              |
|                  | 280Smpl | 7                      | 280 samples/report                                              |
|                  | 1Smpl   | 8                      | 1 sample/report                                                 |

### 7.24.7.29 ACC

Address offset: 0x514

Register accumulating the valid transitions

| Rit n  | umber   |       |  |          |  | 31  | 30 2 | 29.2 | 8 27 | 26 | 25 | 24 | 23.   | י כי  | 21 2  | n 19   | 12   | 17    | 16    | 15 1  | 11    | 2 1 2 | 11     | 10    | a    | Ω.    | 7 6  | 5 5   | 1   | 3  | 2 | 1 | 0 |
|--------|---------|-------|--|----------|--|-----|------|------|------|----|----|----|-------|-------|-------|--------|------|-------|-------|-------|-------|-------|--------|-------|------|-------|------|-------|-----|----|---|---|---|
| DIC II | annoci  |       |  |          |  |     |      |      |      |    |    |    |       |       |       |        |      |       |       |       |       |       |        |       |      |       | _    |       |     |    | _ | _ |   |
| ID     |         |       |  |          |  | Α   | Α ,  | A A  | 4 A  | Α  | Α  | Α  | Α.    | A A   | A A   | 4 A    | Α    | Α     | Α     | Α.    | 4 Δ   | 4 A   | Α      | Α.    | A    | A A   | Α Α  | . Δ   | A   | Α. | Α | Α | Α |
| Rese   | t 0x000 | 00000 |  |          |  | 0   | 0    | 0 (  | 0    | 0  | 0  | 0  | 0     | 0 (   | 0 0   | 0      | 0    | 0     | 0     | 0     | 0 0   | 0     | 0      | 0     | 0    | 0 (   | 0    | 0     | 0   | 0  | 0 | 0 | 0 |
| ID     |         |       |  | Value ID |  |     |      |      |      |    |    |    | Des   |       |       |        |      |       |       |       |       |       |        |       |      |       |      |       |     |    |   |   |   |
| Α      | R       | ACC   |  |          |  | [-1 | 024  | 10   | 23]  |    |    |    | Reg   | iste  | er ac | ccun   | nula | atin  | g al  | II va | lid s | sam   | ples   | (no   | t d  | oub   | le   |       |     |    |   |   | _ |
|        |         |       |  |          |  |     |      |      |      |    |    |    | trar  | ısiti | ion)  | rea    | d fr | om    | the   | e SA  | MP    | LE r  | egis   | er.   |      |       |      |       |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | Dοι   | ıble  | tra   | nsit   | ions | s ( S | SAN   | /IPLI | E = 2 | 2 ) w | vill n | ot b  | ne a | accu  | mu   | ılatı | ed  |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    |       |       |       |        |      | •     |       |       |       |       |        |       |      |       |      |       |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | ın tı | nis i | regi  | ister. | . Ih | e va  | alue  | e is  | a 32  | 2 bit | 2's    | com   | nple | eme   | nt v | valu  | ıe. |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | If a  | san   | nple  | e tha  | at w | oul   | d c   | aus   | e th  | is re | gist   | er to | 0 0  | ver   | low  | or    |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | und   | lerfl | low   | is re  | ecei | ivec  | l, th | he s  | amp   | ole v | will b | e i   | gno  | red   | an   | d     |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | an d  | ove   | rflo  | w ev   | /ent | t ( A | CC    | OF ]  | wil   | ll be | gen    | era   | ted  | l. Th | ie A | CC    |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | regi  | ste   | r is  | clea   | red  | by    | trig  | gger  | ing   | the   | REA    | DCI   | LRA  | CC    | or t | he    |     |    |   |   |   |
|        |         |       |  |          |  |     |      |      |      |    |    |    | RDO   | CLRA  | ACC   | tas    | k.   |       |       |       |       |       |        |       |      |       |      |       |     |    |   |   |   |

### 7.24.7.30 ACCREAD

Address offset: 0x518

Snapshot of the ACC register, updated by the READCLRACC or RDCLRACC task



| ID R/W Field     |             |                  |                    |                     |              |           |
|------------------|-------------|------------------|--------------------|---------------------|--------------|-----------|
|                  |             |                  | Description        |                     |              |           |
| Reset 0x00000000 | 0 0 0 0     | 00000            | 0000000            | 0 0 0 0 0 0         | 0 0 0 0 0 0  | 0 0 0 0 0 |
| ID               | АААА        | A A A A A        | 4 A A A A A        | A A A A A A         | A A A A A    | AAAAA     |
| Bit number       | 31 30 29 28 | 8 27 26 25 24 23 | 3 22 21 20 19 18 1 | 7 16 15 14 13 12 11 | 10 9 8 7 6 5 | 4 3 2 1 0 |

The ACCREAD register is updated when the READCLRACC or RDCLRACC task is triggered.

### 7.24.7.31 PSEL.LED

Address offset: 0x51C

Pin select for LED signal

| Bit r | umber    |         |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |              | С                       | ВАААА                                                           |
| Rese  | et OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |          |         |              |                         |                                                                 |
| Α     | RW       | PIN     |              | [031]                   | Pin number                                                      |
| В     | RW       | PORT    |              | [01]                    | Port number                                                     |
| С     | RW       | CONNECT |              |                         | Connection                                                      |
|       |          |         | Disconnected | 1                       | Disconnect                                                      |
|       |          |         | Connected    | 0                       | Connect                                                         |

# 7.24.7.32 PSEL.A

Address offset: 0x520 Pin select for A signal

| Bit n | umber   |         |              | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|-------------------------|---------------------------------------------------------------|
| ID    |         |         |              | С                       | ваааа                                                         |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | $1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;1\;$   |
| ID    |         |         |              |                         | Description                                                   |
| Α     | RW      | PIN     |              | [031]                   | Pin number                                                    |
| В     | RW      | PORT    |              | [01]                    | Port number                                                   |
| С     | RW      | CONNECT |              |                         | Connection                                                    |
|       |         |         | Disconnected | 1                       | Disconnect                                                    |
|       |         |         | Connected    | 0                       | Connect                                                       |

### 7.24.7.33 PSEL.B

Address offset: 0x524 Pin select for B signal





#### 7.24.7.34 DBFEN

Address offset: 0x528

Enable input debounce filters



#### 7.24.7.35 LEDPRE

Address offset: 0x540

Time period the LED is switched ON prior to sampling



#### 7.24.7.36 ACCDBL

Address offset: 0x544

Register accumulating the number of detected double transitions





#### **7.24.7.37 ACCDBLREAD**

Address offset: 0x548

Snapshot of the ACCDBL, updated by the READCLRACC or RDCLRDBL task



# 7.24.8 Electrical specification

## 7.24.8.1 QDEC Electrical Specification

| Symbol              | Description                                           | Min. | Тур. | Max.   | Units |
|---------------------|-------------------------------------------------------|------|------|--------|-------|
| t <sub>SAMPLE</sub> | Time between sampling signals from quadrature decoder | 128  |      | 131072 | μs    |
| t <sub>LED</sub>    | Time from LED is turned on to signals are sampled     | 0    |      | 511    | μs    |

# 7.25 QSPI — Quad serial peripheral interface

The QSPI peripheral provides support for communicating with an external flash memory device using SPI.

The main features for the QSPI peripheral are:

- Single/dual/quad SPI input/output
- 6 to 96 MHz configurable clock frequency
- Single-word read/write access from/to external flash
- EasyDMA for block read and write transfers
- Up to 48 MB/sec EasyDMA read rate
- Execute in place (XIP) for executing program directly from external flash
- XIP access can optionally be disabled
- On-the-fly encryption and decryption, including EasyDMA and XIP





Figure 118: Block diagram

# 7.25.1 Configuring QSPI

Before any data can be transferred to or from the external flash memory, the peripheral needs to be configured.

- **1.** Select the mandatory input/output pins in the following registers:
  - PSEL.SCK on page 417
  - PSEL.CSN on page 417
  - PSEL.IO0 on page 418
  - PSEL.IO1 on page 418
  - PSEL.IO2 on page 418
  - PSEL.IO3 on page 419

For which pins to use, see Pin assignments on page 790. Only the dedicated QSPI pins shall be used.

- 2. To ensure stable operation, set the GPIO drive strength to high drive. See the GPIO General purpose input/output on page 224 chapter for details on how to configure GPIO drive strength.
- **3.** Activate the dedicated peripheral setting of the GPIO pin. See the GPIO General purpose input/output on page 224 chapter for details on how to assign pins between cores, peripherals, or subsystems.
- **4.** Configure the interface towards the external flash memory using IFCONFIGO on page 419, IFCONFIG1 on page 424, and ADDRCONF on page 425.
- **5.** Enable the QSPI peripheral and acquire I/O pins using ENABLE on page 415.
- **6.** Activate the external flash memory interface using the ACTIVATE task. The READY event will be generated when the interface has been activated and the external flash memory is ready for access.



#### Note:

If the IFCONFIGO register is configured to use the quad mode, the external flash device also needs to be set in the quad mode before any data transfers can take place.

This can be done by sending custom instructions to the external flash device, as described in Sending custom instructions on page 401.

# 7.25.2 Write operation

A write operation to the external flash is configured using the WRITE.DST, WRITE.SRC, and WRITE.CNT registers. It is started using the WRITESTART task.

The READY event is generated when the transfer is complete.

The QSPI peripheral automatically takes care of splitting DMA transfers into page writes.

# 7.25.3 Read operation

A read operation from the external flash is configured using the READ.SRC, READ.DST, and READ.CNT registers. It is started using the READSTART task.

The READY event is generated when the transfer is complete.

# 7.25.4 Erase operation

Erase of pages/blocks of the external flash is configured using the ERASE.PTR and ERASE.LEN registers. It is started using the ERASESTART task.

The READY event is generated when the erase operation has been started.

In this case, the READY event will not indicate that the erase operation of the flash has been completed, but it only signals that the erase operation has been started. The actual status of the erase operation can normally be read from the external flash using a custom instruction (see Sending custom instructions on page 401).

# 7.25.5 Execute in place

Execute in place (XIP) allows the CPU to execute program code directly from the external flash.

After the external flash has been configured, the CPU can execute code from the external flash by accessing the XIP memory region. See the following figure and Memory on page 19 for details.

The XIP memory region is read-only, writing to it will result in a bus error.

When accessing the XIP memory region, the start address of this XIP memory region will map to the address XIPOFFSET on page 419 of the external flash.





Figure 119: XIP memory map

# 7.25.6 Encryption

The contents of an external flash memory can be protected using stream cipher encryption. Encryption can be configured and enabled independently for XIP and EasyDMA, with separate keys and nonce.

Once configured and enabled, the stream cipher operates between the AHB bus and the external flash, encrypting and decrypting data passing through.

The following figure shows the stream cipher block with the three configuration registers. The stream cipher uses an AES 128 encryption operation to form the keystream from key, nonce, and external memory address. The keystream then combines each 32-bit plaintext digit one at a time with the corresponding digit of the keystream.



Figure 120: Stream cipher

The same nonce and key must be used for both encryption and decryption of the same memory address.



The memory address used for encryption is the external flash memory address and thus independent of XIPOFFSET on page 419. This means a second firmware image can be encrypted and written using EasyDMA, then XIPOFFSET on page 419 set to point to the new firmware image before executing from it.

Stream ciphers are symmetric. They do not differentiate between encrypting or decrypting, reading or writing. Thus, if the contents of a plain text external flash is read when stream cipher is enabled, the data provided to the MCU is encrypted.

### **Execute in place (XIP)**

Enable the stream cipher for QSPI XIP by doing the following steps.

- 1. Configure keys using XIP\_ENC.KEY0 on page 420 through XIP\_ENC.KEY3 on page 421.
- 2. Configure nonce using XIP\_ENC.NONCEO on page 421 through XIP\_ENC.NONCE2 on page 422.
- 3. Set XIP\_ENC.ENABLE on page 422.

Any instructions or data read from the XIP interface will now pass through the stream cipher.

### **EasyDMA**

Enable the stream cipher for QSPI EasyDMA by doing the following steps.

- 1. Configure keys using DMA ENC.KEY0 on page 422 through DMA ENC.KEY3 on page 423.
- 2. Configure nonce using DMA ENC.NONCE0 on page 423 through DMA ENC.NONCE2 on page 424.
- 3. Set DMA\_ENC.ENABLE on page 424.

Any data read from or written to the external flash over the EasyDMA interface will now pass through the stream cipher.

# 7.25.7 Sending custom instructions

Custom instructions can be sent to the external flash using the CINSTRCONF, CINSTRDATO, and CINSTRDAT1 registers. It is possible to send an instruction consisting of a one-byte opcode and up to 8 bytes of additional data and to read its response.

A custom instruction is prepared by first writing the data to be sent to CINSTRDATO and CINSTRDAT1 before writing the opcode and other configurations to the CINSTRCONF register.

The custom instruction is sent when the CINSTRCONF register is written and it is always sent on a single data line SPI interface.

The READY event will be generated when the custom instruction has been sent.

After a custom instruction has been sent, the CINSTRDATO and CINSTRDAT1 will contain the response bytes from the custom instruction.

The data of custom instructions is not part of the stream cipher encryption.





Figure 121: Sending custom instruction

# 7.25.7.1 Long frame mode

The LFEN and LFSTOP fields in the CINSTRCONF register control the operation of the custom instruction Long frame mode. Long frame mode is a mechanism that permits arbitrary byte length custom instructions. While in Long frame mode a long custom instruction sequence is split in multiple writes to the CINSTRDATO and CINSTRDAT1 registers.

To enable Long frame mode every write to the CINSTRCONF register must have the LFEN field set to 1. The contents of the OPCODE field will be transmitted after the first write to CINSTRCONF and will be omitted in every subsequent write to this register. For subsequent writes the number of data bytes as specified in the LENGTH field are transferred (that is the value of LENGTH - 1 data bytes). The values of the LIO2 and LIO3 fields are set in the first write to CINSTRCONF and will apply for the entire custom instruction transmission until the long frame is finalized.

To finalize a long frame transmission, the LFSTOP field in the CINSTRCONF register must be set to 1 in the last write to this register.

# 7.25.8 Deep power-down mode

The external flash memory can be put in Deep power-down mode (DPM) to minimize its current consumption when there is no need to access the memory.

DPM is enabled in register IFCONFIGO on page 419 and configured in register DPMDUR on page 425. The DPM status of the external memory can be read in the STATUS register. The DPMDUR register has to be configured according to the external flash specification to get the information in the STATUS register and the timing of the READY event correct.

Entering or exiting DPM is controlled using register IFCONFIG1 on page 424.

### 7.25.9 Instruction set

The following table shows the instruction set supported by QSPI when communicating with an external flash device.



| Instruction | Opcode                             | Description                    |
|-------------|------------------------------------|--------------------------------|
| WREN        | 0x06                               | Write enable                   |
| RDSR        | 0x05                               | Read status register           |
| WRSR        | 0x01                               | Write status register          |
| FASTREAD    | 0x0B                               | Read bytes at higher speed     |
| READ2O      | 0x3B                               | Dual-read output               |
| READ2IO     | OxBB                               | Dual-read input/output         |
| READ4O      | 0x6B                               | Quad-read output               |
| READ4IO     | OxEB                               | Quad-read input/output         |
| PP          | 0x02                               | Page program                   |
| PP2O        | 0xA2                               | Dual-page program output       |
| PP4O        | 0x32                               | Quad-page program output       |
| PP4IO       | 0x38                               | Quad-page program input/output |
| SE          | 0x20                               | Sector erase                   |
| BE          | 0xD8                               | Block erase                    |
| CE          | 0xC7                               | Chip erase                     |
| DP          | 0xB9                               | Enter Deep power-down mode     |
| DPE         | 0xAB                               | Exit Deep power-down mode      |
| EN4B        | Specified in the ADDRCONF register | Enable 32 bit address mode     |

Table 118: Instruction set

# 7.25.10 Interface description



Figure 122: 24-bit FASTREAD, SPIMODE = MODEO





Figure 123: 24-bit READ2O (dual-read output), SPIMODE = MODEO



Figure 124: 24-bit READ2IO (dual read input/output), SPIMODE = MODEO



Figure 125: 24-bit READ4O (quad-read output), SPIMODE = MODE0





Figure 126: 24-bit READ4IO (quad-read input/output), SPIMODE = MODE0



Figure 127: 24-bit PP (page program), SPIMODE = MODE0



Figure 128: 24-bit PP2O (dual-page program output), SPIMODE = MODEO





Figure 129: 24-bit PP4O (quad page program output), SPIMODE = MODEO



Figure 130: 24-bit PP4IO (quad page program input/output), SPIMODE = MODEO



Figure 131: 32-bit FASTREAD, SPIMODE = MODEO





Figure 132: 32-bit READ2O (dual-read output), SPIMODE = MODEO



Figure 133: 32-bit READ2IO (dual read input/output), SPIMODE = MODEO



Figure 134: 32-bit READ4O (quad-read output), SPIMODE = MODEO





Figure 135: 32-bit READ4IO (quad-read input/output), SPIMODE = MODE0



Figure 136: 32-bit PP (page program), SPIMODE = MODE0



Figure 137: 32-bit PP2O (dual-page program output), SPIMODE = MODEO





Figure 138: 32-bit PP4O (quad-page program output), SPIMODE = MODEO



Figure 139: 32-bit PP4IO (quad page program input/output), SPIMODE = MODEO

# 7.25.11 Registers

| Base address Domain | Peripheral | Instance  | Secure mapping | DMA security | Description                  | Configuration           |
|---------------------|------------|-----------|----------------|--------------|------------------------------|-------------------------|
| 0x5002B000          | I OCDI     | QSPI : S  | LIC            | 5.4          | External memory (quad        | Supports 192 MHz and 96 |
| 0x4002B000          | N USPI     | QSPI : NS | US             | SA           | serial peripheral) interface | MHz PCLK192M frequency  |

Table 119: Instances

| Register             | Offset | Security | Description                                                                            |
|----------------------|--------|----------|----------------------------------------------------------------------------------------|
| TASKS_ACTIVATE       | 0x000  |          | Activate QSPI interface                                                                |
| TASKS_READSTART      | 0x004  |          | Start transfer from external flash memory to internal RAM                              |
| TASKS_WRITESTART     | 0x008  |          | Start transfer from internal RAM to external flash memory                              |
| TASKS_ERASESTART     | 0x00C  |          | Start external flash memory erase operation                                            |
| TASKS_DEACTIVATE     | 0x010  |          | Deactivate QSPI interface                                                              |
| SUBSCRIBE_ACTIVATE   | 0x080  |          | Subscribe configuration for task ACTIVATE                                              |
| SUBSCRIBE_READSTART  | 0x084  |          | Subscribe configuration for task READSTART                                             |
| SUBSCRIBE_WRITESTART | 0x088  |          | Subscribe configuration for task WRITESTART                                            |
| SUBSCRIBE_ERASESTART | 0x08C  |          | Subscribe configuration for task ERASESTART                                            |
| SUBSCRIBE_DEACTIVATE | 0x090  |          | Subscribe configuration for task DEACTIVATE                                            |
| EVENTS_READY         | 0x100  |          | QSPI peripheral is ready. This event will be generated as a response to all QSPI tasks |
|                      |        |          | except DEACTIVATE.                                                                     |
| PUBLISH_READY        | 0x180  |          | Publish configuration for event READY                                                  |
| INTEN                | 0x300  |          | Enable or disable interrupt                                                            |
| INTENSET             | 0x304  |          | Enable interrupt                                                                       |
|                      |        |          |                                                                                        |



| Register       | Offset | Security | Description                                                             |
|----------------|--------|----------|-------------------------------------------------------------------------|
| INTENCLR       | 0x308  | •        | Disable interrupt                                                       |
| ENABLE         | 0x500  |          | Enable QSPI peripheral and acquire the pins selected in PSELn registers |
| READ.SRC       | 0x504  |          | Flash memory source address                                             |
| READ.DST       | 0x508  |          | RAM destination address                                                 |
| READ.CNT       | 0x50C  |          | Read transfer length                                                    |
| WRITE.DST      | 0x510  |          | Flash destination address                                               |
| WRITE.SRC      | 0x514  |          | RAM source address                                                      |
| WRITE.CNT      | 0x518  |          | Write transfer length                                                   |
| ERASE.PTR      | 0x51C  |          | Start address of flash block to be erased                               |
| ERASE.LEN      | 0x520  |          | Size of block to be erased.                                             |
| PSEL.SCK       | 0x524  |          | Pin select for serial clock SCK                                         |
| PSEL.CSN       | 0x528  |          | Pin select for chip select signal CSN.                                  |
| PSEL.IO0       | 0x530  |          | Pin select for serial data MOSI/IO0.                                    |
| PSEL.IO1       | 0x534  |          | Pin select for serial data MISO/IO1.                                    |
| PSEL.IO2       | 0x538  |          | Pin select for serial data WP/IO2.                                      |
| PSEL.IO3       | 0x53C  |          | Pin select for serial data HOLD/IO3.                                    |
| XIPOFFSET      | 0x540  |          | Address offset into the external memory for Execute in Place operation. |
| IFCONFIG0      | 0x544  |          | Interface configuration.                                                |
| XIPEN          | 0x54C  |          | Enable Execute in Place operation.                                      |
| XIP_ENC.KEY0   | 0x560  |          | Bits 31:0 of XIP AES KEY                                                |
| XIP_ENC.KEY1   | 0x564  |          | Bits 63:32 of XIP AES KEY                                               |
| XIP_ENC.KEY2   | 0x568  |          | Bits 95:64 of XIP AES KEY                                               |
| XIP_ENC.KEY3   | 0x56C  |          | Bits 127:96 of XIP AES KEY                                              |
| XIP_ENC.NONCE0 | 0x570  |          | Bits 31:0 of XIP NONCE                                                  |
| XIP_ENC.NONCE1 | 0x574  |          | Bits 63:32 of XIP NONCE                                                 |
| XIP_ENC.NONCE2 | 0x578  |          | Bits 95:64 of XIP NONCE                                                 |
| XIP_ENC.ENABLE | 0x57C  |          | Enable stream cipher for XIP                                            |
| DMA_ENC.KEY0   | 0x580  |          | Bits 31:0 of DMA AES KEY                                                |
| DMA_ENC.KEY1   | 0x584  |          | Bits 63:32 of DMA AES KEY                                               |
| DMA_ENC.KEY2   | 0x588  |          | Bits 95:64 of DMA AES KEY                                               |
| DMA_ENC.KEY3   | 0x58C  |          | Bits 127:96 of DMA AES KEY                                              |
| DMA_ENC.NONCE0 | 0x590  |          | Bits 31:0 of DMA NONCE                                                  |
| DMA_ENC.NONCE1 | 0x594  |          | Bits 63:32 of DMA NONCE                                                 |
| DMA_ENC.NONCE2 | 0x598  |          | Bits 95:64 of DMA NONCE                                                 |
| DMA_ENC.ENABLE | 0x59C  |          | Enable stream cipher for EasyDMA                                        |
| IFCONFIG1      | 0x600  |          | Interface configuration.                                                |
| STATUS         | 0x604  |          | Status register.                                                        |
| DPMDUR         | 0x614  |          | Set the duration required to enter/exit deep power-down mode (DPM).     |
| ADDRCONF       | 0x624  |          | Extended address configuration.                                         |
| CINSTRCONF     | 0x634  |          | Custom instruction configuration register.                              |
| CINSTRDATO     | 0x638  |          | Custom instruction data register 0.                                     |
| CINSTRDAT1     | 0x63C  |          | Custom instruction data register 1.                                     |
| IFTIMING       | 0x640  |          | SPI interface timing.                                                   |

Table 120: Register overview

# 7.25.11.1 TASKS\_ACTIVATE

Address offset: 0x000 Activate QSPI interface

Triggering this task activates the external flash memory interface and initiates communication with the external memory. The READY event is generated when the activation has been completed.







### 7.25.11.2 TASKS READSTART

Address offset: 0x004

Start transfer from external flash memory to internal RAM

The READY event will be generated when transfer is complete.



# 7.25.11.3 TASKS\_WRITESTART

Address offset: 0x008

Start transfer from internal RAM to external flash memory

The READY event will be generated when transfer is complete.



# 7.25.11.4 TASKS\_ERASESTART

Address offset: 0x00C

Start external flash memory erase operation

The READY event will be generated when the erase operation has been started. The generation of the READY event does not imply that the erase operation is completed.





## 7.25.11.5 TASKS\_DEACTIVATE

Address offset: 0x010

Deactivate QSPI interface

This task might be needed to optimize current consumption in case there are any added current consumption when QSPI interface is activated, but idle.



### 7.25.11.6 SUBSCRIBE ACTIVATE

Address offset: 0x080

Subscribe configuration for task ACTIVATE

Triggering this task activates the external flash memory interface and initiates communication with the external memory. The READY event is generated when the activation has been completed.



### 7.25.11.7 SUBSCRIBE READSTART

Address offset: 0x084

Subscribe configuration for task READSTART

The READY event will be generated when transfer is complete.





### 7.25.11.8 SUBSCRIBE WRITESTART

Address offset: 0x088

Subscribe configuration for task WRITESTART

The READY event will be generated when transfer is complete.



### 7.25.11.9 SUBSCRIBE ERASESTART

Address offset: 0x08C

Subscribe configuration for task ERASESTART

The READY event will be generated when the erase operation has been started. The generation of the READY event does not imply that the erase operation is completed.



# 7.25.11.10 SUBSCRIBE\_DEACTIVATE

Address offset: 0x090

Subscribe configuration for task DEACTIVATE

This task might be needed to optimize current consumption in case there are any added current consumption when QSPI interface is activated, but idle.





## 7.25.11.11 EVENTS READY

Address offset: 0x100

QSPI peripheral is ready. This event will be generated as a response to all QSPI tasks except DEACTIVATE.



### 7.25.11.12 PUBLISH READY

Address offset: 0x180

Publish configuration for event READY

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | АААААА                                                        |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         | Description                                                   |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event READY will publish to.                |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  |                         | Enable publishing                                             |

#### 7.25.11.13 INTEN

Address offset: 0x300

Enable or disable interrupt





#### 7.25.11.14 INTENSET

Address offset: 0x304

Enable interrupt



#### 7.25.11.15 INTENCLR

Address offset: 0x308

Disable interrupt



#### 7.25.11.16 ENABLE

Address offset: 0x500

Enable QSPI peripheral and acquire the pins selected in PSELn registers



### 7.25.11.17 READ.SRC

Address offset: 0x504

Flash memory source address



Word-aligned flash memory source address.



### 7.25.11.18 READ.DST

Address offset: 0x508

**RAM** destination address



### 7.25.11.19 READ.CNT

Address offset: 0x50C Read transfer length

| Bit n | umber   |       | 31 30 | 29 2 | 8 27 2 | 26 25 | 24 | 23 22 | 212  | 20 1 | 9 18 | 17    | 16 1 | 5 14 | 113  | 12 1  | 1 10 | 9   | 8   | 7   | 6 ! | 5 4 | 3 | 2 | 1 0 |
|-------|---------|-------|-------|------|--------|-------|----|-------|------|------|------|-------|------|------|------|-------|------|-----|-----|-----|-----|-----|---|---|-----|
| ID    |         |       |       |      |        |       |    |       |      | Α Α  | A A  | Α     | A A  | A A  | Α    | Α,    | 4 A  | A   | Α   | Α   | Α / | 4 A | Α | Α | А А |
| Rese  | t 0x000 | 00000 | 0 0   | 0 0  | 0      | 0 0   | 0  | 0 0   | 0    | 0 0  | 0    | 0     | 0 (  | 0    | 0    | 0     | 0 0  | 0   | 0   | 0   | 0 ( | 0 0 | 0 | 0 | 0 0 |
| ID    |         |       |       |      |        |       |    | Desc  |      |      |      |       |      |      |      |       |      |     |     |     |     |     |   |   |     |
| Α     | RW      | CNT   |       |      |        |       |    | Read  | tran | sfer | len  | gth i | n nı | ımb  | er c | of by | tes. | The | len | gth | mu  | ıst |   |   |     |

be a multiple of 4 bytes.

### 7.25.11.20 WRITE.DST

Address offset: 0x510 Flash destination address

| ID R/W       |       |     |            |    |    |    |      |    | Des  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |    |     |     |     |   |   |   |
|--------------|-------|-----|------------|----|----|----|------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|----|-----|-----|-----|---|---|---|
| Reset 0x0000 | 00000 | 0   | 0 0        | 0  | 0  | 0  | 0    | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 ( | 0  | 0 ( | 0 ( | 0   | 0 | 0 | D |
| ID           |       | Α , | <b>Д</b> А | Α  | Α  | Α  | Α    | Α  | Α    | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α  | Α. | A | A A | Δ. | Α , | Δ , | A A | Α | Α | Д |
| Bit number   |       | 313 | 0 29       | 28 | 27 | 26 | 25 : | 24 | 23 : | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 7 | 7  | 6 ! | 5 4 | 1 3 | 2 | 1 | O |

### 7.25.11.21 WRITE.SRC

Address offset: 0x514 **RAM** source address

| A RW       | SRC    |     |    |      |      |    |    | Wo   | rd-a | lign | ed F | RAM   | sou | rce | addr | ess. |      |      |   |   |   |     |    |   |     |
|------------|--------|-----|----|------|------|----|----|------|------|------|------|-------|-----|-----|------|------|------|------|---|---|---|-----|----|---|-----|
| ID R/W     |        |     |    |      |      |    |    |      |      |      |      |       |     |     |      |      |      |      |   |   |   |     |    |   |     |
| Reset 0x00 | 000000 | 0 0 | 0  | 0 (  | 0 0  | 0  | 0  | 0    | 0 (  | 0    | 0    | 0 0   | 0   | 0   | 0 0  | 0    | 0 (  | 0    | 0 | 0 | 0 | 0 ( | 0  | 0 | 0 0 |
| ID         |        | A A | A  | A A  | 4 A  | Α  | Α  | Α    | A A  | A    | Α    | A A   | Α   | Α   | ΑА   | А    | Α /  | 4 A  | A | Α | Α | A A | AA | Α | A A |
| Bit numbe  | r      | 313 | 29 | 28 2 | 7 26 | 25 | 24 | 23 2 | 22 2 | 1 20 | 19   | 18 17 | 16  | 15  | 14 1 | 3 12 | 11 1 | .0 9 | 8 | 7 | 6 | 5 4 | 3  | 2 | 1 0 |

### 7.25.11.22 WRITE.CNT

Address offset: 0x518 Write transfer length





### 7.25.11.23 ERASE.PTR

Address offset: 0x51C

Start address of flash block to be erased

| ID     | R/W   |       |     |      |      |     |     |      |     | De   | escr |    |    |    |      |      |      |    |      |      |     |     |   |   |   |   |     |     |   |   |
|--------|-------|-------|-----|------|------|-----|-----|------|-----|------|------|----|----|----|------|------|------|----|------|------|-----|-----|---|---|---|---|-----|-----|---|---|
| Reset  | 0x000 | 00000 | 0   | 0    | 0    | 0 0 | ) ( | 0 0  | 0   | 0    | 0    | 0  | 0  | 0  | 0 (  | 0    | 0    | 0  | 0    | 0    | 0 0 | 0   | 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID     |       |       | Α . | A    | A    | Α Α | ۸ ۸ | Α Δ  | . Δ | A    | Α    | Α  | Α  | Α  | Α /  | Δ Δ  | Α    | Α  | Α    | Α.   | A A | A   | Α | Α | Α | Α | A   | A A | A | Α |
| Bit nu | ımber |       | 313 | 30 2 | 29 2 | 8 2 | 7 2 | 26 2 | 5 2 | 4 23 | 3 22 | 21 | 20 | 19 | 18 1 | 7 10 | 5 15 | 14 | 13 : | 12 1 | 111 | 0 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 |

Word-aligned start address of block to be erased.

#### 7.25.11.24 ERASE.LEN

Address offset: 0x520

Size of block to be erased.



### 7.25.11.25 PSEL.SCK

Address offset: 0x524

Pin select for serial clock SCK

| Bit n | umber   |         |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |         |              | С                       | ВАААА                                                           |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |         |         |              |                         | Description                                                     |
| Α     | RW      | PIN     |              | [031]                   | Pin number                                                      |
| В     | RW      | PORT    |              | [01]                    | Port number                                                     |
| С     | RW      | CONNECT |              |                         | Connection                                                      |
|       |         |         | Disconnected | 1                       | Disconnect                                                      |
|       |         |         | Connected    | 0                       | Connect                                                         |

### 7.25.11.26 PSEL.CSN

Address offset: 0x528

Pin select for chip select signal CSN.





### 7.25.11.27 PSEL.IO0

Address offset: 0x530

Pin select for serial data MOSI/IO0.

Serial data output (MOSI) during single mode, or serial data IOO during quad mode



#### 7.25.11.28 PSEL.IO1

Address offset: 0x534

Pin select for serial data MISO/IO1.

Serial data input (MISO) during single mode, or serial data IO1 during quad mode



### 7.25.11.29 PSEL.IO2

Address offset: 0x538

Pin select for serial data WP/IO2.

In single mode, this pin can control Write protect (WP, active low).





### 7.25.11.30 PSEL.IO3

Address offset: 0x53C

Pin select for serial data HOLD/IO3.

In single mode, this pin can can pause the device (HOLD, active low).

| Bit n | umber   |         |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |         |              | С                       | ВАААА                                                           |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |         |         |              |                         |                                                                 |
| Α     | RW      | PIN     |              | [031]                   | Pin number                                                      |
| В     | RW      | PORT    |              | [01]                    | Port number                                                     |
| С     | RW      | CONNECT |              |                         | Connection                                                      |
|       |         |         | Disconnected | 1                       | Disconnect                                                      |
|       |         |         | Connected    | 0                       | Connect                                                         |

### 7.25.11.31 XIPOFFSET

Address offset: 0x540

Address offset into the external memory for Execute in Place operation.

| Bit n | umber   |           | 31 | 30 2 | 9 28 | 27 | 26 2 | 25 2 | 4 2 | 3 22 | 21  | 20   | 19   | 18 1 | 7 16 | 5 15 | 14  | 13 1 | 2 1 | 1 10 | 9     | 8   | 7   | 6    | 5 4 | 1 3 | 2 | 1 ( | ) |
|-------|---------|-----------|----|------|------|----|------|------|-----|------|-----|------|------|------|------|------|-----|------|-----|------|-------|-----|-----|------|-----|-----|---|-----|---|
| ID    |         |           | Α  | A A  | A    | Α  | Α.   | A ,  | Δ , | 4 A  | Α   | Α    | Α    | A A  | A A  | A    | Α   | Α.   | Δ Δ | A    | Α     | Α   | Α   | Α    | A A | 4 A | A | A A | l |
| Rese  | t 0x000 | 00000     | 0  | 0 0  | 0    | 0  | 0    | 0    | 0 ( | 0 0  | 0   | 0    | 0    | 0 (  | 0    | 0    | 0   | 0    | 0 0 | 0    | 0     | 0   | 0   | 0    | 0 ( | 0   | 0 | 0 ( |   |
| ID    |         |           |    |      |      |    |      |      |     |      |     |      |      |      |      |      |     |      |     |      |       |     |     |      |     |     |   |     | ı |
| Α     | RW      | XIPOFFSET |    |      |      |    |      |      | A   | ddr  | ess | offs | et i | nto  | the  | ext  | ern | al m | em  | ory  | for I | Exe | cut | e in |     |     |   |     |   |

Place operation. Value must be a multiple of 4.

### 7.25.11.32 IFCONFIGO

Address offset: 0x544

Interface configuration.





| Bit r | umber    |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          |                         | G DCBBAAA                                                       |
| Rese  | et 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |          |                         | Description                                                     |
|       |          |           | READ2O   | 1                       | Dual data line SPI. READ2O (opcode 0x3B).                       |
|       |          |           | READ2IO  | 2                       | Dual data line SPI. READ2IO (opcode 0xBB).                      |
|       |          |           | READ4O   | 3                       | Quad data line SPI. READ4O (opcode 0x6B).                       |
|       |          |           | READ4IO  | 4                       | Quad data line SPI. READ4IO (opcode 0xEB).                      |
| В     | RW       | WRITEOC   |          |                         | Configure number of data lines and opcode used for              |
|       |          |           |          |                         | writing.                                                        |
|       |          |           | PP       | 0                       | Single data line SPI. PP (opcode 0x02).                         |
|       |          |           | PP2O     | 1                       | Dual data line SPI. PP2O (opcode 0xA2).                         |
|       |          |           | PP4O     | 2                       | Quad data line SPI. PP4O (opcode 0x32).                         |
|       |          |           | PP4IO    | 3                       | Quad data line SPI. PP4IO (opcode 0x38).                        |
| С     | RW       | ADDRMODE  |          |                         | Addressing mode.                                                |
|       |          |           | 24BIT    | 0                       | 24-bit addressing.                                              |
|       |          |           | 32BIT    | 1                       | 32-bit addressing.                                              |
| D     | RW       | DPMENABLE |          |                         | Enable deep power-down mode (DPM) feature.                      |
|       |          |           | Disable  | 0                       | Disable DPM feature.                                            |
|       |          |           | Enable   | 1                       | Enable DPM feature.                                             |
| G     | RW       | PPSIZE    |          |                         | Page size for commands PP, PP2O, PP4O and PP4IO.                |
|       |          |           | 256Bytes | 0                       | 256 bytes.                                                      |
|       |          |           | 512Bytes | 1                       | 512 bytes.                                                      |

### 7.25.11.33 XIPEN

Address offset: 0x54C

Enable Execute in Place operation.

| Bit n | umber    |       |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|---------|------------------------|-----------------------------------------------------------------|
| ID    |          |       |         |                        | A                                                               |
| Rese  | et 0x000 | 00001 |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |         |                        |                                                                 |
| Α     | RW       | XIPEN |         |                        | Enable XIP AHB Slave interface and access to XIP memory         |
|       |          |       |         |                        | range                                                           |
|       |          |       |         |                        | When disabled, access to external memory is only available      |
|       |          |       |         |                        | through EasyDMA and custom instructions. Access to              |
|       |          |       |         |                        | disabled XIP interface will cause a Bus Error, and the value    |
|       |          |       |         |                        | read is all zeros.                                              |
|       |          |       | Disable | 0                      | Disable XIP interface                                           |
|       |          |       | Enable  | 1                      | Enable XIP interface                                            |

# 7.25.11.34 XIP\_ENC.KEY0

Address offset: 0x560 Bits 31:0 of XIP AES KEY





# 7.25.11.35 XIP\_ENC.KEY1

Address offset: 0x564
Bits 63:32 of XIP AES KEY

| Bit n | umber   |       | 313 | 80 29 | 28 | 27 | 26 2 | 25 2 | 24 2 | 3 22  | 2 21 | L 20 | 19   | 18 1 | L7 1 | 6 15 | 14 | 13 : | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 4 | 1 3 | 2 | 1 0 |
|-------|---------|-------|-----|-------|----|----|------|------|------|-------|------|------|------|------|------|------|----|------|------|------|---|---|---|---|-----|-----|---|-----|
| ID    |         |       | Α , | А А   | Α  | Α  | Α    | Α.   | A A  | 4 A   | A    | Α    | Α    | Α    | A A  | A A  | Α  | Α    | ΑА   | A    | Α | Α | Α | Α | A A | A A | Α | A A |
| Rese  | t 0x000 | 00000 | 0   | 0 0   | 0  | 0  | 0    | 0    | 0 (  | 0     | 0    | 0    | 0    | 0    | 0 (  | 0    | 0  | 0    | 0 0  | 0    | 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 0 |
| ID    |         |       |     |       |    |    |      |      |      |       |      |      |      |      |      |      |    |      |      |      |   |   |   |   |     |     |   |     |
| Α     | W       | KEY1  |     |       |    |    |      |      | В    | its 6 | 53:3 | 32 c | f XI | PΑ   | ES K | ΕY   |    |      |      |      |   |   |   |   |     |     |   |     |

# 7.25.11.36 XIP\_ENC.KEY2

Address offset: 0x568
Bits 95:64 of XIP AES KEY

| _     | W        | KEY2  |                |       | ο.    |      |       | C >/// |       | KEY    |       |      |      |            |   |   |    |     |     |   |     |     |
|-------|----------|-------|----------------|-------|-------|------|-------|--------|-------|--------|-------|------|------|------------|---|---|----|-----|-----|---|-----|-----|
| ID    |          |       |                |       |       |      |       |        |       |        |       |      |      |            |   |   |    |     |     |   |     |     |
| Rese  | et 0x000 | 00000 | 0 0 0 0 0      | 0 0   | 0 0   | 0    | 0 0   | 0      | 0 0   | 0      | 0 0   | 0    | 0 (  | 0 0        | 0 | 0 | 0  | 0 ( | 0   | 0 | 0 ( | 0 ( |
| ID    |          |       | A A A A A      | АА    | A A   | Α    | А А   | Α.     | А А   | A      | ДД    | A    | Α /  | <b>4</b> А | Α | Α | Α. | A A | AA  | Α | Α / | A A |
| Bit n | umber    |       | 31 30 29 28 27 | 26 25 | 24 23 | 22 2 | 21 20 | 19 1   | L8 17 | ' 16 1 | .5 14 | 4 13 | 12 1 | .1 10      | 9 | 8 | 7  | 6 5 | 5 4 | 3 | 2   | 1 0 |

# 7.25.11.37 XIP\_ENC.KEY3

Address offset: 0x56C Bits 127:96 of XIP AES KEY

|       | W       | KFY3  |    |      |      |      |     |      |     |      |      |      |    | 96 ( |    |    |      |      |    |    |      |      |      |    |   |     |    |     |     |     |   |   |   |
|-------|---------|-------|----|------|------|------|-----|------|-----|------|------|------|----|------|----|----|------|------|----|----|------|------|------|----|---|-----|----|-----|-----|-----|---|---|---|
| ID    |         |       |    |      |      |      |     |      |     |      |      |      |    |      |    |    |      |      |    |    |      |      |      |    |   |     |    |     |     |     |   |   |   |
| Rese  | t 0x000 | 00000 | 0  | 0    | 0    | 0 (  | ) ( | 0 (  | )   | 0    | 0    | 0    | 0  | 0    | 0  | 0  | 0    | 0    | 0  | 0  | 0    | 0    | 0    | 0  | 0 | 0   | 0  | 0 ( | 0 0 | 0   | 0 | 0 | 0 |
| ID    |         |       | Α  | Α    | Α    | A A  | ۸ ۸ | A A  | ١.  | Α.   | Α    | Α    | Α  | Α    | Α  | Α  | Α    | Α    | Α  | Α  | Α    | Α    | Α    | Α  | Α | A . | Δ. | Α / | Δ Α | A A | Α | Α | Α |
| Bit n | umber   |       | 31 | 30 2 | 29 2 | 28 2 | 7 2 | 26 2 | 5 2 | 24 2 | 23 : | 22 : | 21 | 20   | 19 | 18 | 17 : | 16 : | 15 | 14 | 13 1 | 12 : | 11 : | 10 | 9 | 8   | 7  | 6 ! | 5 4 | 3   | 2 | 1 | 0 |

# 7.25.11.38 XIP\_ENC.NONCE0

Address offset: 0x570 Bits 31:0 of XIP NONCE

| Δ     | W        | NONCEO |                        | Rits 31:0 of XIP NONCE                                          |
|-------|----------|--------|------------------------|-----------------------------------------------------------------|
| ID    |          |        |                        |                                                                 |
| Res   | et 0x000 | 00000  | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |        | A A A A A A A          |                                                                 |
| Bit r | number   |        | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

# 7.25.11.39 XIP\_ENC.NONCE1

Address offset: 0x574
Bits 63:32 of XIP NONCE





| ID A A A A A A A A A A A A A A A A A A A                                                         | A W NONCE1       | Bits 63:32 of XIP NONCE                                                               |
|--------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------|
| ID A A A A A A A A A A A A A A A A A A A                                                         | ID R/W Field     |                                                                                       |
|                                                                                                  | Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | ID               | A A A A A A A A A A A A A A A A A A A                                                 |
|                                                                                                  | Bit number       | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

# 7.25.11.40 XIP\_ENC.NONCE2

Address offset: 0x578
Bits 95:64 of XIP NONCE

| Bit n | umber   |        | 313 | 30 29 | 9 28 | 27 | 26 | 25 | 24 2 | 23 2 | 2 2: | 1 20 | 19   | 18 : | 17 1 | 6 1 | 5 14 | 113 | 12 : | 111 | .0 9 | 8 | 7 | 6 | 5 | 4   | 3 2 | 2 1 | 0 |
|-------|---------|--------|-----|-------|------|----|----|----|------|------|------|------|------|------|------|-----|------|-----|------|-----|------|---|---|---|---|-----|-----|-----|---|
| ID    |         |        | Α   | A A   | Α    | Α  | Α  | Α  | Α.   | A A  | A    | A    | Α    | Α    | A    | ДД  | \ A  | Α   | Α    | A A | 4 A  | A | Α | Α | Α | Α . | A A | A A | Α |
| Rese  | t 0x000 | 00000  | 0   | 0 0   | 0    | 0  | 0  | 0  | 0    | 0 0  | 0    | 0    | 0    | 0    | 0    | 0 0 | 0    | 0   | 0    | 0 ( | 0 0  | 0 | 0 | 0 | 0 | 0   | 0 0 | 0   | 0 |
| ID    |         |        |     |       |      |    |    |    |      |      |      |      |      |      |      |     |      |     |      |     |      |   |   |   |   |     |     |     |   |
| Α     | W       | NONCE2 |     |       |      |    |    |    | E    | Bits | 95:  | 64 c | f XI | PΝ   | ON   | CE  |      |     |      |     |      |   |   |   |   |     |     |     |   |

# 7.25.11.41 XIP\_ENC.ENABLE

Address offset: 0x57C

Enable stream cipher for XIP

| Bit n | umber    |        |          | 31 30 29 28 27 20 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|----------|-------------------|-----------------------------------------------------------------------|
| ID    |          |        |          |                   | А                                                                     |
| Rese  | et 0x000 | 00000  |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |        |          |                   | Description                                                           |
| Α     | RW       | ENABLE |          |                   | Enable or disable stream cipher for XIP                               |
|       |          |        | Disabled | 0                 | Disable stream cipher for QSPI XIP                                    |
|       |          |        | Enabled  | 1                 | Enable stream cipher for QSPI XIP                                     |

# 7.25.11.42 DMA\_ENC.KEY0

Address offset: 0x580
Bits 31:0 of DMA AES KEY

| Bit n | umber   |       | 31 | 30 2 | 29 2 | 8 27 | 7 2 | 6 25 | 5 24 | 123 | 22   | 21  | 20 | 19 | 18 1 | 7 1 | 6 15 | 5 14 | 13 | 12 | 11: | 10 9 | 9 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 0 |
|-------|---------|-------|----|------|------|------|-----|------|------|-----|------|-----|----|----|------|-----|------|------|----|----|-----|------|-----|-----|---|---|---|---|---|-----|
| ID    |         |       | Α  | Α.   | A A  | 4 A  | . A | A    | Α    | Α   | Α    | Α   | Α  | Α  | A    | A A | A A  | Α    | Α  | Α  | Α   | Α /  | 4 A | . A | Α | Α | Α | Α | A | А А |
| Rese  | t 0x000 | 00000 | 0  | 0    | 0 (  | 0 0  | 0   | 0    | 0    | 0   | 0    | 0   | 0  | 0  | 0 (  | 0 ( | 0    | 0    | 0  | 0  | 0   | 0 (  | 0 0 | 0   | 0 | 0 | 0 | 0 | 0 | 0 0 |
| ID    |         |       |    |      |      |      |     |      |      |     |      |     |    |    |      |     |      |      |    |    |     |      |     |     |   |   |   |   |   |     |
| Α     | W       | KEY0  |    |      |      |      |     |      |      | Bi  | ts 3 | 1:0 | of | DM | ΑА   | ES  | ΚEΥ  |      |    |    |     |      |     |     |   |   |   |   |   |     |

# 7.25.11.43 DMA\_ENC.KEY1

Address offset: 0x584

Bits 63:32 of DMA AES KEY



| Bit number       | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|---------------------------------------------------------------------------------------|
| ID               | A A A A A A A A A A A A A A A A A A A                                                 |
| Reset 0x00000000 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| ID R/W Field     | Value Description                                                                     |
| A W KEY1         | Bits 63:32 of DMA AES KEY                                                             |

# 7.25.11.44 DMA\_ENC.KEY2

Address offset: 0x588

Bits 95:64 of DMA AES KEY

|       | \/\      | KFY2  |    |      |      |     |     |      |     | _   |     |     |     |     |     | 1A / |            |     |     |     |     |      |      |   |   |   |     |     |     |   |     |
|-------|----------|-------|----|------|------|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|------|------------|-----|-----|-----|-----|------|------|---|---|---|-----|-----|-----|---|-----|
| ID    |          |       |    |      |      |     |     |      |     |     |     |     |     |     |     |      |            |     |     |     |     |      |      |   |   |   |     |     |     |   |     |
| Res   | et 0x000 | 00000 | 0  | 0    | 0 (  | 0 ( | ) ( | 0 0  | ) ( | ) ( | ) ( | 0 ( | ) ( | 0 ( | ) ( | 0 (  | ) (        | ) ( | ) ( | ) ( | ) ( | 0    | 0    | 0 | 0 | 0 | 0   | 0 ( | 0   | 0 | 0 0 |
| ID    |          |       | Α  | Α    | Α /  | Α / | Α , | A A  | Δ / | Α Α | Δ Α | Δ Α | Α Α | Δ , | Δ / | Δ Α  | \ <i>A</i> | Α Α | Δ / | Δ , | Α Α | ι A  | A    | Α | Α | Α | Α . | Α Α | A A | Α | АА  |
| Bit r | number   |       | 31 | 30 2 | 29 2 | 8 2 | 7 2 | 26 2 | 5 2 | 4 2 | 3 2 | 2 2 | 1 2 | 0 1 | 9 1 | 8 1  | 7 1        | 6 1 | 5 1 | 4 1 | 3 1 | 2 1: | 1 10 | 9 | 8 | 7 | 6   | 5 4 | 1 3 | 2 | 1 0 |

# 7.25.11.45 DMA\_ENC.KEY3

Address offset: 0x58C

Bits 127:96 of DMA AES KEY

| ID   | umber   |       |   |   | _ |     | _ | _ | _ |   |   |   |   | _ |   |   | _ | _ | _   |     | _ |   |   | - | _ |   | _ |     |   | _ | 1 0<br>A A |
|------|---------|-------|---|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|-----|-----|---|---|---|---|---|---|---|-----|---|---|------------|
| Rese | t 0x000 | 00000 | 0 | 0 | 0 | 0 ( | ) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | ) ( | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 0        |
| ID   |         |       |   |   |   |     |   |   |   |   |   |   |   |   |   |   |   |   |     |     |   |   |   |   |   |   |   |     |   |   |            |
|      | W       | KEY3  |   |   |   |     |   |   |   |   |   |   |   |   |   |   |   |   | ŒΥ  |     |   |   |   |   |   |   |   |     |   |   |            |

# 7.25.11.46 DMA\_ENC.NONCE0

Address offset: 0x590
Bits 31:0 of DMA NONCE

| Bit n | umber   |        | 31 | . 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 2 | 2 2 | 21 20 | 19   | 18 | 17 | 16  | 15 | 14 1 | 3 12 | 11 | 10 | 9 | 8   | 7  | 6 5 | 5 4 | 3 | 2 | 1 ( | ) |
|-------|---------|--------|----|------|----|----|----|----|----|----|------|-----|-------|------|----|----|-----|----|------|------|----|----|---|-----|----|-----|-----|---|---|-----|---|
| ID    |         |        | Α  | Α    | Α  | Α  | Α  | Α  | Α  | Α  | Α.   | Δ.  | ДД    | A    | Α  | Α  | Α   | Α  | ΑА   | A    | Α  | Α  | Α | A A | Δ, | Δ / | 4 Α | Α | Α | A A | ١ |
| Rese  | t 0x000 | 00000  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   | 0 0   | 0    | 0  | 0  | 0   | 0  | 0 0  | 0    | 0  | 0  | 0 | 0 ( | )  | 0 ( | 0   | 0 | 0 | 0 ( | ) |
| ID    |         |        |    |      |    |    |    |    |    |    | Des  |     |       |      |    |    |     |    |      |      |    |    |   |     |    |     |     |   |   |     | ı |
| Α     | W       | NONCE0 |    |      |    |    |    |    |    |    | Bits | 31  | :0 o  | f DI | MA | NO | NCI |    |      |      |    |    |   |     |    |     |     |   |   |     | _ |

# 7.25.11.47 DMA\_ENC.NONCE1

Address offset: 0x594

Bits 63:32 of DMA NONCE

| Bit number            | 31 30 29 28 27 26 25 24 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 |
|-----------------------|-------------------------|------------------------------------------------------------|-------|
| ID                    | A A A A A A A           | A A A A A A A A A A A A A A A A A A A                      | A A A |
| Reset 0x00000000      | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                    | 0 0 0 |
| ID R/W Field Value ID | Value                   | Description                                                |       |

A W NONCE1 Bits 63:32 of DMA NONCE



# 7.25.11.48 DMA\_ENC.NONCE2

Address offset: 0x598

Bits 95:64 of DMA NONCE



# 7.25.11.49 DMA\_ENC.ENABLE

Address offset: 0x59C

Enable stream cipher for EasyDMA

| Bit num | nber   |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|---------|--------|--------|----------|-------------------------|-----------------------------------------------------------------|
| ID      |        |        |          |                         | A                                                               |
| Reset 0 | )x000x | 00000  |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R    |        |        |          |                         |                                                                 |
| A R     | RW     | ENABLE |          |                         | Enable or disable stream cipher for EasyDMA                     |
|         |        |        | Disabled | 0                       | Disable stream cipher for QSPI EasyDMA                          |
|         |        |        | Enabled  | 1                       | Enable stream cipher for QSPI EasyDMA                           |

### 7.25.11.50 IFCONFIG1

Address offset: 0x600 Interface configuration.

| Bit r | number   |          |       | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|-------|------------------------|-----------------------------------------------------------------|
| ID    |          |          |       | G G G G E C            | A A A A A A A A A A A A A A A A A A A                           |
| Rese  | et 0x000 | 40480    |       | 0 0 0 0 0 0 0          | 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0                     |
| ID    |          |          |       |                        | Description                                                     |
| Α     | RW       | SCKDELAY |       | [0255]                 | Minimum amount of time that the CSN pin must stay high          |
|       |          |          |       |                        | before it can go low again.                                     |
|       |          |          |       |                        | Value is specified in number of 32 MHz periods (31.25 ns).      |
| D     | RW       | DPMEN    |       |                        | Enter/exit deep power-down mode (DPM) for external              |
|       |          |          |       |                        | flash memory.                                                   |
|       |          |          | Exit  | 0                      | Exit DPM.                                                       |
|       |          |          | Enter | 1                      | Enter DPM.                                                      |
| E     | RW       | SPIMODE  |       |                        | Select SPI mode.                                                |
|       |          |          | MODE0 | 0                      | Mode 0: Data are captured on the clock rising edge and          |
|       |          |          |       |                        | data is output on a falling edge. Base level of clock is 0      |
|       |          |          |       |                        | (CPOL=0, CPHA=0).                                               |
|       |          |          | MODE3 | 1                      | Mode 3: Data are captured on the clock rising edge and          |
|       |          |          |       |                        | data is output on a falling edge. Base level of clock is 1      |
|       |          |          |       |                        | (CPOL=1, CPHA=1).                                               |
| G     | RW       | SCKFREQ  |       | [015]                  | SCK frequency is derived from PCLK192M with SCK                 |
|       |          |          |       |                        | frequency = PCLK192M / (2*(SCKFREQ + 1)).                       |



### 7.25.11.51 STATUS

Address offset: 0x604

Status register.

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | FFFFFFF                | D C                                                             |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |          |                        |                                                                 |
| С     | R        | DPM   |          |                        | Deep power-down mode (DPM) status of external flash.            |
|       |          |       | Disabled | 0                      | External flash is not in DPM.                                   |
|       |          |       | Enabled  | 1                      | External flash is in DPM.                                       |
| D     | R        | READY |          |                        | Ready status.                                                   |
|       |          |       | READY    | 1                      | QSPI peripheral is ready. It is allowed to trigger new tasks,   |
|       |          |       |          |                        | writing custom instructions or enter/exit DPM.                  |
|       |          |       | BUSY     | 0                      | QSPI peripheral is busy. It is not allowed to trigger any new   |
|       |          |       |          |                        | tasks, writing custom instructions or enter/exit DPM.           |
| F     | R        | SREG  |          |                        | Value of external flash device Status Register. When the        |
|       |          |       |          |                        | external flash has two bytes status register this field         |
|       |          |       |          |                        | includes the value of the low byte.                             |

### 7.25.11.52 DPMDUR

Address offset: 0x614

Set the duration required to enter/exit deep power-down mode (DPM).

| Bit n | umber   |       | 31 | 30   | 29 2 | 28 2 | 7 26 | 5 25 | 24 | 23 | 22 2  | 21 2 | 20 1  | 9 18       | 3 17 | 16   | 15 1 | 14 1  | 3 12             | 2 11 | 10    | 9 8  | 3 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
|-------|---------|-------|----|------|------|------|------|------|----|----|-------|------|-------|------------|------|------|------|-------|------------------|------|-------|------|-----|---|---|---|---|---|-----|
| ID    |         |       | В  | В    | В    | ВЕ   | 3 B  | В    | В  | В  | В     | В    | ВЕ    | 3 B        | В    | В    | Α    | A .   | 4 Α              | Α    | Α     | A A  | A A | A | Α | Α | Α | Α | АА  |
| Rese  | t OxFFF | FFFFF | 1  | 1    | 1    | 1 1  | 1 1  | 1    | 1  | 1  | 1     | 1    | 1 1   | l <b>1</b> | 1    | 1    | 1    | 1     | 1 1              | 1    | 1     | 1 :  | . 1 | 1 | 1 | 1 | 1 | 1 | 1 1 |
| ID    |         |       |    |      |      |      |      |      |    |    |       |      |       |            |      |      |      |       |                  |      |       |      |     |   |   |   |   |   |     |
| Α     | RW      | ENTER | [0 | 0xF  | FFFF | ]    |      |      |    | Du | ratio | on i | nee   | ded        | by   | exte | erna | al fl | ash <sup>·</sup> | to e | nte   | r DP | M.  |   |   |   |   |   |     |
|       |         |       |    |      |      |      |      |      |    | Du | ratio | on i | is gi | ven        | as I | ENT  | ER   | * 25  | 66 *             | 31.  | 25 r  | ıs   |     |   |   |   |   |   |     |
| В     | RW      | EXIT  | [0 | .OxF | FFFF | :]   |      |      |    | Du | ratio | on i | nee   | ded        | by   | exte | erna | al fl | ash '            | to e | xit [ | DPM  |     |   |   |   |   |   |     |
|       |         |       |    |      |      |      |      |      |    | Du | ratio | on i | is gi | ven        | as I | EXIT | * 2  | 256   | * 31             | 25   | ns.   |      |     |   |   |   |   |   |     |

### 7.25.11.53 ADDRCONF

Address offset: 0x624

Extended address configuration.







| Bit number       |         | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|---------|------------------------|------------------------------------------------------------------|
|                  |         |                        |                                                                  |
| ID               |         | FED                    | D                                                                |
| Reset 0x000000B7 |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1                          |
| ID R/W Field     |         |                        | Description                                                      |
|                  | OpByte0 | 2                      | Send opcode, BYTEO.                                              |
|                  | All     | 3                      | Send opcode, BYTE0, BYTE1.                                       |
| E RW WIPWAIT     |         |                        | Wait for write complete before sending command.                  |
|                  | Disable | 0                      | No wait.                                                         |
|                  | Enable  | 1                      | Wait.                                                            |
| F RW WREN        |         |                        | Send WREN (write enable opcode 0x06) before instruction.         |
|                  | Disable | 0                      | Do not send WREN.                                                |
|                  | Enable  | 1                      | Send WREN.                                                       |

# 7.25.11.54 CINSTRCONF

Address offset: 0x634

Custom instruction configuration register.

A new custom instruction is sent every time this register is written. The READY event will be generated when the custom instruction has been sent.

| Bit n | umber    |         |         | 31 30 2 | 29 28 | 27 26 | 25 24 | 1 23 22 2 | 21 20 : | 19    | 18 17  | 7 16 | 5 15  | 14 1  | 3 12  | 2 11  | 10   | 9 8   | 7    | 6    | 5    | 4   | 3 2 | 1 | 0 |
|-------|----------|---------|---------|---------|-------|-------|-------|-----------|---------|-------|--------|------|-------|-------|-------|-------|------|-------|------|------|------|-----|-----|---|---|
| ID    |          |         |         |         |       |       |       |           |         |       | Н      | l G  | F     | E [   | ) C   | В     | В    | ВЕ    | A    | Α    | Α    | Α , | 4 A | A | Α |
| Rese  | et 0x000 | 02000   |         | 0 0 0   | 0 0   | 0 0   | 0 0   | 0 0       | 0 0     | 0     | 0 0    | 0    | 0     | 0 1   | ۰ 0   | 0     | 0    | 0 0   | 0    | 0    | 0    | 0 ( | 0 0 | 0 | 0 |
| ID    |          |         |         |         |       |       |       |           |         |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
| Α     | RW       | OPCODE  |         | [0255   | 5]    |       |       | Opcod     | e of C  | ust   | om i   | nst  | ruct  | ion.  |       |       | _    |       |      |      |      |     |     |   | Π |
| В     | RW       | LENGTH  |         |         |       |       |       | Length    | of cu   | sto   | m in   | strı | uctio | n in  | nur   | nbe   | r of | byte  | es.  |      |      |     |     |   |   |
|       |          |         | 1B      | 1       |       |       |       | Send o    | pcode   | e oı  | nly.   |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         | 2B      | 2       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO.  | BYT   | ΞΟ.   |       |      |       |      |      |      |     |     |   |   |
|       |          |         | 3B      | 3       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO.  | BYT   | EO -: | > CII | NST  | RDA   | ΤО.Е | BYTE | E1.  |     |     |   |   |
|       |          |         | 4B      | 4       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO.  | BYT   | EO -: | > CII | NST  | RDA   | ΤО.Е | BYTE | E2.  |     |     |   |   |
|       |          |         | 5B      | 5       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO   | BYT   | E0 -: | > CII | NST  | RDA   | TO.E | BYTE | E3.  |     |     |   |   |
|       |          |         | 6B      | 6       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO   | BYT   | E0 -: | > CII | NST  | RDA   | T1.E | BYTE | E4.  |     |     |   |   |
|       |          |         | 7B      | 7       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO   | BYT   | E0 -: | > CII | NST  | RDA   | T1.E | BYTE | E5.  |     |     |   |   |
|       |          |         | 8B      | 8       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO   | BYT   | EO -: | > CII | NST  | RDA   | Т1.Е | BYTE | E6.  |     |     |   |   |
|       |          |         | 9B      | 9       |       |       |       | Send o    | pcode   | e, C  | INST   | RD   | ATO   | BYT   | EO -: | > CII | NST  | RDA   | T1.E | BYTE | E7.  |     |     |   |   |
| С     | RW       | LIO2    |         | [01]    |       |       |       | Level c   | of the  | 102   | 2 pin  | (if  | coni  | necte | ed) ( | duri  | ng t | rans  | mis  | sior | n of |     |     |   |   |
|       |          |         |         |         |       |       |       | custon    | n instr | uct   | ion.   |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
| D     | RW       | LIO3    |         | [01]    |       |       |       | Level c   | of the  | 103   | pin    | (if  | coni  | necte | ed) ( | duri  | ng t | rans  | mis  | sior | n of |     |     |   |   |
|       |          |         |         |         |       |       |       | custon    | n instr | uct   | ion.   |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
| E     | RW       | WIPWAIT |         |         |       |       |       | Wait fo   | or wri  | te c  | omp    | lete | e be  | fore  | sen   | ding  | g co | mm    | and  |      |      |     |     |   |   |
|       |          |         | Disable | 0       |       |       |       | No wa     | it.     |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         | Enable  | 1       |       |       |       | Wait.     |         |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
| F     | RW       | WREN    |         |         |       |       |       | Send V    | VREN    | (w    | rite e | enal | ble o | рсо   | de (  | 0x06  | ) b  | efore | ins  | tru  | ctio | n.  |     |   |   |
|       |          |         | Disable | 0       |       |       |       | Do not    | send    | W     | REN.   |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         | Enable  | 1       |       |       |       | Send V    | VREN.   |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
| G     | RW       | LFEN    |         |         |       |       |       | Enable    | Long    | fra   | me ı   | mod  | de. \ | Whe   | n en  | able  | ed,  | a cu  | ton  | n    |      |     |     |   |   |
|       |          |         |         |         |       |       |       | instruc   | tion t  | ran   | sact   | ion  | has   | to b  | e er  | nded  | by   | wri   | ing  | the  | 9    |     |     |   |   |
|       |          |         |         |         |       |       |       | LFSTOF    | field   |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         | Disable | 0       |       |       |       | Long fr   | rame    | mo    | de d   | isat | oled  |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         | Enable  | 1       |       |       |       | Long fr   | rame    | mo    | de e   | nab  | led   |       |       |       |      |       |      |      |      |     |     |   |   |
| Н     | RW       | LFSTOP  |         |         |       |       |       | Stop (f   | inalize | e) lo | ong f  | ran  | ne ti | ansa  | actio | on    |      |       |      |      |      |     |     |   |   |
|       |          |         | Stop    | 1       |       |       |       | Stop      |         |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |
|       |          |         |         |         |       |       |       |           |         |       |        |      |       |       |       |       |      |       |      |      |      |     |     |   |   |



### 7.25.11.55 CINSTRDATO

Address offset: 0x638

Custom instruction data register 0.



### 7.25.11.56 CINSTRDAT1

Address offset: 0x63C

Custom instruction data register 1.



### 7.25.11.57 IFTIMING

Address offset: 0x640

SPI interface timing.

| Bit r | umber    |         | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|-------------------|---------------------------------------------------------------------|
| ID    |          |         |                   | ссс                                                                 |
| Rese  | et 0x000 | 000200  | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |          |         |                   |                                                                     |
| С     | RW       | RXDELAY | [70]              | Timing related to sampling of the input serial data. The            |
|       |          |         |                   | value of RXDELAY specifies the number of prescaled 192              |
|       |          |         |                   | MHz cycles delay from the the rising edge of the SPI Clock          |
|       |          |         |                   | (SCK) until the input serial data is sampled. For example, if       |
|       |          |         |                   | RXDELAY is set to 0, the input serial data is sampled on the        |
|       |          |         |                   | rising edge of SCK.                                                 |



# 7.25.12 Electrical specification

## 7.25.12.1 Timing specification

| Symbol                   | Description                                 | Min. | Тур. | Max. | Units |
|--------------------------|---------------------------------------------|------|------|------|-------|
| F <sub>QSPI,CLK</sub>    | SCK frequency                               |      |      | 96   | MHz   |
| DC <sub>QSPI,CLK</sub>   | SCK duty cycle                              |      |      |      | %     |
| F <sub>QSPI,XIP,16</sub> | XIP fetch frequency for 16 bit instructions |      |      | 24   | MHz   |
| F <sub>QSPI,XIP,32</sub> | XIP fetch frequency for 32 bit instructions |      |      | 12   | MHz   |
| t <sub>MOH</sub>         | External memory output hold time            | 1.0  |      |      | ns    |



Figure 140: QSPI memory timing diagram

# 7.26 RADIO - 2.4 GHz radio

The 2.4 GHz radio transceiver is compatible with multiple radio standards such as Bluetooth Low Energy, IEEE 802.15.4, and Nordic's proprietary modes.

The main features of RADIO are:

- Multidomain 2.4 GHz radio transceiver, with
  - Bluetooth Low Energy 1 Mbps and 2 Mbps modes
  - Bluetooth Low Energy Long Range (125 kbps and 500 kbps) modes
  - Angle of Arrival (AoA) and Angle of Departure (AoD) direction finding using Bluetooth Low Energy
  - IEEE 802.15.4 250 kbps mode
  - 1 Mbps and 2 Mbps Nordic proprietary modes
- Best in class link budget and low power operation
- Efficient data interface with EasyDMA support
- Automatic address filtering and pattern matching

EasyDMA, in combination with an automated packet assembler, packet disassembler, automated CRC generator and CRC checker, makes it easy to configure and use RADIO. See the following figure for details.





Figure 141: RADIO block diagram

RADIO includes a device address match unit and an interframe spacing control unit that can be utilized to simplify device filtering and interframe spacing in Bluetooth Low Energy and similar applications.

RADIO also includes a received signal strength indicator (RSSI) and a bit counter. The bit counter generates events when a preconfigured number of bits are sent or received by RADIO.

# 7.26.1 Packet configuration

A RADIO packet contains the fields PREAMBLE, ADDRESS, SO, LENGTH, S1, PAYLOAD, and CRC. For Long Range (125 kbps and 500 kbps) Bluetooth Low Energy modes, fields CI, TERM1, and TERM2 are also included.

The content of a RADIO packet is illustrated in the following figures. RADIO sends the fields in the packet according to the sequence shown in the figures, starting on the left.



Figure 142: On-air packet layout



Figure 143: On-air packet layout for Long Range (125 kbps and 500 kbps) Bluetooth Low Energy modes

Not shown in the figures is the static payload add-on (the length of which is defined in PCNF1.STATLEN, and which is 0 bytes in a standard BLE packet). The static payload add-on is sent between PAYLOAD and CRC fields. RADIO sends the different fields in the packet in the order they are illustrated above, from left to right.

PREAMBLE is sent with least significant bit first on air. The size of the PREAMBLE depends on the mode selected in the MODE register:

• The PREAMBLE is one byte for MODE = Ble\_1Mbit as well as all Nordic proprietary operating modes (MODE = Nrf\_1Mbit and MODE = Nrf\_2Mbit), and PCNFO.PLEN has to be set accordingly. If the first bit of the ADDRESS is 0, the preamble will be set to 0xAA. Otherwise the PREAMBLE will be set to 0x55.

NORDIC

- For MODE = Ble\_2Mbit, the PREAMBLE must be set to 2 bytes through PCNF0.PLEN. If the first bit of the ADDRESS is 0, the preamble will be set to 0xAAAA. Otherwise the PREAMBLE will be set to 0x5555.
- For MODE = Ble LR125Kbit and MODE = Ble LR500Kbit, the PREAMBLE is 10 repetitions of 0x3C.
- For MODE = leee802154\_250Kbit, the PREAMBLE is 4 bytes and set to all zeros.

Radio packets are stored in memory inside instances of a RADIO packet data structure as illustrated below. The PREAMBLE, ADDRESS, CI, TERM1, TERM2, and CRC fields are omitted in this data structure. Fields SO, LENGTH, and S1 are optional.



Figure 144: Representation of a RADIO packet in RAM

The byte ordering on air is always least significant byte first for the ADDRESS and PAYLOAD fields, and most significant byte first for the CRC field. The ADDRESS fields are always transmitted and received least significant bit first. The CRC field is always transmitted and received most significant bit first. The endianness, i.e. the order in which the bits are sent and received, of the SO, LENGTH, S1, and PAYLOAD fields can be configured via PCNF1.ENDIAN.

The sizes of the SO, LENGTH, and S1 fields can be individually configured via SOLEN, LFLEN, and S1LEN in PCNFO respectively. If any of these fields are configured to be less than 8 bits, the least significant bits of the fields are used.

If SO, LENGTH, or S1 are specified with zero length, their fields will be omitted in memory. Otherwise each field will be represented as a separate byte, regardless of the number of bits in their on-air counterpart.

Independent of the configuration of PCNF1.MAXLEN, the combined length of SO, LENGTH, S1, and PAYLOAD cannot exceed 258 bytes.

# 7.26.2 Address configuration

The on-air radio ADDRESS field is composed of two parts, the base address field and the address prefix field.

The size of the base address field is configurable via PCNF1.BALEN. The base address is truncated from the least significant byte if the PCNF1.BALEN is less than 4. See Definition of logical addresses on page 430.

The on-air addresses are defined in the BASEO/BASE1 and PREFIXO/PREFIX1 registers. It is only when writing these registers that the user must relate to the actual on-air addresses. For other radio address registers, such as the TXADDRESS, RXADDRESSES, and RXMATCH registers, logical radio addresses ranging from 0 to 7 are being used. The relationship between the on-air radio addresses and the logical addresses is described in the following table.

| Logical address | Base address | Prefix byte |
|-----------------|--------------|-------------|
| 0               | BASE0        | PREFIXO.APO |
| 1               | BASE1        | PREFIXO.AP1 |
| 2               | BASE1        | PREFIXO.AP2 |
| 3               | BASE1        | PREFIXO.AP3 |
| 4               | BASE1        | PREFIX1.AP4 |
| 5               | BASE1        | PREFIX1.AP5 |
| 6               | BASE1        | PREFIX1.AP6 |
| 7               | BASE1        | PREFIX1.AP7 |

Table 121: Definition of logical addresses



# 7.26.3 Data whitening

RADIO can do packet whitening and de-whitening which is enabled in PCNF1.WHITEEN. When enabled, whitening and de-whitening will be handled by RADIO automatically as packets are sent and received.

The whitening word is generated using polynomial  $g(D) = D^7 + D^4 + 1$ , which then is XORed with the data packet that is to be whitened, or de-whitened. The linear feedback shift register is initialized via DATAWHITEIV. See the following figure.



Figure 145: Data whitening and de-whitening

Whitening and de-whitening will be performed over the whole packet except for the preamble and the address fields.

Including the address field in CRC check (CRCCNF.SKIPADDR=Include) is not supported for whitened packets.

### 7.26.4 CRC

The CRC generator in RADIO calculates the CRC over the whole packet excluding the preamble.

If useful, the address field can be excluded from the CRC calculation as well. See the CRCCNF register for more information.

The CRC polynomial is configurable as illustrated in the following figure, where bit 0 in the CRCPOLY register corresponds to  $X^0$  and bit 1 corresponds to  $X^1$  etc. See CRCPOLY on page 488 for more information.

Figure 146: CRC generation of an n bit CRC

The figure shows that the CRC is calculated by feeding the packet serially through the CRC generator. Before the packet is clocked through the CRC generator, the CRC generator's latches  $b_0$  through  $b_n$  will be initialized with a predefined value specified in the CRCINIT register. After the whole packet has been clocked through the CRC generator,  $b_0$  through  $b_n$  will hold the resulting CRC. This value will be used by RADIO during both transmission and reception. Latches  $b_0$  through  $b_n$  are not available to be read by the CPU at any time. However, a received CRC can be read by the CPU via the RXCRC register.

The length (n) of the CRC is configurable, see CRCCNF for more information.

NORDIC\*
SEMICONDUCTOR

Once the entire packet, including the CRC, has been received and no errors were detected, RADIO generates a CRCOK event. If CRC errors were detected, a CRCERROR event is generated.

The status of the CRC check can be read from the CRCSTATUS register after a packet has been received.

### 7.26.5 Radio states

Tasks and events are used to control the operating state of RADIO.

RADIO can enter the states described in the following table.

| State     | Description                                                                                          |
|-----------|------------------------------------------------------------------------------------------------------|
| DISABLED  | No operations are going on inside RADIO and the power consumption is at a minimum                    |
| RXRU      | RADIO is ramping up and preparing for reception                                                      |
| RXIDLE    | RADIO is ready for reception to start                                                                |
| RX        | Reception has been started and the addresses enabled in the RXADDRESSES register are being monitored |
| TXRU      | RADIO is ramping up and preparing for transmission                                                   |
| TXIDLE    | RADIO is ready for transmission to start                                                             |
| TX        | RADIO is transmitting a packet                                                                       |
| RXDISABLE | RADIO is disabling the receiver                                                                      |
| TXDISABLE | RADIO is disabling the transmitter                                                                   |

Table 122: RADIO state diagram

A state diagram showing an overview of RADIO is shown in the following figure.



Figure 147: Radio states

This figure shows how the tasks and events relate to RADIO's operation. RADIO does not prevent a task from being triggered from the wrong state. If a task is triggered from the wrong state, for example if the RXEN task is triggered from the RXDISABLE state, this may lead to incorrect behavior. The PAYLOAD event is always generated even if the payload is zero.

The END to START shortcut should not be used with IEEE 802.15.4 250 kbps mode. Use the PHYEND to START shortcut instead.

The END to START shortcut should not be used with Long Range (125 kbps and 500 kbps) Bluetooth Low Energy modes. Use the PHYEND to START shortcut instead.

## 7.26.6 Transmit sequence



Before RADIO can transmit a packet, it must first ramp-up in TX mode. See TXRU in Radio states on page 432 and Transmit sequence on page 433. A TXRU ramp-up sequence is initiated when the TXEN task is triggered. After RADIO has successfully ramped up it will generate the READY event indicating that a packet transmission can be initiated. A packet transmission is initiated by triggering the START task. The START task can first be triggered after RADIO has entered into the TXIDLE state.

The following figure illustrates a single packet transmission where the CPU manually triggers the different tasks needed to control the flow of RADIO, i.e. no shortcuts are used. If shortcuts are not used, a certain amount of delay caused by CPU execution is expected between READY and START, and between END and DISABLE. As illustrated in the following figure, RADIO will by default transmit 1s between READY and START, and between END and DISABLED. What is transmitted can be programmed through the DTX field in the MODECNFO register.



Figure 148: Transmit sequence

The following figure shows a slightly modified version of the transmit sequence where RADIO is configured to use shortcuts between READY and START, and between END and DISABLE, which means that no delay is introduced.



Figure 149: Transmit sequence using shortcuts to avoid delays

RADIO is able to send multiple packets one after the other without having to disable and re-enable RADIO between packets, as illustrated in the following figure.





Figure 150: Transmission of multiple packets

# 7.26.7 Receive sequence

Before RADIO is able to receive a packet, it must first ramp up in RX mode. See RXRU in Radio states on page 432 and Receive sequence on page 434 for more information.

An RXRU ramp up sequence is initiated when the RXEN task is triggered. After RADIO has successfully ramped up it will generate the READY event indicating that a packet reception can be initiated. A packet reception is initiated by triggering the START task. As illustrated in Radio states on page 432, the START task can first be triggered after RADIO has entered into the RXIDLE state.

The following figure shows a single packet reception where the CPU manually triggers the different tasks needed to control the flow of RADIO, i.e. no shortcuts are used. If shortcuts are not used, a certain amount of delay caused by CPU execution is expected between READY and START, and between END and DISABLE. RADIO will be listening and possibly receiving undefined data, represented with an 'X', from START and until a packet with valid preamble (P) is received.



Figure 151: Receive sequence

The following figure shows a modified version of the receive sequence, where RADIO is configured to use shortcuts between READY and START, and between END and DISABLE, which means that no delay is introduced.





Figure 152: Receive sequence using shortcuts to avoid delays

RADIO can receive consecutive packets without having to disable and re-enable RADIO between packets, as illustrated in the following figure.



Figure 153: Reception of multiple packets

# 7.26.8 Received signal strength indicator (RSSI)

RADIO implements a mechanism for measuring the power in the received signal. This feature is called received signal strength indicator (RSSI).

The RSSI is measured continuously and the value filtered using a single-pole IIR filter. After a signal level change, the RSSI will settle after approximately RSSI<sub>SETTLE</sub>.

Sampling of the received signal strength is started by using the RSSISTART task. The sample can be read from the RSSISAMPLE register.

The sample period of the RSSI is defined by RSSI<sub>PERIOD</sub>. The RSSISAMPLE will hold the filtered received signal strength after this sample period.

For the RSSI sample to be valid, RADIO has to be enabled in RX mode (RXEN task) and the reception has to be started (READY event followed by START task).

# 7.26.9 Interframe spacing (IFS)

Interframe spacing (IFS) is defined as the time, in microseconds, between two consecutive packets, starting from when the end of the last bit of the previous packet is received, to the beginning of the first bit of the subsequent packet that is transmitted.

RADIO can enforce this interval, as specified in the TIFS register, as long as the TIFS register is not specified to be shorter than RADIO's turnaround time (i.e. the time needed to switch off the receiver, and then



switch the transmitter back on). The TIFS register can be written any time before the last bit on air is received.

This timing is illustrated in the following figure.



Figure 154: IFS timing detail

The TIFS duration starts after the last bit on air (just before the END event), and elapses with the first bit being transmitted on air (just after READY event).

TIFS is only enforced if the shortcuts END to DISABLE and DISABLED to TXEN or END to DISABLE and DISABLED to RXEN are enabled.

TIFS is qualified for use in IEEE 802.15.4 250kbps mode, Bluetooth Low Energy Long Range (125 kbps and 500 kbps) modes, and Bluetooth Low Energy 1 Mbps and 2 Mbps modes, using the default ramp-up mode.

SHORTS and TIFS registers are not double-buffered, and can be updated at any point before the last bit on air is received. The MODE register is double-buffered and sampled at the TXEN or RXEN task.

### 7.26.10 Device address match

The device address match feature is tailored for device filtering in Bluetooth Low Energy and similar implementations.

This feature enables on-the-fly device address matching while receiving a packet on air. This feature only works in receive mode and when RADIO is configured for little endian, see PCNF1.ENDIAN for more information.

The device address match unit assumes that the first 48 bits of the payload are the device address and that bit number 6 in S0 is the TxAdd bit. See the *Bluetooth Core Specification* for more information about device addresses, TxAdd, and device filtering procedure.

RADIO is able to listen for eight different device addresses at the same time. These addresses are specified in a DAB/DAP register pair, one pair per address, in addition to a TxAdd bit configured in the DACNF register. The DAB register specifies the 32 least significant bits of the device address, while the DAP register specifies the 16 most significant bits of the device address.

Each of the device addresses can be individually included or excluded from the matching mechanism. This is configured in the DACNF register.



### 7.26.11 Bit counter

RADIO implements a simple counter that can be configured to generate an event after a specific number of bits have been transmitted or received.

By using shortcuts, this counter can be started from different events generated by RADIO and count relative to these.

The bit counter is started by triggering the BCSTART task, and stopped by triggering the BCSTOP task. A BCMATCH event will be generated when the bit counter has counted the number of bits specified in the BCC register. The bit counter will continue to count bits until the DISABLED event is generated or until the BCSTOP task is triggered. After a BCMATCH event, the CPU can reconfigure the BCC value for new BCMATCH events within the same packet.

The bit counter can only be started after RADIO has received the ADDRESS event.

The bit counter will stop and reset on either the BCSTOP, STOP, or DISABLE task, or the END event.

The following figure shows how the bit counter can be used to generate a BCMATCH event in the beginning of the packet payload, and again generate a second BCMATCH event after sending 2 bytes (16 bits) of the payload.



Figure 155: Bit counter example

# 7.26.12 Direction finding

RADIO implements the Angle of Arrival (AoA) and Angle of Departure (AoD) Bluetooth Low Energy feature, which can be used to determine the direction of a peer device. The feature is available for the Bluetooth Low Energy 1 and 2 Mbps modes.

When using this feature, the transmitter sends a packet with a constant tone extension (CTE) appended to the packet, after the CRC. During the CTE, the receiver can take IQ samples of the incoming signal.

An antenna array is employed at the transmitter (AoD) or at the receiver (AoA). The AoD transmitter, or AoA receiver, switches between the antennas, in order to collect IQ samples from the different antenna pairs. The IQ samples can be used to calculate the relative path lengths between the antenna pairs, which can be used to estimate the direction of the transmitter.

#### 7.26.12.1 CTE format

The CTE is from 16  $\mu$ s to 160  $\mu$ s and consists of an unwhitened sequence of 1s, equivalent to a continuous tone nominally offset from the carrier by +250 kHz for the Bluetooth Low Energy 1 Mbps PHY and +500



kHz for the 2 Mbps Bluetooth Low Energy PHY. The format of the CTE, when switching and/or sampling, is shown in the following figure.



Figure 156: Constant tone extension (CTE) structure

Antenna switching is performed during switch slots and the guard period. The AoA/AoD feature requires that one IQ sample is taken for each microsecond within the reference period, and once for each sample slot. Oversampling is possible by changing the sample spacing as described in IQ sampling on page 441. The switch slot and sample slot durations are either 1 or 2  $\mu$ s, but must be equal. The format of the CTE and switching and sampling procedures may be configured prior to, or during, packet transmission and reception. Alternatively, during packet reception, these operations can be configured by reading specific fields of the packet contents.

#### 7.26.12.2 Mode

Depending on the DFEMODE, the device performs the procedures shown in the following table.

|                   |                                           |    | DFEN | <b>NODE</b> |    |
|-------------------|-------------------------------------------|----|------|-------------|----|
|                   |                                           | A  | OA   | AC          | )D |
|                   |                                           | тх | RX   | TX          | RX |
|                   | Generating and transmitting CTE           | х  |      | х           |    |
| AoA/AoD Procedure | Receiving, interpreting, and sampling CTE |    | x    |             | х  |
|                   | Antenna switching                         |    | x    | x           |    |

Table 123: AoA/AoD Procedures performed as a function of DFEMODE and TX/RX mode

### 7.26.12.3 Inline configuration

When inline configuration is enabled during RX, further configuration of the AoA/AoD procedures is performed based on the values of the CP bit and the CTEInfo octet within the packet. This is enabled by setting CTEINLINECONF.CTEINLINECTRLEN. The CTEInfo octet is present only if the CP bit is set. The position of the CP bit and CTEInfo octet depends on whether the packet has a *Data Channel PDU* (CTEINLINECONF.CTEINFOINS1=InS1), or an *Advertising Channel PDU* (CTEINLINECONF.CTEINFOINS1=NotInS1).

#### **Data channel PDU**

For Data Channel PDUs, PCNF0.SOLEN must be 1 byte, and PCNF0.LFLEN must be 8 bits. To determine if S1 is present, the registers CTEINLINECONF.SOMASK and CTEINLINECONF.SOCONF forms a bitwise mask-and-test for the S0 field. If the bitwise AND between S0 and S0MASK equals S0CONF, then S1 is determined to be present. When present, the value of PCNF0.S1LEN will be ignored, as this is decided by the CP bit in the the following figure.



Figure 157: Data channel PDU header



When encrypting and decrypting Bluetooth Low Energy packets using the CCM peripheral, it is also required to set PCNF0.S1INCL=1. The CCM mode must be configured to use an 8-bit length field. The value of the CP bit is included in the calculation of the MIC, while the S1 field is ignored by the CCM calculation.

#### **Advertising channel PDU**

For advertising channel PDUs, the CTEInfo Flag replaces the CP bit. The CTEInfo Flag is within the extended header flag field in some of the advertising PDUs that employ the common extended advertising payload format (i.e. AUX\_SYNC\_IND, AUX\_CHAIN\_IND). The format of such packets is shown in the following figure.



Figure 158: Advertising channel PDU header

The CTEINLINECONF.SOCONF and CTEINLINECONF.SOMASK fields can be configured to accept only certain advertising PDU Types. If the extended header length is non-zero, the CTEInfo extended header flag is checked to determine whether CTEInfo is present. If a bit before the CTEInfo flag within the extended header flags is set, then the CTEInfo position is postponed 6 octets.

### **CTEInfo parsing**

The CTEInfo field is shown in the following figure.



Figure 159: CTEInfo field

The CTETIME field defines the length of the CTE in 8  $\mu$ s units. The valid upper bound of values can be adjusted using CTEINLINECONF.CTETIMEVALIDRANGE, including allowing use of the RFU bit within this field. If the CTETIME field is an invalid value of either 0 or 1, the CTE is assumed to be the minimum valid length of 16  $\mu$ s. The slot duration is determined by the CTEType field. In RX mode this determines whether the sample spacing as defined in CTEINLINECONF.CTEINLINERXMODE1US or CTEINLINECONF.CTEINLINERXMODE2US is used.

| СТЕТуре | Description             | TX switch spacing RX sample spacing during |                  | Sample spacing RX during |  |
|---------|-------------------------|--------------------------------------------|------------------|--------------------------|--|
|         |                         |                                            | reference period | reference period         |  |
| 0       | AoA, no switching       | -                                          | TSAMPLESPACING1  | TSAMPLESPACING2          |  |
| 1       | AoD, 1 μs slots         | 2 μs                                       | TSAMPLESPACING1  | CTEINLINERXMODE1US       |  |
| 2       | AoD, 2 μs slots         | 4 μs                                       | TSAMPLESPACING1  | CTEINLINERXMODE2US       |  |
| 3       | Reserved for future use |                                            |                  |                          |  |

Table 124: Switching and sampling spacing based on CTEType

# 7.26.12.4 Manual configuration

If CTEINLINECONF.CTEINLINECTRLEN is not set, then the packet is not parsed to determine the CTE parameters and the antenna switching and sampling is controlled by other registers (see Antenna switching on page 440). The length of the CTE is given in 8  $\mu$ s units by DFECTRL1.NUMBEROF8US. The start of the antenna switching and/or sampling (denoted as an AoA/AoD procedure), can be configured to start at some trigger with an additional offset. Using DFECTRL1.DFEINEXTENSION, the trigger can be



configured to be the end of the CRC, or alternatively, the ADDRESS event. The additional offset for antenna switching is configured using DFECTRL2.TSWITCHOFFSET. Similarly, the additional offset for antenna sampling is configured using DFECTRL2.TSAMPLEOFFSET.

### 7.26.12.5 Receive- and transmit sequences

The addition of the CTE to the transmitted packet is illustrated in the following figure.



Figure 160: Transmit sequence with DFE

The presence of CTE within a received packet is signalled by the CTEPRESENT event illustrated in the following figure.



Figure 161: Receive sequence with DFE

### 7.26.12.6 Antenna switching

RADIO can control up to 8 GPIO pins in order to control external antenna switches used in direction finding.

# Pin configuration

The eight antenna selection signals are mapped to physical pins according to the pin numbers specified in the PSEL.DFEGPIO[n] registers. Only pins that have the PSEL.DFEGPIO[n].CONNECTED field set to Connected will be controlled by RADIO. Pins that are disconnected will be controlled by GPIO.

During transmission in AoD TX mode or reception in AoA RX mode, RADIO automatically acquires the pins as needed. At times when RADIO does not use the pin, the pin is released to its default state and controlled by the GPIO configuration. Thus, the pin must be configured using the GPIO peripheral.

| Pin acquired by RADIO | Direction         | Value                      | Comment                                                                       |
|-----------------------|-------------------|----------------------------|-------------------------------------------------------------------------------|
| Yes                   | Output            | Specified in SWITCHPATTERN | Pin acquired by RADIO, and in use for DFE.                                    |
| No                    | Specified by GPIO | Specified by GPIO          | DFE not in progress. Pin has not been acquired by RADIO, but is available for |
|                       |                   |                            | DFE use.                                                                      |

Table 125: Pin configuration matrix for a connected and enabled pin [n]

### Switch pattern configuration

The values of the GPIOs while switching during the CTE are configured by writing successively to the SWITCHPATTERN register. The first write to SWITCHPATTERN is the GPIO pattern applied from the call of TASKS\_TXEN or TASKS\_RXEN until the first antenna switch is triggered. The second write sets the pattern for the reference period and is applied at the start of the guard period. The following writes set the pattern for the remaining switch slots and are applied at the start of each switch slot. If writing beyond the total number of antenna slots, the pattern will wrap to SWITCHPATTERN[2] and start over again. During operation, when the end of the SWITCHPATTERN buffer is reached, RADIO cycles back to SWITCHPATTERN[2]. At the end of the AoA/AoD procedure, SWITCHPATTERN[0] is applied to DFECTRL1.TSWITCHSPACING after the previous antenna switch. The SWITCHPATTERN buffer can be erased/cleared using CLEARPATTERN.

A minimum number of three patterns must be written to the SWITCHPATTERN register.

If CTEINLINECONF.CTEINLINECTRLEN is not set, then the antenna switch spacing is determined by DFECTRL1.TSWITCHSPACING (see Switching and sampling spacing based on CTEType on page 439). DFECTRL2.TSWITCHOFFSET determines the position of the first switch compared to the configurable start of CTE (see DFECTRL1.DFEINEXTENSION).

## 7.26.12.7 IQ sampling

RADIO uses DMA to write IQ samples recorded during the CTE to RAM. Alternatively, the magnitude and phase of the samples can be recorded using the DFECTRL1.SAMPLETYPE field. The samples are written to the location in RAM specified by DFEPACKET.PTR. The maximum number of samples to transfer are specified by DFEPACKET.MAXCNT and the number of samples transferred are given in DFEPACKET.AMOUNT. The IQ samples are recorded with respect to the RX carrier frequency. The format of the samples is provided in the following table.

| SAMPLETYPE       | Field     | Bits  | Description                                                                                   |  |  |  |  |
|------------------|-----------|-------|-----------------------------------------------------------------------------------------------|--|--|--|--|
| 0: I_Q (default) | Q         | 31:16 | 12 bits signed, sign extended to 16 bits. Out of range samples are saturated at value -32768. |  |  |  |  |
|                  | I         | 15:0  |                                                                                               |  |  |  |  |
| 1: MagPhase      | reserved  | 31:29 | Always zero                                                                                   |  |  |  |  |
|                  | magnitude | 28:16 | 13 bits unsigned. Equals 1.646756*sqrt(I² + Q²).                                              |  |  |  |  |
|                  | phase     | 15:0  | 9 bits signed, sign extended to 16 bits. Equals 64*atan2(Q, I) in the range [-201,201].       |  |  |  |  |

*Table 126: Format of samples* 

Oversampling is configured separately for the reference period and for the time after the reference period. During the reference period, the sample spacing is determined by DFECTRL1.TSAMPLESPACINGREF.

DFECTRL2.TSAMPLEOFFSET allows fine tuning the position of the samples in steps of 16 MHz periods (62.5 ns)

For the time after the reference period, if CTEINLINECONF.CTEINLINECTRLEN is disabled, the sample spacing is set in DFECTRL1.TSAMPLESPACING. However, when CTEINLINECONF.CTEINLINECTRLEN is enabled, the sample spacing is determined by two different registers, depending on whether the device is in AoA or AoD RX-mode.

For AoD RX mode, the sample spacing after the reference period is determined by the CTEType in the packet, as listed in the following table.

NORDIC

| СТЕТуре        | Sample spacing                   |
|----------------|----------------------------------|
| AoD 1 µs slots | CTEINLINECONF.CTEINLINERXMODE1US |
| AoD 2 µs slots | CTEINLINECONF.CTEINLINERXMODE2US |
| Other          | DFECTRL1.TSAMPLESPACING          |

Table 127: Sample spacing when CTEINLINECONF.CTEINLINECTRLEN is set and the device is in AoD RX mode

For AoA RX mode, the sample spacing after the reference period is determined by DFECTRL1.TSWITCHSPACING, as listed in the following table.

| DFECTRL1.TSWITCHSPACING | Sample spacing                   |
|-------------------------|----------------------------------|
| 2 μs                    | CTEINLINECONF.CTEINLINERXMODE1US |
| 4 μs                    | CTEINLINECONF.CTEINLINERXMODE2US |
| Other                   | DFECTRL1.TSAMPLESPACING          |

Table 128: Sample spacing when CTEINLINECONF.CTEINLINECTRLEN is set and the device is in AoA RX mode

For the reference and switching periods, DFECTRL1.TSAMPLESPACINGREF and DFECTRL1.TSAMPLESPACING can be used to achieve oversampling.

# 7.26.13 IEEE 802.15.4 operation

With the MODE=Ieee802154\_250kbit, RADIO will comply with the IEEE 802.15.4-2006 standard implementing its 250 kbps, 2450 MHz, O-QPSK PHY.

The IEEE 802.15.4 standard differs from Nordic's proprietary and Bluetooth Low Energy modes. Notable differences include modulation scheme, channel structure, packet structure, security, and medium access control.

The main features of the IEEE 802.15.4 mode are:

- Ultra-low power 250 kbps, 2450 MHz, IEEE 802.15.4-2006 compliant link
- Clear channel assessment (CCA)
- Energy detection (ED) scan
- · CRC generation

#### 7.26.13.1 Packet structure

The IEEE 802.15.4 standard defines an on-the-air frame/packet that is different from what is used in Bluetooth Low Energy.

The following figure provides an overview of the physical frame structure and its timing.



Figure 162: IEEE 802.15.4 frame format (PPDU)

The standard uses the term *octet* for an 8-bit storage unit within the PPDU. For timing, the value *symbol* is used, and it has a duration of  $16 \mu s$ .

The total usable payload (PSDU) is 127 octets, but when CRC is in use, this is reduced to 125 octets of usable payload.



The preamble sequence consists of four octets that are all zero, and are used for synchronizing RADIO's receiver. Following the preamble is the single octet *start of frame delimiter (SFD)*, with a fixed value of 0xA7. An alternate SFD can be programmed through the SFD register, providing an initial level of frame filtering for those who choose non-standard compliance. It is a valuable feature when operating in a congested or private network. The preamble sequence and the SFD are generated by RADIO, and are not programmed by the user into the frame buffer.

Following the five octet *synchronization header (SHR)* is the single octet *phy header (PHR)*. The least significant seven bits of PHR denote the frame length of the following PSDU. The most significant bit is reserved and is set to 0 for frames that are standard compliant. RADIO reports all eight bits which can be used to carry additional information. The PHR is the first byte written to the frame data memory pointed to by PACKETPTR. Frames with zero length are discarded, and the FRAMESTART event is not generated in this case.

The next N octets carry the data of the PHY packet, where N equals the value of the PHR. For an implementation also using the IEEE 802.15.4 medium access control (MAC) layer, the PHY data is a MAC frame of N-2 octets, since two octets occupy a CRC field.

An IEEE 802.15.4 MAC layer frame consists of the following:

- A header:
  - The frame control field (FCF)
  - The sequence number
  - Addressing fields
- A payload
- The 16-bit frame control sequence (FCS)



Figure 163: IEEE 802.15.4 frame format (MPDU)

The two FCF octets contain information about the frame type, addressing, and other control flags. This field is decoded when using the assisted operating modes offered by RADIO.

The sequence number is a single octet in size and is unique for a frame. It is used in the associated acknowledgement frame sent upon successful frame reception.

The addressing field can be zero (acknowledgement frame) or up to 20 octets in size. The field is used to direct packets to the correct recipient and denote its origin. IEEE 802.15.4 bases its addressing on networks being organized in PANs with 16-bit identifier and nodes having a 16-bit or 64-bit address. In the assisted receive mode, these parameters are analyzed for address matching and acknowledgement.

The MAC payload carries the data of the next higher layer, or in the case of a MAC command frame, information used by the MAC layer itself.



The two last octets contain the 16-bit ITU-T CRC. The FCS is calculated over the MAC header (MHR) and MAC payload (MSDU) parts of the frame. This field is calculated automatically when sending a frame, or indicated in the CRCSTATUS register when a frame is received. If configured, this feature is maintained autonomously by the CRC module.

### 7.26.13.2 Operating frequencies

The IEEE 802.15.4 standard defines 16 channels in the 2450 MHz frequency band. The channels are numbered from 11 to 26, and each channel is 5 MHz wide.

To choose the correct channel center frequency, the FREQUENCY register must be programmed according to the following table.

| IEEE 802.15.4 channel | Center frequency (MHz) | FREQUENCY setting |
|-----------------------|------------------------|-------------------|
| Channel 11            | 2405                   | 5                 |
| Channel 12            | 2410                   | 10                |
| Channel 13            | 2415                   | 15                |
| Channel 14            | 2420                   | 20                |
| Channel 15            | 2425                   | 25                |
| Channel 16            | 2430                   | 30                |
| Channel 17            | 2435                   | 35                |
| Channel 18            | 2440                   | 40                |
| Channel 19            | 2445                   | 45                |
| Channel 20            | 2450                   | 50                |
| Channel 21            | 2455                   | 55                |
| Channel 22            | 2460                   | 60                |
| Channel 23            | 2465                   | 65                |
| Channel 24            | 2470                   | 70                |
| Channel 25            | 2475                   | 75                |
| Channel 26            | 2480                   | 80                |

Table 129: IEEE 802.15.4 center frequency definition

## 7.26.13.3 Energy detection (ED)

As required by the IEEE 802.15.4 standard, it must be possible to sample the received signal power within the bandwidth of a channel, for the purpose of determining presence of activity.

To prevent the channel signal from being decoded, the shortcut between the READY event and the START task should be disabled before putting RADIO in receive mode. The energy detection (ED) measurement time, where RSSI samples are averaged, is 8 symbol periods, corresponding to 128 µs. The standard further specifies the measurement to be a number between 0 and 255, where 0 shall indicate received power less than 10 dB above the selected receiver sensitivity. The power range of the ED values must be at least a 40 dB linear mapping with accuracy of ±6 dB. See section 6.9.7 Receiver ED in the IEEE 802.15.4 standard for further details.

The following example shows how to perform a single energy detection measurement and convert to IEEE 802.15.4 scale.



#### IEEE 802.15.4 ED measurement example

```
#define ED_RSSISCALE 4 // From electrical specifications
uint8_t sample_ed(void)
{
   int val;
   NRF_RADIO->TASKS_EDSTART = 1; // Start
   while (NRF_RADIO->EVENTS_EDEND != 1) {
        // CPU can sleep here or do something else
        // Use of interrupts are encouraged
      }
   val = NRF_RADIO->EDSAMPLE * ED_RSSISCALE; // Read level
   return (uint8_t)(val>255 ? 255 : val); // Convert to IEEE 802.15.4 scale
}
```

For scaling between hardware value and dBm, see equation Conversion between hardware value and dBm on page 447.

The mlme-scan.req primitive of the MAC layer uses the ED measurement to detect channels where there might be wireless activity. To assist this primitive, a tailored mode of operation is available where the ED measurement runs for a defined number of iterations keeping track of the maximum ED level. This is enganged by writing the EDCNT register to a value different from 0, where it will run the specified number of iterations and report the maximum energy measurement in the EDSAMPLE register. The scan is started with EDSTART task and its end indicated with the EDEND event. This significantly reduces the interrupt frequency and therefore power consumption. The following figure shows how the ED measurement will operate depending on the EDCNT register.





Figure 164: Energy detection measurement examples

The scan is stopped by writing the EDSTOP task. It is followed by the EDSTOPPED event when the module has terminated.

## 7.26.13.4 Clear channel assessment (CCA)

The IEEE 802.15.4 standard implements a listen-before-talk channel access method to avoid collisions when transmitting, known as *carrier sense multiple access with collision avoidance (CSMA-CA)*. The key part of this is measuring if the wireless medium is busy or not.



The following clear channel assesment modes are supported:

- *CCA Mode 1* (energy above threshold) The medium is reported busy upon detecting any energy above the FD threshold.
- *CCA Mode 2* (carrier sense only) The medium is reported busy upon detection of a signal compliant with the IEEE 802.15.4 standard with the same modulation and spreading characteristics.
- CCA Mode 3 (carrier sense with energy above threshold) The medium is reported busy using a logical combination (AND/OR) between the results from CCA Mode 1 and CCA Mode 2.

The clear channel assessment should survey a period equal to 8 symbols or 128 μs.

RADIO must be in RX mode and be able to receive correct packets when performing the CCA. The shortcut between READY and START must be disabled if baseband processing is not to be performed while the measurement is running.

Register EDSAMPLE on page 492 is updated at the end of the clear channel assessment and can be used to read the energy level measured during the procedure. For CCACTRL.CCAMODE=EdModeEdModeTest1, EDSAMPLE holds the first ED measurement. For the other CCA modes, EDSAMPLE holds the average ED value.

#### **CCA Mode 1**

CCA Mode 1 is enabled by first configuring the field CCACTRL.CCAMODE=EdMode and writing the CCACTRL.CCAEDTHRES field to a chosen value. Once the CCASTART task is written, RADIO will perform an ED measurement for 8 symbols and compare the measured level with that found in the CCACTRL.CCAEDTHRES field. If the measured value is higher than or equal to this threshold, the CCABUSY event is generated. If the measured level is less than the threshold, the CCAIDLE event is generated.

#### CCA Mode 2

CCA Mode 2 is enabled by configuring CCACTRL.CCAMODE=CarrierMode. RADIO will sample to see if a valid SFD is found during the 8 symbols. If a valid SFD is detected, the CCABUSY event is generated and the device should not send any data. The CCABUSY event is also generated if the scan was performed during an ongoing frame reception. In the case where the measurement period completes with no SFD detection, the CCAIDLE event is generated. When CCACTRL.CCACORRCNT is not zero, the algorithm will look at the correlator output in addition to the SFD detection signal. If a SFD is reported during the scan period, it will terminate immidiately indicating busy medium. Similarly, if the number of peaks above CCACTRL.CCACORRTHRES crosses the CCACTRL.CCACORRCNT, the CCACTRL.CCABUSY event is generated. If less than CCACORRCOUNT crossings are found and no SFD is reported, the CCAIDLE event will be generated and the device can send data.

### **CCA Mode 3**

CCA Mode 3 is enabled by configuring CCACTRL.CCAMODE=CarrierAndEdMode or CCACTRL.CCAMODE=CarrierOrEdMode, performing the required logical combination of the result from CCA Mode 1 and 2. The CCABUSY or CCAIDLE events are generated by ANDing or ORing the energy above threshold and carrier detection scans.

#### **Shortcuts**

An ongoing CCA can always be stopped by issuing the CCASTOP task. This will trigger the associated CCASTOPPED event.

For CCA mode automation, the following shortcuts are available:

To automatically switch between RX mode (when performing the CCA) and to TX mode where the
packet is sent, the shortcut between CCAIDLE and TXEN, in conjunction with the short between
CCAIDLE and STOP must be used.

NORDIC

- To automatically disable RADIO whenever the CCA reports a busy medium, the shortcut between CCABUSY and DISABLE can be used.
- To immediately start a CCA after ramping up into RX mode, the shortcut between RXREADY and CCASTART can be used.

#### Conversion

The conversion from a CCAEDTHRES, LQI, or EDSAMPLE value to dBm can be done with the following equation, where VAL<sub>HARDWARE</sub> is either CCAEDTHRES, LQI, or EDSAMPLE. LQI and EDSAMPLE are hardware-reported values, while CCAEDTHRES is set by software. Constants ED\_RSSISCALE and ED\_RSSIOFFS are from electrical specifications.

```
P_{RF}[dBm] = ED_RSSIOFFS + VAL_{HARDWARE}
```

Figure 165: Conversion between hardware value and dBm

The ED\_RSSISCALE constant is used to calculate power in 802.15.4 units (0-255):

```
P_{RF}[802.15.4 \text{ units}] = MIN(ED_RSSISCALE \times VAL_{HARDWARE}, 255)
```

Figure 166: Conversion between hardware value and 802.15.4 units (0-255)

### 7.26.13.5 Cyclic redundancy check (CRC)

The IEEE 802.15.4 standard uses a 16-bit ITU-T cyclic redundancy check (CRC) calculated over the MAC header (MHR) and MAC service data unit (MSDU).

The standard defines the following generator polynomial:

```
G(x) = x^{16} + x^{12} + x^5 + 1
```

In RX mode, RADIO will trigger the CRC module when the first octet after the frame length (PHR) is received. The CRC will then update on each consecutive octet received. When a complete frame is received the CRCSTATUS register will be updated accordingly and the CRCOK or CRCERROR events generated. When the CRC module is enabled it will not write the two last octets (CRC) to the frame Data RAM. When transmitting, the CRC will be computed on the fly, starting with the first octet after PHR, and inserted as the two last octets in the frame. The EasyDMA will fetch frame length minus 2 octets from RAM and insert the CRC octets at their correct positions in the frame.

The following code shows how to configure the CRC module for correct operation when in IEEE 802.15.4 mode. The CRCCNF is written to 16-bit CRC and the CRCPOLY is written to  $0 \times 11021$ . The start value used by IEEE 802.15.4 is 0 and CRCINIT is configured to reflect this.

The ENDIANESS subregister must be set to little-endian since the FCS field is transmitted from left bit to right.

### 7.26.13.6 Transmit sequence

The transmission is started by first putting RADIO in RX mode and triggering the RXEN task.

An outline of the IEEE 802.15.4 transmission is illustrated in the following figure.





Figure 167: IEEE 802.15.4 transmit sequence

The receiver will ramp up and enter the RXIDLE state where the READY event is generated. Upon receiving the ready event, the CCA is started by triggering the CCASTART task. The chosen mode of assessment (CCACTRL.CCAMODE register) will be performed and signal the CCAIDLE or CCABUSY event 128  $\mu$ s later. If the CCABUSY event is received, RADIO will have to retry the CCA after a specific back-off period. This is outlined in the *IEEE 802.15.4 standard*, *Figure 69 in section 7.5.1.4 The CSMA-CA algorithm*.

If the CCAIDLE event is generated, a write to the TXEN task register enters RADIO in TXRU state. The READY event will be generated when RADIO is in TXIDLE state and ready to transmit. With the PACKETPTR pointing to the length (PHR) field of the frame, the START task can be written. RADIO will send the four octet preamble sequence followed by the start of frame delimiter (SFD register). The first byte read from the Data RAM is the length field (PHR) followed by the transmission of the number of bytes indicated as the frame length. If the CRC module is configured it will run for PHR-2 octets. The last two octets will be substituted with the results from running the CRC. The necessary CRC parameters are sampled on the START task. The FCS field of the frame is little endian.

In addition to the already available shortcuts, one is provided between the READY event and the CCASTART task so that a CCA can automatically start when the receiver is ready. A second shortcut has been added between the CCAIDLE event and the TXEN task, so that upon detecting a clear channel RADIO can immediately enter TX mode.

### 7.26.13.7 Receive sequence

The reception is started by first putting RADIO in receive mode. After writing to the RXEN task, RADIO will start ramping up and enter the RXRU state.

When the READY event is generated, RADIO enters the RXIDLE mode. For the baseband processing to be enabled, the START task must be written. An outline of the IEEE 802.15.4 reception can be found in the following figure.





Figure 168: IEEE 802.15.4 receive sequence

When a valid SHR is received, RADIO will start storing future octets (starting with PHR) to the data memory pointed to by PACKETPTR. After the SFD octet is received, the FRAMESTART event is generated. If the CRC module is enabled it will start updating with the second byte received (first byte in payload) and run for the full frame length. The two last bytes in the frame are not written to RAM when CRC is configured. However, if the result of the CRC after running the full frame is zero, the CRCOK event will be generated. The END event is generated when the last octet has been received and is available in data memory.

When a packet is received, a link quality indicator (LQI) is also generated and appended immediately after the last received octet. When using an IEEE 802.15.4 compliant frame, this will be just after the MSDU since the FCS is not reported. In the case of a non-compliant frame, it will be appended after the full frame. The LQI reported by the hardware must be converted to the IEEE 802.15.4 range by an 8-bit saturating multiplication of 4, as shown in IEEE 802.15.4 ED measurement example on page 445. The LQI is only valid for frames equal to or longer than three octets. When receiving a frame, the RSSI (reported as negative dB) will be measured at three points during the reception. These three values will be sorted and the middle one selected (median 3) to be remapped within the LQI range. The following figure illustrates the LQI measurement and how the data is arranged in data memory.





Figure 169: IEEE 802.15.4 frame in data memory

A shortcut has been added between the FRAMESTART event and the BCSTART task. This can be used to trigger a BCMATCH event after N bits, such as when inspecting the MAC addressing fields.

# 7.26.13.8 Interframe spacing (IFS)

The IEEE 802.15.4 standard defines a specific time that is alotted for the MAC sublayer to process received data. The interframe spacing (IFS) is used to prevent two frames from being transmitted too close together. If the transmission is requesting an acknowledgement, the space before the second frame shall be at least one IFS period.

IFS is determined to be one of the following:

- IFS equals macMinSIFSPeriod (12 symbols) if the MPDU is less than or equal to aMaxSIFSFrameSize (18 octets) octets
- IFS equals macMinLIFSPeriod (40 symbols) if the MPDU is larger than aMaxSIFSFrameSize

Using the efficient assisted modes in RADIO, the TIFS will be programmed with the correct value based on the frame being transmitted. If the assisted modes are not in use, the TIFS register must be updated manually. The following figure provides details on what IFS period is valid in both acknowledged and unacknowledged transmissions.





Figure 170: Interframe spacing examples

# 7.26.14 EasyDMA

RADIO uses EasyDMA to read and write packets to RAM without CPU involvement.

As illustrated in RADIO block diagram on page 429, RADIO's EasyDMA utilizes the same PACKETPTR for receiving and transmitting packets. This pointer should be reconfigured by the CPU each time before RADIO is started by the START task. The PACKETPTR register is double-buffered, meaning that it can be updated and prepared for the next transmission.

The END event indicates that the last bit has been processed by RADIO. The DISABLED event is issued to acknowledge that a DISABLE task is done.

The structure of a packet is described in detail in Packet configuration on page 429. The data that is stored in Data RAM and transported by EasyDMA consists of the following fields:

- S0
- LENGTH
- S1
- PAYLOAD

In addition, a static add-on is sent immediately after the payload.

The size of each of the above fields in the frame is configurable (see Packet configuration on page 429), and the space occupied in RAM depends on these settings. The size of the field can be zero, as long as the resulting frame complies with the chosen RF protocol.

All fields are extended in size to align with a byte boundary in RAM. For instance, a 3-bit long field on air will occupy 1 byte in RAM while a 9-bit long field will be extended to 2 bytes.

The packet's elements can be configured as follows:

- CI, TERM1, and TERM2 fields are only present in Bluetooth Low Energy Long Range mode
- S0 is configured through the PCNF0.S0LEN field
- LENGTH is configured through the PCNFO.LFLEN field
- S1 is configured through the PCNFO.S1LEN field
- Payload size is configured through the value in RAM corresponding to the LENGTH field
- Static add-on size is configured through the PCNF1.STATLEN field

The PCNF1.MAXLEN field configures the maximum packet payload plus add-on size in number of bytes that can be transmitted or received by RADIO. This feature can be used to ensure that RADIO does not overwrite, or read beyond, the RAM assigned to the packet payload. This means that if the LENGTH field of the packet payload exceedes PCNF1.STATLEN, and the LENGTH field in the packet specifies a packet larger than configured in PCNF1.MAXLEN, the payload will be truncated to the length specified in PCNF1.MAXLEN.



**Note:** The PCNF1.MAXLEN field includes the payload and the add-on, but excludes the size occupied by the SO, LENGTH, and S1 fields. This has to be taken into account when allocating RAM.

If the payload and add-on length is specified larger than PCNF1.MAXLEN, RADIO will still transmit or receive in the same way as before, except the payload is now truncated to PCNF1.MAXLEN. The packet's LENGTH field will not be altered when the payload is truncated. RADIO will calculate CRC as if the packet length is equal to PCNF1.MAXLEN.

**Note:** If PACKETPTR is not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

The END event indicates that the last bit has been processed by RADIO. The DISABLED event is issued to acknowledge that an DISABLE task is done.

# 7.26.15 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description   | Configuration |
|---------------------|------------|----------|----------------|--------------|---------------|---------------|
| 0x41008000 NETWORK  | RADIO      | RADIO    | NS             | NA           | 2.4 GHz radio |               |

Table 130: Instances

| Register            | Offset | Security | Description                                                              |
|---------------------|--------|----------|--------------------------------------------------------------------------|
| TASKS_TXEN          | 0x000  |          | Enable RADIO in TX mode                                                  |
| TASKS_RXEN          | 0x004  |          | Enable RADIO in RX mode                                                  |
| TASKS_START         | 0x008  |          | Start RADIO                                                              |
| TASKS_STOP          | 0x00C  |          | Stop RADIO                                                               |
| TASKS_DISABLE       | 0x010  |          | Disable RADIO                                                            |
| TASKS_RSSISTART     | 0x014  |          | Start the RSSI and take one single sample of the receive signal strength |
| TASKS_RSSISTOP      | 0x018  |          | Stop the RSSI measurement                                                |
| TASKS_BCSTART       | 0x01C  |          | Start the bit counter                                                    |
| TASKS_BCSTOP        | 0x020  |          | Stop the bit counter                                                     |
| TASKS_EDSTART       | 0x024  |          | Start the energy detect measurement used in IEEE 802.15.4 mode           |
| TASKS_EDSTOP        | 0x028  |          | Stop the energy detect measurement                                       |
| TASKS_CCASTART      | 0x02C  |          | Start the clear channel assessment used in IEEE 802.15.4 mode            |
| TASKS_CCASTOP       | 0x030  |          | Stop the clear channel assessment                                        |
| SUBSCRIBE_TXEN      | 0x080  |          | Subscribe configuration for task TXEN                                    |
| SUBSCRIBE_RXEN      | 0x084  |          | Subscribe configuration for task RXEN                                    |
| SUBSCRIBE_START     | 0x088  |          | Subscribe configuration for task START                                   |
| SUBSCRIBE_STOP      | 0x08C  |          | Subscribe configuration for task STOP                                    |
| SUBSCRIBE_DISABLE   | 0x090  |          | Subscribe configuration for task DISABLE                                 |
| SUBSCRIBE_RSSISTART | 0x094  |          | Subscribe configuration for task RSSISTART                               |
| SUBSCRIBE_RSSISTOP  | 0x098  |          | Subscribe configuration for task RSSISTOP                                |
| SUBSCRIBE_BCSTART   | 0x09C  |          | Subscribe configuration for task BCSTART                                 |
| SUBSCRIBE_BCSTOP    | 0x0A0  |          | Subscribe configuration for task BCSTOP                                  |
| SUBSCRIBE_EDSTART   | 0x0A4  |          | Subscribe configuration for task EDSTART                                 |
| SUBSCRIBE_EDSTOP    | 0x0A8  |          | Subscribe configuration for task EDSTOP                                  |
| SUBSCRIBE_CCASTART  | 0x0AC  |          | Subscribe configuration for task CCASTART                                |
| SUBSCRIBE_CCASTOP   | 0x0B0  |          | Subscribe configuration for task CCASTOP                                 |
| EVENTS_READY        | 0x100  |          | RADIO has ramped up and is ready to be started                           |
| EVENTS_ADDRESS      | 0x104  |          | Address sent or received                                                 |
| EVENTS_PAYLOAD      | 0x108  |          | Packet payload sent or received                                          |
| EVENTS_END          | 0x10C  |          | Packet sent or received                                                  |
|                     |        |          |                                                                          |



| Register           | Offset | Security | Description                                                                      |  |
|--------------------|--------|----------|----------------------------------------------------------------------------------|--|
| EVENTS_DISABLED    | 0x110  |          | RADIO has been disabled                                                          |  |
| EVENTS DEVMATCH    | 0x114  |          | A device address match occurred on the last received packet                      |  |
| EVENTS DEVMISS     | 0x118  |          | No device address match occurred on the last received packet                     |  |
| EVENTS_RSSIEND     | 0x11C  |          | Sampling of receive signal strength complete                                     |  |
| EVENTS_BCMATCH     | 0x128  |          | Bit counter reached bit count value                                              |  |
| EVENTS_CRCOK       | 0x130  |          | Packet received with CRC ok                                                      |  |
| EVENTS_CRCERROR    | 0x134  |          | Packet received with CRC error                                                   |  |
| EVENTS_FRAMESTART  | 0x138  |          | IEEE 802.15.4 length field received                                              |  |
| EVENTS_EDEND       | 0x13C  |          | Sampling of energy detection complete. A new ED sample is ready for readout from |  |
| _                  |        |          | the RADIO.EDSAMPLE register.                                                     |  |
| EVENTS_EDSTOPPED   | 0x140  |          | The sampling of energy detection has stopped                                     |  |
| EVENTS_CCAIDLE     | 0x144  |          | Wireless medium in idle - clear to send                                          |  |
| EVENTS_CCABUSY     | 0x148  |          | Wireless medium busy - do not send                                               |  |
| EVENTS_CCASTOPPED  | 0x14C  |          | The CCA has stopped                                                              |  |
| EVENTS_RATEBOOST   | 0x150  |          | Ble LR CI field received, receive mode is changed from Ble LR125Kbit to          |  |
|                    |        |          | Ble_LR500Kbit.                                                                   |  |
| EVENTS_TXREADY     | 0x154  |          | RADIO has ramped up and is ready to be started TX path                           |  |
| EVENTS RXREADY     | 0x158  |          | RADIO has ramped up and is ready to be started RX path                           |  |
| EVENTS_MHRMATCH    | 0x15C  |          | MAC header match found                                                           |  |
| EVENTS_SYNC        | 0x168  |          | Preamble indicator                                                               |  |
| EVENTS_PHYEND      | 0x16C  |          | Generated when last bit is sent on air, or received from air                     |  |
| EVENTS_CTEPRESENT  | 0x170  |          | CTE is present (early warning right after receiving CTEInfo byte)                |  |
| PUBLISH_READY      | 0x180  |          | Publish configuration for event READY                                            |  |
| PUBLISH ADDRESS    | 0x184  |          | Publish configuration for event ADDRESS                                          |  |
| PUBLISH_PAYLOAD    | 0x188  |          | Publish configuration for event PAYLOAD                                          |  |
| PUBLISH END        | 0x18C  |          | Publish configuration for event END                                              |  |
| PUBLISH_DISABLED   | 0x190  |          | Publish configuration for event DISABLED                                         |  |
| PUBLISH_DEVMATCH   | 0x194  |          | Publish configuration for event DEVMATCH                                         |  |
| PUBLISH_DEVMISS    | 0x198  |          | Publish configuration for event DEVMISS                                          |  |
| PUBLISH RSSIEND    | 0x19C  |          | Publish configuration for event RSSIEND                                          |  |
| PUBLISH_BCMATCH    | 0x1A8  |          | Publish configuration for event BCMATCH                                          |  |
| PUBLISH_CRCOK      | 0x1B0  |          | Publish configuration for event CRCOK                                            |  |
| PUBLISH CRCERROR   | 0x1B4  |          | Publish configuration for event CRCERROR                                         |  |
| PUBLISH_FRAMESTART | 0x1B8  |          | Publish configuration for event FRAMESTART                                       |  |
| PUBLISH EDEND      | 0x1BC  |          | Publish configuration for event EDEND                                            |  |
| PUBLISH EDSTOPPED  | 0x1C0  |          | Publish configuration for event EDSTOPPED                                        |  |
| PUBLISH CCAIDLE    | 0x1C4  |          | Publish configuration for event CCAIDLE                                          |  |
| PUBLISH CCABUSY    | 0x1C8  |          | Publish configuration for event CCABUSY                                          |  |
| PUBLISH_CCASTOPPED | 0x1CC  |          | Publish configuration for event CCASTOPPED                                       |  |
| PUBLISH_RATEBOOST  | 0x1D0  |          | Publish configuration for event RATEBOOST                                        |  |
| PUBLISH_TXREADY    | 0x1D4  |          | Publish configuration for event TXREADY                                          |  |
| PUBLISH RXREADY    | 0x1D8  |          | Publish configuration for event RXREADY                                          |  |
| PUBLISH_MHRMATCH   | 0x1DC  |          | Publish configuration for event MHRMATCH                                         |  |
| PUBLISH_SYNC       | 0x1E8  |          | Publish configuration for event SYNC                                             |  |
| PUBLISH_PHYEND     | 0x1EC  |          | Publish configuration for event PHYEND                                           |  |
| PUBLISH_CTEPRESENT | 0x1F0  |          | Publish configuration for event CTEPRESENT                                       |  |
| SHORTS             | 0x200  |          | Shortcuts between local events and tasks                                         |  |
| INTENSET           | 0x304  |          | Enable interrupt                                                                 |  |
| INTENCLR           | 0x308  |          | Disable interrupt                                                                |  |
| CRCSTATUS          | 0x400  |          | CRC status                                                                       |  |
| RXMATCH            | 0x408  |          | Received address                                                                 |  |
| RXCRC              | 0x40C  |          | CRC field of previously received packet                                          |  |
| DAI                | 0x410  |          | Device address match index                                                       |  |
|                    | 0      |          |                                                                                  |  |



| Register         | Offset | Security | Description                                                       |
|------------------|--------|----------|-------------------------------------------------------------------|
| PDUSTAT          | 0x414  |          | Payload status                                                    |
| CTESTATUS        | 0x44C  |          | CTEInfo parsed from received packet                               |
| DFESTATUS        | 0x458  |          | DFE status information                                            |
| PACKETPTR        | 0x504  |          | Packet pointer                                                    |
| FREQUENCY        | 0x508  |          | Frequency                                                         |
| TXPOWER          | 0x50C  |          | Output power                                                      |
| MODE             | 0x510  |          | Data rate and modulation                                          |
| PCNF0            | 0x514  |          | Packet configuration register 0                                   |
| PCNF1            | 0x518  |          | Packet configuration register 1                                   |
| BASE0            | 0x51C  |          | Base address 0                                                    |
| BASE1            | 0x520  |          | Base address 1                                                    |
| PREFIXO          | 0x524  |          | Prefixes bytes for logical addresses 0-3                          |
| PREFIX1          | 0x524  |          | Prefixes bytes for logical addresses 4-7                          |
| TXADDRESS        | 0x526  |          | Transmit address select                                           |
|                  |        |          |                                                                   |
| RXADDRESSES      | 0x530  |          | Receive address select                                            |
| CRCCNF           | 0x534  |          | CRC configuration                                                 |
| CRCPOLY          | 0x538  |          | CRC polynomial                                                    |
| CRCINIT          | 0x53C  |          | CRC initial value                                                 |
| TIFS             | 0x544  |          | Interframe spacing in μs                                          |
| RSSISAMPLE       | 0x548  |          | RSSI sample                                                       |
| STATE            | 0x550  |          | Current radio state                                               |
| DATAWHITEIV      | 0x554  |          | Data whitening initial value                                      |
| BCC              | 0x560  |          | Bit counter compare                                               |
| DAB[n]           | 0x600  |          | Device address base segment n                                     |
| DAP[n]           | 0x620  |          | Device address prefix n                                           |
| DACNF            | 0x640  |          | Device address match configuration                                |
| MHRMATCHCONF     | 0x644  |          | Search pattern configuration                                      |
| MHRMATCHMAS      | 0x648  |          | Pattern mask                                                      |
| MODECNF0         | 0x650  |          | Radio mode configuration register 0                               |
| SFD              | 0x660  |          | IEEE 802.15.4 start of frame delimiter                            |
| EDCNT            | 0x664  |          | IEEE 802.15.4 energy detect loop count                            |
| EDSAMPLE         | 0x668  |          | IEEE 802.15.4 energy detect level                                 |
| CCACTRL          | 0x66C  |          | IEEE 802.15.4 clear channel assessment control                    |
| DFEMODE          | 0x900  |          | Whether to use Angle-of-Arrival (AOA) or Angle-of-Departure (AOD) |
| CTEINLINECONF    | 0x904  |          | Configuration for CTE inline mode                                 |
| DFECTRL1         | 0x910  |          | Various configuration for Direction finding                       |
| DFECTRL2         | 0x914  |          | Start offset for Direction finding                                |
| SWITCHPATTERN    | 0x928  |          | GPIO patterns to be used for each antenna                         |
| CLEARPATTERN     | 0x92C  |          | Clear the GPIO pattern array for antenna control                  |
| PSEL.DFEGPIO[n]  | 0x930  |          | Pin select for DFE pin n                                          |
| DFEPACKET.PTR    | 0x950  |          | Data pointer                                                      |
| DFEPACKET.MAXCNT | 0x954  |          | Maximum number of buffer words to transfer                        |
| DFEPACKET.AMOUNT | 0x958  |          | Number of samples transferred in the last transaction             |
| POWER            | 0xFFC  |          | Peripheral power control                                          |

Table 131: Register overview

# 7.26.15.1 TASKS\_TXEN

Address offset: 0x000 Enable RADIO in TX mode





# 7.26.15.2 TASKS\_RXEN

Address offset: 0x004
Enable RADIO in RX mode



# 7.26.15.3 TASKS START

Address offset: 0x008

Start RADIO



### 7.26.15.4 TASKS STOP

Address offset: 0x00C

Stop RADIO



### 7.26.15.5 TASKS\_DISABLE

Address offset: 0x010

Disable RADIO





# 7.26.15.6 TASKS\_RSSISTART

Address offset: 0x014

Start the RSSI and take one single sample of the receive signal strength

| Bit n | umber   |                 |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                 |         |                         | A                                                               |
| Rese  | t 0x000 | 00000           |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                 |         |                         |                                                                 |
| Α     | W       | TASKS_RSSISTART |         |                         | Start the RSSI and take one single sample of the receive        |
|       |         |                 |         |                         | signal strength                                                 |
|       |         |                 | Trigger | 1                       | Trigger task                                                    |

# 7.26.15.7 TASKS\_RSSISTOP

Address offset: 0x018

Stop the RSSI measurement



## 7.26.15.8 TASKS\_BCSTART

Address offset: 0x01C Start the bit counter



### 7.26.15.9 TASKS BCSTOP

Address offset: 0x020 Stop the bit counter





# 7.26.15.10 TASKS\_EDSTART

Address offset: 0x024

Start the energy detect measurement used in IEEE 802.15.4 mode



## 7.26.15.11 TASKS EDSTOP

Address offset: 0x028

Stop the energy detect measurement



## 7.26.15.12 TASKS\_CCASTART

Address offset: 0x02C

Start the clear channel assessment used in IEEE 802.15.4 mode



## 7.26.15.13 TASKS CCASTOP

Address offset: 0x030

Stop the clear channel assessment





# 7.26.15.14 SUBSCRIBE\_TXEN

Address offset: 0x080

Subscribe configuration for task TXEN

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task TXEN will subscribe to                 |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable subscription                                          |
|       |         |       | Enabled  |                         | Enable subscription                                           |

# 7.26.15.15 SUBSCRIBE\_RXEN

Address offset: 0x084

Subscribe configuration for task RXEN

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|-----|
| ID    |          |       |          | В                       | A A A A A                                                   | АА  |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID    |          |       |          |                         |                                                             |     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task RXEN will subscribe to               |     |
|       |          |       |          |                         |                                                             |     |
| В     | RW       | EN    |          |                         |                                                             |     |
| В     | RW       | EN    | Disabled | 0                       | Disable subscription                                        |     |

# 7.26.15.16 SUBSCRIBE\_START

Address offset: 0x088

Subscribe configuration for task START

| Bit n | Bit number |       | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 3 | 1 0                                            |     |
|-------|------------|-------|-------------------------|-------------------------------------------------------------|------------------------------------------------|-----|
| ID    |            |       |                         | В                                                           | A A A A A A                                    | A A |
| Rese  | et 0x000   | 00000 |                         | 0 0 0 0 0 0 0 0                                             | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0        | 0 ( |
| ID    |            |       |                         |                                                             |                                                |     |
| Α     | RW         | CHIDX |                         | [2550]                                                      | DPPI channel that task START will subscribe to |     |
| В     | RW         | EN    |                         |                                                             |                                                |     |
|       |            |       | Disabled                | 0                                                           | Disable subscription                           |     |
|       |            |       | Enabled                 | 1                                                           | Enable subscription                            |     |

# 7.26.15.17 SUBSCRIBE\_STOP

Address offset: 0x08C





### Subscribe configuration for task STOP



# 7.26.15.18 SUBSCRIBE\_DISABLE

Address offset: 0x090

Subscribe configuration for task DISABLE



# 7.26.15.19 SUBSCRIBE\_RSSISTART

Address offset: 0x094

Subscribe configuration for task RSSISTART



# 7.26.15.20 SUBSCRIBE\_RSSISTOP

Address offset: 0x098

Subscribe configuration for task RSSISTOP





# 7.26.15.21 SUBSCRIBE BCSTART

Address offset: 0x09C

Subscribe configuration for task BCSTART



# 7.26.15.22 SUBSCRIBE\_BCSTOP

Address offset: 0x0A0

Subscribe configuration for task BCSTOP

| Bit n | umber            |       |                 | 31 30 29 28 27 26 25 24                 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|-------|-----------------|-----------------------------------------|---------------------------------------------------------------|
| ID    |                  |       |                 | В                                       | A A A A A A A                                                 |
| Rese  | Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                               |
| ID    |                  |       |                 |                                         |                                                               |
| Α     | RW               | CHIDX |                 | [2550]                                  | DPPI channel that task BCSTOP will subscribe to               |
| В     | RW               | EN    |                 |                                         |                                                               |
|       |                  |       | Disabled        | 0                                       | Disable subscription                                          |
|       |                  |       | Enabled         | 1                                       | Enable subscription                                           |

## 7.26.15.23 SUBSCRIBE\_EDSTART

Address offset: 0x0A4

Subscribe configuration for task EDSTART







## 7.26.15.24 SUBSCRIBE\_EDSTOP

Address offset: 0x0A8

Subscribe configuration for task EDSTOP



# 7.26.15.25 SUBSCRIBE\_CCASTART

Address offset: 0x0AC

Subscribe configuration for task CCASTART



### 7.26.15.26 SUBSCRIBE CCASTOP

Address offset: 0x0B0

Subscribe configuration for task CCASTOP



## 7.26.15.27 EVENTS\_READY

Address offset: 0x100

RADIO has ramped up and is ready to be started



| Bit n | umber            |              |              | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|--------------|--------------|----------------------|------------------------------------------------------------------|
| ID    |                  |              |              |                      | A                                                                |
| Rese  | Reset 0x00000000 |              |              | 0 0 0 0 0 0 0        | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                        |
| ID    |                  |              |              |                      |                                                                  |
| Α     | RW               | EVENTS_READY |              |                      | RADIO has ramped up and is ready to be started                   |
|       |                  |              | NotGenerated | 0                    | Event not generated                                              |
|       |                  |              | Generated    | 1                    | Event generated                                                  |

# 7.26.15.28 EVENTS\_ADDRESS

Address offset: 0x104 Address sent or received

| Bit n | umber   |                |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |              |                         | A                                                               |
| Rese  | t 0x000 | 00000          |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |              |                         |                                                                 |
| Α     | RW      | EVENTS_ADDRESS |              |                         | Address sent or received                                        |
|       |         |                | NotGenerated | 0                       | Event not generated                                             |
|       |         |                | Generated    | 1                       | Event generated                                                 |

# 7.26.15.29 EVENTS\_PAYLOAD

Address offset: 0x108

Packet payload sent or received

| Bit n | umber   |                |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |                |              |                        | A                                                               |
| Rese  | t 0x000 | 00000          |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |              |                        |                                                                 |
| Α     | RW      | EVENTS_PAYLOAD |              |                        | Packet payload sent or received                                 |
|       |         |                | NotGenerated | 0                      | Event not generated                                             |
|       |         |                | Generated    | 1                      | Event generated                                                 |

# 7.26.15.30 EVENTS\_END

Address offset: 0x10C

Packet sent or received

| Bit number  |            |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------|------------|--------------|------------------------|-----------------------------------------------------------------|
| ID          |            |              |                        | А                                                               |
| Reset 0x000 | 00000      |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W      |            |              |                        | Description                                                     |
| A RW        | EVENTS_END |              |                        | Packet sent or received                                         |
|             |            | NotGenerated | 0                      | Event not generated                                             |
|             |            | Generated    | 1                      | Event generated                                                 |

# 7.26.15.31 EVENTS\_DISABLED

Address offset: 0x110

RADIO has been disabled





## 7.26.15.32 EVENTS\_DEVMATCH

Address offset: 0x114

A device address match occurred on the last received packet



# 7.26.15.33 EVENTS\_DEVMISS

Address offset: 0x118

No device address match occurred on the last received packet



### 7.26.15.34 EVENTS RSSIEND

Address offset: 0x11C

Sampling of receive signal strength complete

A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register





### 7.26.15.35 EVENTS\_BCMATCH

Address offset: 0x128

Bit counter reached bit count value

Bit counter value is specified in the RADIO.BCC register



# 7.26.15.36 EVENTS\_CRCOK

Address offset: 0x130

Packet received with CRC ok



### 7.26.15.37 EVENTS CRCERROR

Address offset: 0x134

Packet received with CRC error



### 7.26.15.38 EVENTS FRAMESTART

Address offset: 0x138

IEEE 802.15.4 length field received





## 7.26.15.39 EVENTS\_EDEND

Address offset: 0x13C

Sampling of energy detection complete. A new ED sample is ready for readout from the RADIO.EDSAMPLE register.



# 7.26.15.40 EVENTS\_EDSTOPPED

Address offset: 0x140

The sampling of energy detection has stopped

| Bit n | umber    |                  |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                  |              |                         | A                                                               |
| Rese  | et 0x000 | 00000            |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                  |              |                         | Description                                                     |
| Α     | RW       | EVENTS_EDSTOPPED |              |                         | The sampling of energy detection has stopped                    |
|       |          |                  | NotGenerated | 0                       | Event not generated                                             |
|       |          |                  | Generated    | 1                       | Event generated                                                 |

## 7.26.15.41 EVENTS\_CCAIDLE

Address offset: 0x144

Wireless medium in idle - clear to send



# 7.26.15.42 EVENTS\_CCABUSY

Address offset: 0x148



#### Wireless medium busy - do not send



### 7.26.15.43 EVENTS CCASTOPPED

Address offset: 0x14C
The CCA has stopped



# 7.26.15.44 EVENTS\_RATEBOOST

Address offset: 0x150

Ble\_LR CI field received, receive mode is changed from Ble\_LR125Kbit to Ble\_LR500Kbit.



## 7.26.15.45 EVENTS TXREADY

Address offset: 0x154

RADIO has ramped up and is ready to be started TX path







### 7.26.15.46 EVENTS\_RXREADY

Address offset: 0x158

RADIO has ramped up and is ready to be started RX path



### 7.26.15.47 EVENTS MHRMATCH

Address offset: 0x15C

MAC header match found



# 7.26.15.48 EVENTS\_SYNC

Address offset: 0x168

Preamble indicator

A possible preamble has been received in Ble\_LR125Kbit, Ble\_LR500Kbit, or leee802154\_250Kbit modes during an RX transaction. False triggering of the event is possible.



### 7.26.15.49 EVENTS PHYEND

Address offset: 0x16C

Generated when last bit is sent on air, or received from air





# 7.26.15.50 EVENTS\_CTEPRESENT

Address offset: 0x170

CTE is present (early warning right after receiving CTEInfo byte)

| Bit n | umber   |                   |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0   |
|-------|---------|-------------------|--------------|-------------------------|-------------------------------------------------------------------|
| ID    |         |                   |              |                         | А                                                                 |
| Rese  | t 0x000 | 00000             |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                           |
| ID    |         |                   |              |                         | Description                                                       |
|       |         |                   |              |                         |                                                                   |
| Α     | RW      | EVENTS_CTEPRESENT |              |                         | CTE is present (early warning right after receiving CTEInfo       |
| Α     | RW      | EVENTS_CTEPRESENT |              |                         | CTE is present (early warning right after receiving CTEInfo byte) |
| Α     | RW      | EVENTS_CTEPRESENT | NotGenerated | 0                       |                                                                   |

# 7.26.15.51 PUBLISH\_READY

Address offset: 0x180

Publish configuration for event READY

| Bit n | umber            |       |                 | 31 30 29 28 27 26 25 24                 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 |
|-------|------------------|-------|-----------------|-----------------------------------------|---------------------------------------------------------|-------|
| ID    |                  |       |                 | В                                       | АААА                                                    | А А А |
| Rese  | Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0                                                   |       |
| ID    |                  |       |                 |                                         |                                                         |       |
| Α     | RW               | CHIDX |                 | [2550]                                  | DPPI channel that event READY will publish to.          |       |
| В     | RW               | EN    |                 |                                         |                                                         |       |
|       |                  |       | Disabled        | 0                                       | Disable publishing                                      |       |
|       |                  |       | Enabled         | 1                                       | Enable publishing                                       |       |

## 7.26.15.52 PUBLISH\_ADDRESS

Address offset: 0x184

Publish configuration for event ADDRESS





### 7.26.15.53 PUBLISH\_PAYLOAD

Address offset: 0x188

Publish configuration for event PAYLOAD



## 7.26.15.54 PUBLISH\_END

Address offset: 0x18C

Publish configuration for event END



### 7.26.15.55 PUBLISH DISABLED

Address offset: 0x190

Publish configuration for event DISABLED



## 7.26.15.56 PUBLISH\_DEVMATCH

Address offset: 0x194

Publish configuration for event DEVMATCH





## 7.26.15.57 PUBLISH DEVMISS

Address offset: 0x198

Publish configuration for event DEVMISS



## 7.26.15.58 PUBLISH\_RSSIEND

Address offset: 0x19C

Publish configuration for event RSSIEND

A new RSSI sample is ready for readout from the RADIO.RSSISAMPLE register



## 7.26.15.59 PUBLISH\_BCMATCH

Address offset: 0x1A8

Publish configuration for event BCMATCH

Bit counter value is specified in the RADIO.BCC register





# 7.26.15.60 PUBLISH\_CRCOK

Address offset: 0x1B0

Publish configuration for event CRCOK



# 7.26.15.61 PUBLISH\_CRCERROR

Address offset: 0x1B4

Publish configuration for event CRCERROR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event CRCERROR will publish to.             |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 1                       | Enable publishing                                             |

## 7.26.15.62 PUBLISH\_FRAMESTART

Address offset: 0x1B8

Publish configuration for event FRAMESTART







### 7.26.15.63 PUBLISH\_EDEND

Address offset: 0x1BC

Publish configuration for event EDEND



## 7.26.15.64 PUBLISH\_EDSTOPPED

Address offset: 0x1C0

Publish configuration for event EDSTOPPED



### 7.26.15.65 PUBLISH CCAIDLE

Address offset: 0x1C4

Publish configuration for event CCAIDLE



## 7.26.15.66 PUBLISH\_CCABUSY

Address offset: 0x1C8

Publish configuration for event CCABUSY





# 7.26.15.67 PUBLISH\_CCASTOPPED

Address offset: 0x1CC

Publish configuration for event CCASTOPPED



## 7.26.15.68 PUBLISH\_RATEBOOST

Address offset: 0x1D0

Publish configuration for event RATEBOOST

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event RATEBOOST will publish to.              |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

## 7.26.15.69 PUBLISH\_TXREADY

Address offset: 0x1D4

Publish configuration for event TXREADY







## 7.26.15.70 PUBLISH\_RXREADY

Address offset: 0x1D8

Publish configuration for event RXREADY



## 7.26.15.71 PUBLISH\_MHRMATCH

Address offset: 0x1DC

Publish configuration for event MHRMATCH



### 7.26.15.72 PUBLISH SYNC

Address offset: 0x1E8

Publish configuration for event SYNC

A possible preamble has been received in Ble\_LR125Kbit, Ble\_LR500Kbit, or leee802154\_250Kbit modes during an RX transaction. False triggering of the event is possible.

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event SYNC will publish to.                   |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

## 7.26.15.73 PUBLISH\_PHYEND

Address offset: 0x1EC

Publish configuration for event PHYEND





# 7.26.15.74 PUBLISH\_CTEPRESENT

Address offset: 0x1F0

Publish configuration for event CTEPRESENT

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event CTEPRESENT will publish to.             |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

### 7.26.15.75 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber   |                   |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                   |          |                         | UTSRQPONMLK H GFEDCBA                                           |
| Rese  | t 0x000 | 00000             |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                   |          |                         |                                                                 |
| Α     | RW      | READY_START       |          |                         | Shortcut between event READY and task START                     |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| В     | RW      | END_DISABLE       |          |                         | Shortcut between event END and task DISABLE                     |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| С     | RW      | DISABLED_TXEN     |          |                         | Shortcut between event DISABLED and task TXEN                   |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| D     | RW      | DISABLED_RXEN     |          |                         | Shortcut between event DISABLED and task RXEN                   |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| Е     | RW      | ADDRESS_RSSISTART |          |                         | Shortcut between event ADDRESS and task RSSISTART               |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| F     | RW      | END_START         |          |                         | Shortcut between event END and task START                       |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |
| G     | RW      | ADDRESS_BCSTART   |          |                         | Shortcut between event ADDRESS and task BCSTART                 |
|       |         |                   | Disabled | 0                       | Disable shortcut                                                |
|       |         |                   | Enabled  | 1                       | Enable shortcut                                                 |





| Bit n | umber    |                    |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------------|----------|----------------------|------------------------------------------------------------------|
| ID    |          |                    |          |                      | UTSRQPONMLK H GFEDCBA                                            |
| Rese  | et 0x000 | 00000              |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |          |                    |          |                      |                                                                  |
| н     | RW       | DISABLED_RSSISTOP  |          |                      | Shortcut between event DISABLED and task RSSISTOP                |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| K     | RW       | RXREADY_CCASTART   |          |                      | Shortcut between event RXREADY and task CCASTART                 |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| L     | RW       | CCAIDLE_TXEN       |          |                      | Shortcut between event CCAIDLE and task TXEN                     |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| М     | RW       | CCABUSY_DISABLE    |          |                      | Shortcut between event CCABUSY and task DISABLE                  |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| N     | RW       | FRAMESTART_BCSTART |          |                      | Shortcut between event FRAMESTART and task BCSTART               |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| О     | RW       | READY_EDSTART      |          |                      | Shortcut between event READY and task EDSTART                    |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| Р     | RW       | EDEND_DISABLE      |          |                      | Shortcut between event EDEND and task DISABLE                    |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| Q     | RW       | CCAIDLE_STOP       |          |                      | Shortcut between event CCAIDLE and task STOP                     |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| R     | RW       | TXREADY_START      |          |                      | Shortcut between event TXREADY and task START                    |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| S     | RW       | RXREADY_START      |          |                      | Shortcut between event RXREADY and task START                    |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| Т     | RW       | PHYEND_DISABLE     |          |                      | Shortcut between event PHYEND and task DISABLE                   |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |
| U     | RW       | PHYEND_START       |          |                      | Shortcut between event PHYEND and task START                     |
|       |          |                    | Disabled | 0                    | Disable shortcut                                                 |
|       |          |                    | Enabled  | 1                    | Enable shortcut                                                  |

# 7.26.15.76 INTENSET

Address offset: 0x304

Enable interrupt

| Bit numbe | er      |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------|---------|----------|-------------------|---------------------------------------------------------------------|
| ID        |         |          | b a Z             | W V U T S R Q P O N M L J H G F E D C B A                           |
| Reset 0x0 | 0000000 |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID R/V    |         |          |                   |                                                                     |
| A RW      | READY   |          |                   | Write '1' to enable interrupt for event READY                       |
|           |         | Set      | 1                 | Enable                                                              |
|           |         | Disabled | 0                 | Read: Disabled                                                      |



| Bit r | number   |            |                 | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------|-----------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |            |                 | b a Z                   | W V U T S R Q P O N M L J H G F E D C B A                       |
| Rese  | et 0x000 | 00000      |                 | 0 0 0 0 0 0 0 0         | 000000000000000000000000000000000000000                         |
|       |          |            |                 |                         |                                                                 |
|       | .,       |            | Enabled         | 1                       | Read: Enabled                                                   |
| В     | RW       | ADDRESS    |                 | _                       | Write '1' to enable interrupt for event ADDRESS                 |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| С     | RW       | PAYLOAD    | 21102100        | -                       | Write '1' to enable interrupt for event PAYLOAD                 |
| _     |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| D     | RW       | END        | Enabled         | -                       | Write '1' to enable interrupt for event END                     |
|       | 11.00    | LIND       | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| E     | RW       | DISABLED   | Lilabled        | 1                       | Write '1' to enable interrupt for event DISABLED                |
| _     | IV V V   | DISABLED   | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         |                         | Read: Enabled                                                   |
| F     | RW       | DEVMATCH   | Enabled         | 1                       |                                                                 |
| г     | IV V V   | DEVINIAICH | Cat             | 1                       | Write '1' to enable interrupt for event DEVMATCH  Enable        |
|       |          |            | Set             | 1                       |                                                                 |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
| _     | DVA      | DEVANCE    | Enabled         | 1                       | Read: Enabled                                                   |
| G     | RW       | DEVMISS    | C-+             | 4                       | Write '1' to enable interrupt for event DEVMISS                 |
|       |          |            | Set<br>Disabled | 0                       | Enable Read: Disabled                                           |
|       |          |            |                 |                         | Read: Enabled                                                   |
|       | DVA      | DECIEND    | Enabled         | 1                       | ······································                          |
| Н     | RW       | RSSIEND    |                 |                         | Write '1' to enable interrupt for event RSSIEND                 |
|       |          |            |                 |                         | A new RSSI sample is ready for readout from the                 |
|       |          |            |                 |                         | RADIO.RSSISAMPLE register                                       |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| J     | RW       | BCMATCH    |                 |                         | Write '1' to enable interrupt for event BCMATCH                 |
|       |          |            |                 |                         | Bit counter value is specified in the RADIO.BCC register        |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| L     | RW       | CRCOK      |                 |                         | Write '1' to enable interrupt for event CRCOK                   |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| М     | RW       | CRCERROR   |                 |                         | Write '1' to enable interrupt for event CRCERROR                |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| N     | RW       | FRAMESTART |                 | -                       | Write '1' to enable interrupt for event FRAMESTART              |
|       |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | Disabled        | 0                       | Read: Disabled                                                  |
|       |          |            | Enabled         | 1                       | Read: Enabled                                                   |
| 0     | RW       | EDEND      | Lindbled        | -                       | Write '1' to enable interrupt for event EDEND                   |
| _     |          |            | Set             | 1                       | Enable                                                          |
|       |          |            | JEL             | -                       | LITUDIC                                                         |

477



| Bit r | umber    |             |                 | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|----------|-------------|-----------------|------------------------|----------------------------------------------------------------|
| ID    |          |             |                 | b a Z                  | W V U T S R Q P O N M L J H G F E D C B A                      |
| Res   | et 0x000 | 00000       |                 | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                        |
|       |          |             |                 |                        |                                                                |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| Р     | RW       | EDSTOPPED   |                 |                        | Write '1' to enable interrupt for event EDSTOPPED              |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| Q     | RW       | CCAIDLE     |                 |                        | Write '1' to enable interrupt for event CCAIDLE                |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| R     | RW       | CCABUSY     |                 |                        | Write '1' to enable interrupt for event CCABUSY                |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| S     | RW       | CCASTOPPED  |                 |                        | Write '1' to enable interrupt for event CCASTOPPED             |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| Т     | RW       | RATEBOOST   |                 |                        | Write '1' to enable interrupt for event RATEBOOST              |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| U     | RW       | TXREADY     | 6.1             |                        | Write '1' to enable interrupt for event TXREADY                |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
| V     | RW       | RXREADY     | Enabled         | 1                      | Read: Enabled                                                  |
| V     | KVV      | KAREADI     | Set             | 1                      | Write '1' to enable interrupt for event RXREADY  Enable        |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| W     | RW       | MHRMATCH    | Lilabica        | •                      | Write '1' to enable interrupt for event MHRMATCH               |
| ••    |          | WITHWAY CIT | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
| Z     | RW       | SYNC        |                 |                        | Write '1' to enable interrupt for event SYNC                   |
|       |          |             |                 |                        |                                                                |
|       |          |             |                 |                        | A possible preamble has been received in Ble_LR125Kbit,        |
|       |          |             |                 |                        | Ble_LR500Kbit, or leee802154_250Kbit modes during an           |
|       |          |             | 6.1             | _                      | RX transaction. False triggering of the event is possible.     |
|       |          |             | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled  Read: Enabled                                  |
| 2     | RW       | PHYEND      | Enabled         | 1                      |                                                                |
| а     | 1/4/     | IIILINU     | Set             | 1                      | Write '1' to enable interrupt for event PHYEND  Enable         |
|       |          |             | Set<br>Disabled | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Disabled Read: Enabled                                   |
| b     | RW       | CTEPRESENT  | LIIUDICU        | <u>.</u>               | Write '1' to enable interrupt for event CTEPRESENT             |
| U     | IVVV     | CTETILIZENI | Set             | 1                      | Enable                                                         |
|       |          |             | Disabled        | 0                      | Read: Disabled                                                 |
|       |          |             | Enabled         | 1                      | Read: Enabled                                                  |
|       |          |             | LITUDICU        | -                      | nedd, Ellubica                                                 |



# 7.26.15.77 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |           |                   | 313    | 0 29 2 | 8 27 | 26 25 : | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|-------------------|--------|--------|------|---------|-----------------------------------------------------------------|
| ID    |          |           |                   |        | k      | o a  | Z       | W V U T S R Q P O N M L J H G F E D C B A                       |
| Rese  | et 0x000 | 00000     |                   | 0 0    | 0 0    | 0 0  | 0 0     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |                   |        |        |      |         | Description                                                     |
| Α     | RW       | READY     |                   |        |        |      |         | Write '1' to disable interrupt for event READY                  |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| В     | RW       | ADDRESS   |                   |        |        |      |         | Write '1' to disable interrupt for event ADDRESS                |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| С     | RW       | PAYLOAD   |                   |        |        |      |         | Write '1' to disable interrupt for event PAYLOAD                |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| D     | RW       | END       |                   |        |        |      |         | Write '1' to disable interrupt for event END                    |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| E     | RW       | DISABLED  |                   |        |        |      |         | Write '1' to disable interrupt for event DISABLED               |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
| -     | D) 47    | DELMAATCH | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| F     | RW       | DEVMATCH  | Class             | 1      |        |      |         | Write '1' to disable interrupt for event DEVMATCH               |
|       |          |           | Clear<br>Disabled | 1<br>0 |        |      |         | Disable  Read: Disabled                                         |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| G     | RW       | DEVMISS   | Ellableu          | 1      |        |      |         | Write '1' to disable interrupt for event DEVMISS                |
| U     | IVV      | DEVIVII33 | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| Н     | RW       | RSSIEND   | Enabled           | •      |        |      |         | Write '1' to disable interrupt for event RSSIEND                |
|       |          |           |                   |        |        |      |         |                                                                 |
|       |          |           |                   |        |        |      |         | A new RSSI sample is ready for readout from the                 |
|       |          |           | Class             | 1      |        |      |         | RADIO.RSSISAMPLE register                                       |
|       |          |           | Clear<br>Disabled | 1      |        |      |         | Disable  Read: Disabled                                         |
|       |          |           | Enabled           | 0      |        |      |         | Read: Enabled                                                   |
| J     | RW       | BCMATCH   | Ellableu          | 1      |        |      |         | Write '1' to disable interrupt for event BCMATCH                |
| J     | IVV      | BCWATCH   |                   |        |        |      |         | <i>,</i>                                                        |
|       |          |           |                   |        |        |      |         | Bit counter value is specified in the RADIO.BCC register        |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
|       |          |           | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| L     | RW       | CRCOK     | CI.               |        |        |      |         | Write '1' to disable interrupt for event CRCOK                  |
|       |          |           | Clear             | 1      |        |      |         | Disable                                                         |
|       |          |           | Disabled          | 0      |        |      |         | Read: Disabled                                                  |
| N.C   | D\A/     | CRCERROR  | Enabled           | 1      |        |      |         | Read: Enabled                                                   |
| М     | RW       | CRCERROR  |                   |        |        |      |         | Write '1' to disable interrupt for event CRCERROR               |



| BIT II | umber   |            |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|--------|---------|------------|----------|----------------------|----------------------------------------------------------------|
| ID     |         |            |          | b a Z                | W V U T S R Q P O N M L J H G F E D C B                        |
| Rese   | t 0x000 | 00000      |          | 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                        |
|        |         |            |          |                      |                                                                |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| N      | RW      | FRAMESTART |          |                      | Write '1' to disable interrupt for event FRAMESTART            |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| 0      | RW      | EDEND      |          |                      | Write '1' to disable interrupt for event EDEND                 |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| Р      | RW      | EDSTOPPED  |          |                      | Write '1' to disable interrupt for event EDSTOPPED             |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| Q      | RW      | CCAIDLE    |          |                      | Write '1' to disable interrupt for event CCAIDLE               |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| R      | RW      | CCABUSY    |          |                      | Write '1' to disable interrupt for event CCABUSY               |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| S      | RW      | CCASTOPPED |          |                      | Write '1' to disable interrupt for event CCASTOPPED            |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| Т      | RW      | RATEBOOST  |          |                      | Write '1' to disable interrupt for event RATEBOOST             |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| U      | RW      | TXREADY    |          |                      | Write '1' to disable interrupt for event TXREADY               |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| V      | RW      | RXREADY    |          |                      | Write '1' to disable interrupt for event RXREADY               |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| w      | RW      | MHRMATCH   |          |                      | Write '1' to disable interrupt for event MHRMATCH              |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |
| Z      | RW      | SYNC       |          |                      | Write '1' to disable interrupt for event SYNC                  |
|        |         |            |          |                      |                                                                |
|        |         |            |          |                      | A possible preamble has been received in Ble_LR125Kbit,        |
|        |         |            |          |                      | Ble_LR500Kbit, or leee802154_250Kbit modes during an           |
|        |         |            |          |                      | RX transaction. False triggering of the event is possible.     |
|        |         |            | Clear    | 1                    | Disable                                                        |
|        |         |            | Disabled | 0                    | Read: Disabled                                                 |
|        |         |            | Enabled  | 1                    | Read: Enabled                                                  |





| Bit r | number   |            |          | 31 | 30 | 29 2 | 8 27 | 26 | 25 2 | 42  | 3 2  | 2 21  | L 20 | 19  | 18 3 | 17 1 | 6 1  | 5 14 | 4 13 | 12  | 11   | 10  | 9 8  | 3 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
|-------|----------|------------|----------|----|----|------|------|----|------|-----|------|-------|------|-----|------|------|------|------|------|-----|------|-----|------|-----|---|---|---|---|---|-----|
| ID    |          |            |          |    |    | k    | о а  | Z  |      | ٧   | ۷١   | / U   | Т    | S   | R    | Q F  | , C  | N    | I M  | L   |      | J   |      | Н   | G | F | Ε | D | С | ВА  |
| Res   | et 0x000 | 00000      |          | 0  | 0  | 0 (  | 0    | 0  | 0 (  | ) ( | 0 (  | 0     | 0    | 0   | 0    | 0 (  | 0    | 0    | 0    | 0   | 0    | 0   | 0 (  | 0   | 0 | 0 | 0 | 0 | 0 | 0 0 |
| ID    |          |            |          |    |    |      |      |    |      |     |      |       |      |     |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
| а     | RW       | PHYEND     |          |    |    |      |      |    |      | ٧   | Vrit | e '1  | ' to | dis | able | int  | errı | ıpt  | for  | eve | nt F | РН  | /ENI | )   |   |   |   |   |   |     |
|       |          |            | Clear    | 1  |    |      |      |    |      | D   | isa  | ble   |      |     |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
|       |          |            | Disabled | 0  |    |      |      |    |      | R   | lead | d: D  | isab | led |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
|       |          |            | Enabled  | 1  |    |      |      |    |      | R   | lead | d: Eı | nabl | ed  |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
| b     | RW       | CTEPRESENT |          |    |    |      |      |    |      | ٧   | Vrit | e '1  | ' to | dis | able | int  | errı | upt  | for  | eve | nt ( | СТЕ | PRE  | SEN | Т |   |   |   |   |     |
|       |          |            | Clear    | 1  |    |      |      |    |      | D   | isa  | ble   |      |     |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
|       |          |            | Disabled | 0  |    |      |      |    |      | R   | lead | d: D  | isab | led |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
|       |          |            | Enabled  | 1  |    |      |      |    |      | R   | lead | d: Eı | nabl | ed  |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |
|       |          |            |          |    |    |      |      |    |      |     |      |       |      |     |      |      |      |      |      |     |      |     |      |     |   |   |   |   |   |     |

## 7.26.15.78 CRCSTATUS

Address offset: 0x400

CRC status

| Bit n | umber   |           |          | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|----------|----------------|------------------------------------------------------------------------|
| ID    |         |           |          |                | A                                                                      |
| Rese  | t 0x000 | 00000     |          | 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |           |          |                |                                                                        |
| Α     | R       | CRCSTATUS |          |                | CRC status of packet received                                          |
|       |         |           | CRCError | 0              | Packet received with CRC error                                         |
|       |         |           | CRCOk    | 1              | Packet received with CRC ok                                            |

# 7.26.15.79 RXMATCH

Address offset: 0x408

Received address

| ^     | D        | RXMATCH |                | Received address                                                       |
|-------|----------|---------|----------------|------------------------------------------------------------------------|
| ID    |          |         |                |                                                                        |
| Rese  | et 0x000 | 00000   | 0 0 0 0 0      | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                              |
| ID    |          |         |                | A A A                                                                  |
| Bit n | umber    |         | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

Logical address of which previous packet was received

## 7.26.15.80 RXCRC

Address offset: 0x40C

CRC field of previously received packet

| ^     | D        | RXCRC |                  |         | CRC 1 | Fiold | of r | rovi  | ious | ly ro | coiv | od n | ack  | ot    |   |   |   |     |            |   |   |     |
|-------|----------|-------|------------------|---------|-------|-------|------|-------|------|-------|------|------|------|-------|---|---|---|-----|------------|---|---|-----|
| ID    |          |       |                  |         | Desc  |       |      |       |      |       |      |      |      |       |   |   |   |     |            |   |   |     |
| Rese  | et 0x000 | 00000 | 0 0 0 0 0 0      | 0 0     | 0 0   | 0     | 0    | 0 0   | 0    | 0 (   | 0    | 0    | 0    | 0 0   | 0 | 0 | 0 | 0 ( | 0          | 0 | 0 | 0 0 |
| ID    |          |       |                  |         | АА    | Α     | A    | А А   | Α    | A     | A A  | Α    | A    | А А   | Α | Α | Α | Α / | <b>А</b> А | Α | Α | А А |
| Bit n | number   |       | 31 30 29 28 27 2 | 6 25 24 | 23 22 | 21    | 20 1 | .9 18 | 3 17 | 16 1  | 5 14 | 13   | 12 1 | 11 10 | 9 | 8 | 7 | 6 ! | 5 4        | 3 | 2 | 1 0 |

CRC field of previously received packet





#### 7.26.15.81 DAI

Address offset: 0x410

Device address match index



#### 7.26.15.82 PDUSTAT

Address offset: 0x414

Payload status



#### 7.26.15.83 CTESTATUS

Address offset: 0x44C

CTEInfo parsed from received packet

| Bit n | umber   |         | 31 30 29 28 27 26 25 | $24\ 23\ 22\ 21\ 20\ 19\ 18\ 17\ 16\ 15\ 14\ 13\ 12\ 11\ 10\ 9\ 8\ 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0$ |
|-------|---------|---------|----------------------|--------------------------------------------------------------------------------------------|
| ID    |         |         |                      | ССВАААА                                                                                    |
| Rese  | t 0x000 | 00000   | 0 0 0 0 0 0 0        | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                                                  |
| ID    |         |         |                      | Description                                                                                |
| Α     | R       | CTETIME |                      | CTETime parsed from packet                                                                 |
| В     | R       | RFU     |                      | RFU parsed from packet                                                                     |
| С     | R       | CTETYPE |                      | CTEType parsed from packet                                                                 |

#### 7.26.15.84 DFESTATUS

Address offset: 0x458

DFE status information





| Bit n | umber   |                |           | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|-----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |           |                         | B AAA                                                           |
| Rese  | t 0x000 | 00000          |           | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |           |                         |                                                                 |
| Α     | R       | SWITCHINGSTATE |           |                         | Internal state of switching state machine                       |
|       |         |                | Idle      | 0                       | Switching state Idle                                            |
|       |         |                | Offset    | 1                       | Switching state Offset                                          |
|       |         |                | Guard     | 2                       | Switching state Guard                                           |
|       |         |                | Ref       | 3                       | Switching state Ref                                             |
|       |         |                | Switching | 4                       | Switching state Switching                                       |
|       |         |                | Ending    | 5                       | Switching state Ending                                          |
| В     | R       | SAMPLINGSTATE  |           |                         | Internal state of sampling state machine                        |
|       |         |                | Idle      | 0                       | Sampling state Idle                                             |
|       |         |                | Sampling  | 1                       | Sampling state Sampling                                         |

# 7.26.15.85 PACKETPTR

Address offset: 0x504

Packet pointer

| Bit n | umber    |           | 31 | 30 2 | 29 2 | 8 2 | 7 26 | 25 | 24 | 23 | 3 22 | 2 21  | 1 20 | 19  | 18   | 3 17  | 7 10 | 5 1! | 5 1  | 4 1   | 3 1  | 2 1: | 10   | 9    | 8    | 7    | 6   | 5    | 4 | 3 | 2 | 1 | 0 |
|-------|----------|-----------|----|------|------|-----|------|----|----|----|------|-------|------|-----|------|-------|------|------|------|-------|------|------|------|------|------|------|-----|------|---|---|---|---|---|
| ID    |          |           | Α  | Α    | A A  | 4 Α | A    | Α  | Α  | Α  | . A  | A     | . A  | Α   | Α    | Α     | Δ    | . Δ  |      | A /   | ۱ ۸  | A A  | Α    | Α    | Α    | Α    | Α   | Α    | Α | Α | Α | Α | Α |
| Rese  | et 0x010 | 00000     | 0  | 0    | 0 (  | 0 0 | 0    | 0  | 1  | 0  | 0    | 0     | 0    | 0   | 0    | 0     | 0    | 0    | (    | 0     | ) (  | 0    | 0    | 0    | 0    | 0    | 0   | 0    | 0 | 0 | 0 | 0 | 0 |
| ID    |          |           |    |      |      |     |      |    |    |    |      |       |      |     |      |       |      |      |      |       |      |      |      |      |      |      |     |      |   |   |   |   |   |
| Α     | RW       | PACKETPTR |    |      |      |     |      |    |    | Pa | ack  | et p  | ooir | nte | r    |       |      |      |      |       |      |      |      |      |      |      |     |      |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | Pa | ack  | et a  | add  | res | s to | b be  | e u  | sec  | l fo | r tl  | ne i | next | tra  | nsn  | nis  | sio  | n o | r    |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | re | ce   | ptic  | n. ۱ | Wŀ  | ien  | tra   | ns   | mit  | tin  | ıg, 1 | the  | pac  | ket  | ро   | inte | ed 1 | to  |      |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | by | / th | nis a | add  | res | s w  | ill l | be   | tra  | nsr  | mit   | ted  | and  | w b  | her  | re   | cei  | vin | g,   |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | th | ie r | ece   | eive | d p | ac   | ket   | wi   | ll b | e v  | vrit  | ter  | to   | this | ad   | dre  | SS.  | Th  | is   |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | ad | ddr  | ess   | is a | a b | yte  | ali   | gne  | ed F | RAI  | M a   | dd   | ress | . Se | ee t | he   | me   | mo  | ry   |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | ch | nap  | ter   | for  | de  | tai  | ls a  | bo   | ut   | wh   | ich   | me   | emo  | rie  | s ar | e a  | vila | ble | e fo | r |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | Ea | syl  | DM    | IA.  |     |      |       |      |      |      |       |      |      |      |      |      |      |     |      |   |   |   |   |   |
|       |          |           |    |      |      |     |      |    |    | ch | nap  | ter   | for  |     |      |       |      |      |      |       |      |      |      |      |      |      |     |      |   |   |   |   |   |

# 7.26.15.86 FREQUENCY

Address offset: 0x508

Frequency

| Bit n | umber    |           |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|---------|------------------------|-----------------------------------------------------------------|
| ID    |          |           |         |                        | B A A A A A A                                                   |
| Rese  | et 0x000 | 000002    |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |         |                        |                                                                 |
| Α     | RW       | FREQUENCY |         | [0100]                 | Radio channel frequency                                         |
|       |          |           |         |                        | Frequency = 2400 + FREQUENCY (MHz)                              |
| В     | RW       | MAP       |         |                        | Channel map selection                                           |
|       |          |           | Default | 0                      | Channel map between 2400 MHz and 2500 MHz                       |
|       |          |           |         |                        | Frequency = 2400 + FREQUENCY (MHz)                              |
|       |          |           | Low     | 1                      | Channel map between 2360 MHz and 2460 MHz                       |
|       |          |           |         |                        | Frequency = 2360 + FREQUENCY (MHz)                              |





# 7.26.15.87 TXPOWER

Address offset: 0x50C

Output power

| Bit n | umber   |         |          | 31 30 29 28 27 26 25 24 | <sup>1</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0    |
|-------|---------|---------|----------|-------------------------|--------------------------------------------------------------------|------------|
| ID    |         |         |          |                         | A A A                                                              | A A A A    |
| Rese  | t 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            | 0 0 0 0    |
| ID    |         |         |          |                         |                                                                    |            |
| Α     | RW      | TXPOWER |          |                         | RADIO output power                                                 |            |
|       |         |         |          |                         | Output power in number of dBm, i.e. if the value -20 is            |            |
|       |         |         |          |                         | specified the output power will be set to -20 dBm.                 |            |
|       |         |         |          |                         |                                                                    |            |
|       |         |         |          |                         | When the radio is operated on high voltage (see VREQCTRI           |            |
|       |         |         |          |                         | Voltage request control on page 63 for how to control              |            |
|       |         |         |          |                         | voltage), the output power is increased by 3 dB. I.e. if           |            |
|       |         |         |          |                         | the TXPOWER value is set to 0 dBm and high voltage is              |            |
|       |         |         |          |                         | requested using VREQCTRL, the output power will be +3              |            |
|       |         |         |          |                         | dBm.                                                               |            |
|       |         |         | 0dBm     | 0x0                     | 0 dBm                                                              |            |
|       |         |         | Neg1dBm  | 0xFF                    | -1 dBm                                                             |            |
|       |         |         | Neg2dBm  | 0xFE                    | -2 dBm                                                             |            |
|       |         |         | Neg3dBm  | 0xFD                    | -3 dBm                                                             |            |
|       |         |         | Neg4dBm  | 0xFC                    | -4 dBm                                                             |            |
|       |         |         | Neg5dBm  | 0xFB                    | -5 dBm                                                             |            |
|       |         |         | Neg6dBm  | 0xFA                    | -6 dBm                                                             |            |
|       |         |         | Neg7dBm  | 0xF9                    | -7 dBm                                                             |            |
|       |         |         | Neg8dBm  | 0xF8                    | -8 dBm                                                             |            |
|       |         |         | Neg12dBm | 0xF4                    | -12 dBm                                                            |            |
|       |         |         | Neg16dBm | 0xF0                    | -16 dBm                                                            |            |
|       |         |         | Neg20dBm | 0xEC                    | -20 dBm                                                            |            |
|       |         |         | Neg30dBm | 0xE2                    | -40 dBm                                                            | Deprecated |
|       |         |         | Neg40dBm | 0xD8                    | -40 dBm                                                            |            |

## 7.26.15.88 MODE

Address offset: 0x510

Data rate and modulation

| Bit n | umber   |       |                    | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|--------------------|------------------------|------------------------------------------------------------------|
| ID    |         |       |                    |                        | ААА                                                              |
| Rese  | t 0x000 | 00000 |                    | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |         |       |                    |                        | Description                                                      |
| Α     | RW      | MODE  |                    |                        | Radio data rate and modulation setting. The radio supports       |
|       |         |       |                    |                        | frequency-shift keying (FSK) modulation.                         |
|       |         |       | Nrf_1Mbit          | 0                      | 1 Mbps Nordic proprietary radio mode                             |
|       |         |       | Nrf_2Mbit          | 1                      | 2 Mbps Nordic proprietary radio mode                             |
|       |         |       | Ble_1Mbit          | 3                      | 1 Mbps BLE                                                       |
|       |         |       | Ble_2Mbit          | 4                      | 2 Mbps BLE                                                       |
|       |         |       | Ble_LR125Kbit      | 5                      | Long Range 125 kbps TX, 125 kbps and 500 kbps RX                 |
|       |         |       | Ble_LR500Kbit      | 6                      | Long Range 500 kbps TX, 125 kbps and 500 kbps RX                 |
|       |         |       | leee802154_250Kbit | 15                     | IEEE 802.15.4-2006 250 kbps                                      |



# 7.26.15.89 PCNF0

Address offset: 0x514

Packet configuration register 0

| Bit n | umber   |         |           | 31 | 30 2 | 29 2 | 8 27 | 7 26 | 25 | 24 | 23  | 22 2  | 21 2 | 20 1  | 9 18  | 8 17  | 16    | 15     | 14   | 13 1 | .2 1 | .1 10 | 9    | 8    | 7   | 6 5 | 5 4 | 3 | 2 | 1 | 0 |
|-------|---------|---------|-----------|----|------|------|------|------|----|----|-----|-------|------|-------|-------|-------|-------|--------|------|------|------|-------|------|------|-----|-----|-----|---|---|---|---|
| ID    |         |         |           |    | J    | J    |      | -1   | Н  | Н  | G   | G     |      | F E   | E     | Е     | Ε     |        |      |      |      |       |      | С    |     |     |     | Α | Α | Α | Α |
| Rese  | t 0x000 | 00000   |           | 0  | 0    | 0 (  | 0 0  | 0    | 0  | 0  | 0   | 0     | 0 (  | 0 (   | 0     | 0     | 0     | 0      | 0    | 0 (  | 0    | 0 0   | 0    | 0    | 0   | 0 ( | 0   | 0 | 0 | 0 | 0 |
| ID    |         |         |           |    |      |      |      |      |    |    |     |       |      |       |       |       |       |        |      |      |      |       |      |      |     |     |     |   |   |   | ı |
| Α     | RW      | LFLEN   |           |    |      |      |      |      |    |    | Ler | ngth  | on   | air   | of    | LEN   | GTI   | I fie  | ld   | n n  | um   | ber   | of b | its  |     |     |     |   |   |   | _ |
| С     | RW      | SOLEN   |           |    |      |      |      |      |    |    | Ler | ngth  | on   | air   | of :  | SO f  | ield  | in r   | nun  | nbe  | r of | f byt | es   |      |     |     |     |   |   |   |   |
| E     | RW      | S1LEN   |           |    |      |      |      |      |    |    | Ler | ngth  | on   | air   | of :  | S1 f  | ield  | in r   | nun  | nbe  | r of | bits  | 5    |      |     |     |     |   |   |   |   |
| F     | RW      | S1INCL  |           |    |      |      |      |      |    |    | Inc | lude  | e or | ex    | cluc  | le S  | 1 fie | eld i  | n R  | AM   |      |       |      |      |     |     |     |   |   |   |   |
|       |         |         | Automatic | 0  |      |      |      |      |    |    | Inc | lude  | e S1 | L fie | ld i  | n R   | AΜ    | only   | / if | S1L  | ΕN   | > 0   |      |      |     |     |     |   |   |   |   |
|       |         |         | Include   | 1  |      |      |      |      |    |    | Alv | vays  | ind  | cluc  | le S  | 1 fie | eld i | n R    | ΑM   | ind  | lep  | end   | ent  | of S | 1LE | N   |     |   |   |   |   |
| G     | RW      | CILEN   |           |    |      |      |      |      |    |    | Ler | ngth  | of   | coc   | le ir | ndic  | ato   | r - L  | on   | g Ra | nge  | е     |      |      |     |     |     |   |   |   |   |
| Н     | RW      | PLEN    |           |    |      |      |      |      |    |    | Ler | ngth  | of   | pre   | am    | ble   | on a  | air. I | Dec  | isio | n p  | oint  | : TA | SKS  | _Sī | ART | -   |   |   |   |   |
|       |         |         |           |    |      |      |      |      |    |    | tas | k     |      |       |       |       |       |        |      |      |      |       |      |      |     |     |     |   |   |   |   |
|       |         |         | 8bit      | 0  |      |      |      |      |    |    | 8-b | it p  | rea  | mb    | le    |       |       |        |      |      |      |       |      |      |     |     |     |   |   |   |   |
|       |         |         | 16bit     | 1  |      |      |      |      |    |    | 16- | bit   | pre  | am    | ble   |       |       |        |      |      |      |       |      |      |     |     |     |   |   |   |   |
|       |         |         | 32bitZero | 2  |      |      |      |      |    |    | 32- | bit   | zer  | o pi  | ear   | nble  | e - u | ised   | l fo | r IE | EE 8 | 302.  | 15.4 | 1    |     |     |     |   |   |   |   |
|       |         |         | LongRange | 3  |      |      |      |      |    |    | Pre | am    | ble  | - us  | sed   | for   | Blu   | eto    | oth  | LE I | Lon  | ıg Ra | nge  | 9    |     |     |     |   |   |   |   |
| 1     | RW      | CRCINC  |           |    |      |      |      |      |    |    | Ind | licat | es i | if LE | NG    | TH    | field | d co   | nta  | ins  | CR   | C or  | not  |      |     |     |     |   |   |   |   |
|       |         |         | Exclude   | 0  |      |      |      |      |    |    | LEN | NGT   | H d  | loes  | no    | t co  | nta   | in C   | RC   |      |      |       |      |      |     |     |     |   |   |   |   |
|       |         |         | Include   | 1  |      |      |      |      |    |    | LEN | NGT   | H ir | nclu  | ides  | CR    | С     |        |      |      |      |       |      |      |     |     |     |   |   |   |   |
| J     | RW      | TERMLEN |           |    |      |      |      |      |    |    | Ler | ngth  | of   | TEF   | RM    | field | d in  | Lon    | g R  | ang  | ge c | pera  | atio | n    |     |     |     |   |   |   |   |
|       |         |         |           |    |      |      |      |      |    |    |     |       |      |       |       |       |       |        |      |      |      |       |      |      |     |     |     |   |   |   |   |

# 7.26.15.90 PCNF1

Address offset: 0x518

Packet configuration register 1

| ID E D C C C B B B B B B B A A A A                                         | AAAA    |
|----------------------------------------------------------------------------|---------|
| Reset 0x000000000 0 0 0 0 0 0 0 0 0 0 0 0 0                                | 0 0 0 0 |
| ID R/W Field Value ID Value Description                                    |         |
| A RW MAXLEN [0255] Maximum length of packet payload. If the packet payload |         |
| is larger than MAXLEN, the radio will truncate the payload                 |         |
| to MAXLEN.                                                                 |         |
| B RW STATLEN [0255] Static length in number of bytes                       |         |
| The static length parameter is added to the total length                   |         |
| of the payload when sending and receiving packets, e.g. if                 |         |
| the static length is set to N the radio will receive or send N             |         |
| bytes more than what is defined in the LENGTH field of the                 |         |
| packet.                                                                    |         |
| C RW BALEN [24] Base address length in number of bytes                     |         |
| The address field is composed of the base address and the                  |         |
| one byte long address prefix, e.g. set BALEN=2 to get a                    |         |
| total address of 3 bytes.                                                  |         |
| D RW ENDIAN On-air endianness of packet, this applies to the SO,           |         |
| LENGTH, S1, and the PAYLOAD fields.                                        |         |
| Little 0 Least significant bit on air first                                |         |





#### 7.26.15.91 BASEO

Address offset: 0x51C

Base address 0



#### 7.26.15.92 BASE1

Address offset: 0x520

Base address 1

| A RW BASE1            | Base address 1                                                                        |
|-----------------------|---------------------------------------------------------------------------------------|
| ID R/W Field Value ID | Value Description                                                                     |
| Reset 0x00000000      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |
| ID                    | A A A A A A A A A A A A A A A A A A A                                                 |
| Bit number            | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 7.26.15.93 PREFIXO

Address offset: 0x524

Prefixes bytes for logical addresses 0-3

| A-D RW     | AP[i] (i=03) |     |        |        |       |      | Add  | lres | s pre | efix i |                   |      |      |       |    |       |   |   |   |     |   |   |   |     |
|------------|--------------|-----|--------|--------|-------|------|------|------|-------|--------|-------------------|------|------|-------|----|-------|---|---|---|-----|---|---|---|-----|
| ID R/W     |              |     |        |        |       |      |      |      |       |        |                   |      |      |       |    |       |   |   |   |     |   |   |   |     |
| Reset 0x00 | 000000       | 0 0 | 0 (    | 0 0    | 0 0   | 0    | 0    | 0 0  | 0     | 0      | 0 0               | 0    | 0    | 0 0   | 0  | 0 0   | 0 | 0 | 0 | 0 0 | 0 | 0 | 0 | 0 0 |
| ID         |              | D C | ) D [  | D D    | D D   | D    | С    | C C  | С     | С      | c c               | С    | В    | ВВ    | В  | ВВ    | В | В | Α | A A | A | Α | Α | А А |
| Bit number |              | 313 | 0 29 2 | 8 27 : | 26 25 | 5 24 | 23 2 | 22 2 | 1 20  | 19     | 18 1 <sup>-</sup> | 7 16 | 15 1 | .4 13 | 12 | 11 10 | 9 | 8 | 7 | 6 5 | 4 | 3 | 2 | 1 0 |

#### 7.26.15.94 PREFIX1

Address offset: 0x528

Prefixes bytes for logical addresses 4-7





#### 7.26.15.95 TXADDRESS

Address offset: 0x52C
Transmit address select



Logical address to be used when transmitting a packet

#### 7.26.15.96 RXADDRESSES

Address offset: 0x530 Receive address select



#### 7.26.15.97 CRCCNF

Address offset: 0x534

**CRC** configuration



| Bit n | umber    |          |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|------------|------------------------|-----------------------------------------------------------------|
| ID    |          |          |            |                        | вв АА                                                           |
| Rese  | et 0x000 | 00000    |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |          |            |                        | Description                                                     |
| Α     | RW       | LEN      |            | [13]                   | CRC length in number of bytes                                   |
|       |          |          |            |                        | For MODE Ble_LR125Kbit and Ble_LR500Kbit, only LEN set          |
|       |          |          |            |                        | to 3 is supported                                               |
|       |          |          | Disabled   | 0                      | CRC length is zero and CRC calculation is disabled              |
|       |          |          | One        | 1                      | CRC length is one byte and CRC calculation is enabled           |
|       |          |          | Two        | 2                      | CRC length is two bytes and CRC calculation is enabled          |
|       |          |          | Three      | 3                      | CRC length is three bytes and CRC calculation is enabled        |
| В     | RW       | SKIPADDR |            |                        | Include or exclude packet address field out of CRC              |
|       |          |          |            |                        | calculation.                                                    |
|       |          |          | Include    | 0                      | CRC calculation includes address field                          |
|       |          |          | Skip       | 1                      | CRC calculation does not include address field. The CRC         |
|       |          |          |            |                        | calculation will start at the first byte after the address.     |
|       |          |          | leee802154 | 2                      | CRC calculation as per 802.15.4 standard. Starting at first     |
|       |          |          |            |                        | byte after length field.                                        |

# 7.26.15.98 CRCPOLY

Address offset: 0x538

CRC polynomial

| Bit n | umber   |         | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|------------------------|------------------------------------------------------------------|
| ID    |         |         |                        | A A A A A A A A A A A A A A A A A A A                            |
| Rese  | t 0x000 | 00000   | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |         |         |                        |                                                                  |
| Α     | RW      | CRCPOLY |                        | CRC polynomial                                                   |
|       |         |         |                        | Each term in the CRC polynomial is mapped to a bit in this       |
|       |         |         |                        | register which index corresponds to the term's exponent.         |
|       |         |         |                        | The least significant term/bit is hardwired internally to        |
|       |         |         |                        | 1, and bit number 0 of the register content is ignored by        |
|       |         |         |                        | the hardware. The following example is for an 8 bit CRC          |
|       |         |         |                        |                                                                  |

## 7.26.15.99 CRCINIT

Address offset: 0x53C

CRC initial value

| ID R/W     |        |                         |                                                                 |
|------------|--------|-------------------------|-----------------------------------------------------------------|
|            |        |                         | Description                                                     |
| Reset 0x00 | 000000 | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID         |        |                         | A A A A A A A A A A A A A A A A A A A                           |
| Bit number |        | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

Initial value for CRC calculation

## 7.26.15.100 TIFS

Address offset: 0x544 Interframe spacing in  $\mu s$ 







### 7.26.15.101 RSSISAMPLE

Address offset: 0x548

RSSI sample

| Bit r | umber    |            | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|------------|-------------------|---------------------------------------------------------------------|
| ID    |          |            |                   | A A A A A A                                                         |
| Rese  | et 0x000 | 00000      | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |          |            |                   | Description                                                         |
| Α     | R        | RSSISAMPLE | [0127]            | RSSI sample.                                                        |
|       |          |            |                   | RSSI sample result. The value of this register is read as a         |
|       |          |            |                   | positive value while the actual received signal strength is a       |
|       |          |            |                   | negative value. Actual received signal strength is therefore        |
|       |          |            |                   | as follows: received signal strength = -A dBm.                      |

### 7.26.15.102 STATE

Address offset: 0x550 Current radio state

| D.11   | 1     |       |           | 24 20 20 20 27 26 25 2  | A 22 22 24 20 40 40 47 46 4F 44 42 42 44 40 0 0 0 7 6 F A 22 2 4 0 |
|--------|-------|-------|-----------|-------------------------|--------------------------------------------------------------------|
| Bit nu | ımber |       |           | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0    |
| ID     |       |       |           |                         | ААА                                                                |
| Reset  | 0x000 | 00000 |           | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID     |       |       |           |                         | Description                                                        |
| Α      | R     | STATE |           |                         | Current radio state                                                |
|        |       |       | Disabled  | 0                       | RADIO is in the Disabled state                                     |
|        |       |       | RxRu      | 1                       | RADIO is in the RXRU state                                         |
|        |       |       | RxIdle    | 2                       | RADIO is in the RXIDLE state                                       |
|        |       |       | Rx        | 3                       | RADIO is in the RX state                                           |
|        |       |       | RxDisable | 4                       | RADIO is in the RXDISABLED state                                   |
|        |       |       | TxRu      | 9                       | RADIO is in the TXRU state                                         |
|        |       |       | TxIdle    | 10                      | RADIO is in the TXIDLE state                                       |
|        |       |       | Tx        | 11                      | RADIO is in the TX state                                           |
|        |       |       | TxDisable | 12                      | RADIO is in the TXDISABLED state                                   |

### 7.26.15.103 DATAWHITEIV

Address offset: 0x554

Data whitening initial value





#### 7.26.15.104 BCC

Address offset: 0x560 Bit counter compare

| A RV     | N BO   | CC  |     |      |     |      |    |    |    | Bit  | cou  | nte  | r co | mp   | are |      |      |      |    |    |      |     |   |   |   |     |     |     |   |
|----------|--------|-----|-----|------|-----|------|----|----|----|------|------|------|------|------|-----|------|------|------|----|----|------|-----|---|---|---|-----|-----|-----|---|
| ID R/    |        |     |     |      |     |      |    |    |    | Des  |      |      |      |      |     |      |      |      |    |    |      |     |   |   |   |     |     |     |   |
| Reset 0x | 000000 | 000 | 0   | 0 (  | 0 0 | 0    | 0  | 0  | 0  | 0    | 0    | 0 0  | 0    | 0    | 0   | 0    | 0 (  | 0    | 0  | 0  | 0 (  | 0 0 | 0 | 0 | 0 | 0 ( | 0   | ) 0 | 0 |
| ID       |        |     | Α   | A A  | Δ Α | A    | Α  | Α  | Α  | Α    | Α.   | A A  | A    | A    | Α   | Α.   | A A  | A A  | Α  | Α  | A A  | 4 Δ | Α | Α | Α | A A | A A | A A | Α |
| Bit numb | ber    |     | 313 | 30 2 | 9 2 | 8 27 | 26 | 25 | 24 | 23 2 | 22 2 | 21 2 | 0 19 | 9 18 | 17  | 16 1 | 15 1 | 4 13 | 12 | 11 | 10 9 | 9 8 | 7 | 6 | 5 | 4 3 | 3 2 | 2 1 | 0 |

Bit counter compare register

## 7.26.15.105 DAB[n] (n=0..7)

Address offset:  $0x600 + (n \times 0x4)$ Device address base segment n



## 7.26.15.106 DAP[n] (n=0..7)

Address offset:  $0x620 + (n \times 0x4)$ 

Device address prefix n



#### 7.26.15.107 DACNF

Address offset: 0x640

Device address match configuration



| Dit nu | umber   |               |                     | 21 20 20 20 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------|---------|---------------|---------------------|------------------------|-----------------------------------------------------------------|
|        | ullibei |               |                     |                        |                                                                 |
| ID     |         |               |                     |                        | PONMLKJIHGFEDCBA                                                |
| Rese   | t 0x000 | 00000         |                     | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID     |         |               |                     |                        |                                                                 |
| А-Н    | RW      | ENA[i] (i=07) |                     |                        | Enable or disable device address matching using device          |
|        |         |               |                     |                        | address i                                                       |
|        |         |               |                     |                        |                                                                 |
|        |         |               | Disabled            | 0                      | Disabled                                                        |
|        |         |               | Disabled<br>Enabled | 0                      | Disabled Enabled                                                |

### 7.26.15.108 MHRMATCHCONF

Address offset: 0x644

Search pattern configuration



#### 7.26.15.109 MHRMATCHMAS

Address offset: 0x648

Pattern mask



#### 7.26.15.110 MODECNF0

Address offset: 0x650

Radio mode configuration register 0

| Bit r | umber    |       |         | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|---------|------------------|------------------------------------------------------------------------|
| ID    |          |       |         |                  | C C A                                                                  |
| Rese  | et 0x000 | 00200 |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |          |       |         |                  |                                                                        |
| Α     | RW       | RU    |         |                  | Radio ramp-up time                                                     |
|       |          |       | Default | 0                | Default ramp-up time (tRXEN and tTXEN), compatible with                |
|       |          |       |         |                  | firmware written for nRF51                                             |
|       |          |       | Fast    | 1                | Fast ramp-up (tRXEN,FAST and tTXEN,FAST), see electrical               |
|       |          |       |         |                  | specifications for more information                                    |
|       |          |       |         |                  | When enabled, TIFS is not enforced by hardware and                     |
|       |          |       |         |                  | software needs to control when to turn on the Radio                    |





#### 7.26.15.111 SFD

Address offset: 0x660

IEEE 802.15.4 start of frame delimiter



#### 7.26.15.112 EDCNT

Address offset: 0x664

IEEE 802.15.4 energy detect loop count

Number of iterations to perform an ED scan. If set to 0 one scan is performed, otherwise the specified number + 1 of ED scans will be performed and the max ED value tracked in EDSAMPLE.



#### 7.26.15.113 EDSAMPLE

Address offset: 0x668

IEEE 802.15.4 energy detect level





## 7.26.15.114 CCACTRL

Address offset: 0x66C

IEEE 802.15.4 clear channel assessment control

| Bit n | umber    |              |                  | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|------------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |              |                  | D D D D D D D           | ОСССССССВВВВВВВВ ААА                                            |
| Rese  | et 0x052 | 2D0000       |                  | 0 0 0 0 0 1 0 1         | . 0 0 1 0 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |                  |                         |                                                                 |
| Α     | RW       | CCAMODE      |                  |                         | CCA mode of operation                                           |
|       |          |              | EdMode           | 0                       | Energy above threshold                                          |
|       |          |              |                  |                         | Will report busy whenever energy is detected above              |
|       |          |              |                  |                         | CCAEDTHRES                                                      |
|       |          |              | CarrierMode      | 1                       | Carrier seen                                                    |
|       |          |              |                  |                         | Will report busy whenever compliant IEEE 802.15.4 signal        |
|       |          |              |                  |                         | is seen                                                         |
|       |          |              | CarrierAndEdMode | 2                       | Energy above threshold AND carrier seen                         |
|       |          |              | CarrierOrEdMode  | 3                       | Energy above threshold OR carrier seen                          |
|       |          |              | EdModeTest1      | 4                       | Energy above threshold test mode that will abort when           |
|       |          |              |                  |                         | first ED measurement over threshold is seen. No averaging.      |
| В     | RW       | CCAEDTHRES   |                  |                         | CCA energy busy threshold. Used in all the CCA modes            |
|       |          |              |                  |                         | except CarrierMode.                                             |
|       |          |              |                  |                         | Must be converted from IEEE 802.15.4 range by dividing by       |
|       |          |              |                  |                         | factor ED_RSSISCALE - similar to EDSAMPLE register              |
| С     | RW       | CCACORRTHRES |                  |                         | CCA correlator busy threshold. Only relevant to                 |
|       |          |              |                  |                         | CarrierMode, CarrierAndEdMode, and CarrierOrEdMode.             |
| D     | RW       | CCACORRCNT   |                  |                         | Limit for occurances above CCACORRTHRES. When not               |
|       |          |              |                  |                         | equal to zero the corrolator based signal detect is enabled.    |

### 7.26.15.115 DFEMODE

Address offset: 0x900

Whether to use Angle-of-Arrival (AOA) or Angle-of-Departure (AOD)





# 7.26.15.116 CTEINLINECONF

Address offset: 0x904

Configuration for CTE inline mode

| Bit n | umber    |                             |                | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                 |
|-------|----------|-----------------------------|----------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ID    |          |                             |                | 1 1 1 1 1 1 1           | H H H H H H H G G G F F F E E C B A                                                                                                                                                             |
| Rese  | et 0x000 | 02800                       |                | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0                                                                                                                                                         |
| ID    |          |                             |                |                         | Description                                                                                                                                                                                     |
| A     | RW       | CTEINLINECTRLEN             | Enabled        | 1                       | Enable parsing of CTEInfo from received packet in BLE modes  Parsing of CTEInfo is enabled                                                                                                      |
|       |          |                             | Disabled       | 0                       | Parsing of CTEInfo is disabled                                                                                                                                                                  |
| В     | RW       | CTEINFOINS1                 |                |                         | CTEInfo is S1 byte or not                                                                                                                                                                       |
|       |          |                             | InS1           | 1                       | CTEInfo is in S1 byte (data PDU)                                                                                                                                                                |
|       |          |                             | NotInS1        | 0                       | CTEInfo is NOT in S1 byte (advertising PDU)                                                                                                                                                     |
| С     | RW       | CTEERRORHANDLING            |                |                         | Sampling/switching if CRC is not OK                                                                                                                                                             |
|       |          |                             | Yes            | 1                       | Sampling and antenna switching also when CRC is not OK                                                                                                                                          |
|       |          |                             | No             | 0                       | No sampling and antenna switching when CRC is not OK                                                                                                                                            |
| E     | RW       | CTETIMEVALIDRANGE           |                |                         | Max range of CTETime                                                                                                                                                                            |
|       |          |                             | 20             | 0                       | Valid range is 2-20 in the Bluetooth Core Specification. If larger than 20, it can be an indication of an error in the received packet. $20 \text{ in } 8  \mu \text{s} \text{ unit (default)}$ |
|       |          |                             |                |                         | Set to 20 if parsed CTETime is larger than 20                                                                                                                                                   |
|       |          |                             | 31             | 1                       | 31 in 8 µs unit                                                                                                                                                                                 |
|       |          |                             | 63             | 2                       | 63 in 8 µs unit                                                                                                                                                                                 |
| F     | RW       | CTEINLINERXMODE1US          |                | _                       | Spacing between samples for the samples in the                                                                                                                                                  |
|       |          |                             |                |                         | SWITCHING period when CTEINLINEMODE is set.                                                                                                                                                     |
|       |          |                             |                |                         |                                                                                                                                                                                                 |
|       |          |                             |                |                         | AoD 1 μs                                                                                                                                                                                        |
|       |          |                             | 4us            | 1                       | 4 μs                                                                                                                                                                                            |
|       |          |                             | 2us            | 2                       | 2 μs                                                                                                                                                                                            |
|       |          |                             | 1us            | 3<br>4                  | 1 μs                                                                                                                                                                                            |
|       |          |                             | 500ns<br>250ns | 5                       | 0.5 µs                                                                                                                                                                                          |
|       |          |                             | 125ns          | 6                       | 0.25 μs<br>0.125 μs                                                                                                                                                                             |
| G     | RW       | CTEINLINERXMODE2US          |                | 0                       | Spacing between samples for the samples in the                                                                                                                                                  |
| J     |          | 012.112.112.10.111.03.22.00 |                |                         | SWITCHING period when CTEINLINEMODE is set.                                                                                                                                                     |
|       |          |                             |                |                         | When the device is in AoD mode, this is used when the                                                                                                                                           |
|       |          |                             |                |                         | received CTEType is "AoD 2 $\mu s$ ". When in AoA mode, this is                                                                                                                                 |
|       |          |                             |                |                         | used when TSWITCHSPACING is 4 $\mu s$ .                                                                                                                                                         |
|       |          |                             | 4us            | 1                       | 4 μs                                                                                                                                                                                            |
|       |          |                             | 2us            | 2                       | 2 μs                                                                                                                                                                                            |
|       |          |                             | 1us            | 3                       | 1 μs                                                                                                                                                                                            |
|       |          |                             | 500ns          | 4                       | 0.5 μs                                                                                                                                                                                          |
|       |          |                             | 250ns          | 5                       | 0.25 μs                                                                                                                                                                                         |
|       |          |                             | 125ns          | 6                       | 0.125 μs                                                                                                                                                                                        |
| Н     | RW       | SOCONF                      |                |                         | SO bit pattern to match                                                                                                                                                                         |
|       |          |                             |                |                         | The least significant bit always corresponds to the first bit of SO received.                                                                                                                   |



| Bit n | umber   |        | 31 | 30 | 29 | 28 | 27 26 | 5 25 | 5 24 | 123 | 22    | 2 21        | 20    | 19 1 | 18 1 | 7 16 | 15   | 14   | 13 12 | 2 11 | 10 9 | 8    | 7    | 6     | 5   | 4 | 3 2 | 2 1 | 0 |
|-------|---------|--------|----|----|----|----|-------|------|------|-----|-------|-------------|-------|------|------|------|------|------|-------|------|------|------|------|-------|-----|---|-----|-----|---|
| ID    |         |        | 1  | 1  | 1  | 1  | 1 1   | -1   | -1   | Н   | Н     | Н           | Н     | Н    | н н  | Н    | G    | G    | G F   | F    | F    |      | Ε    | Ε     |     | С | В   |     | Α |
| Rese  | t 0x000 | 02800  | 0  | 0  | 0  | 0  | 0 0   | 0    | 0    | 0   | 0     | 0           | 0     | 0    | 0 0  | 0    | 0    | 0    | 1 0   | 1    | 0 (  | 0    | 0    | 0     | 0   | 0 | 0 ( | 0   | 0 |
| ID    |         |        |    |    |    |    |       |      |      |     |       |             |       |      |      |      |      |      |       |      |      |      |      |       |     |   |     |     |   |
| 1     | RW      | SOMASK |    |    |    |    |       |      |      | S0  | bit ( | t ma        | ask ' | to s | et v | hic  | h bi | t to | mat   | ch   |      |      |      |       |     |   |     |     |   |
|       |         |        |    |    |    |    |       |      |      |     |       | east<br>rec | ·     |      | cant | bit  | alw  | ays  | corr  | espo | onds | to t | he i | first | bit | t |     |     |   |

# 7.26.15.117 DFECTRL1

Address offset: 0x910

Various configuration for Direction finding

| Bit n | umber    |                   |                | 31     | 30 2 | 29 28 | 3 27 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |   |                                                       |      |     | . 0  |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|-------|----------|-------------------|----------------|--------|------|-------|------|--------------------------------------------------------------------------|---|-------------------------------------------------------|------|-----|------|-------|------|------|-----|------|------|------|------|-----|-------|------|------|------|-----|------|-----|-----|-----|---|-----|
| ID    |          |                   |                |        |      |       | -1   | 1                                                                        | ī | ī                                                     | н    | 1 1 | н н  |       | G    | G    | (   | 6 F  |      | Ε Ε  |      | Е   |       | С    | С    | С    | В   | ,    | ۸ , | Δ / | . Δ | A | A   |
| Rese  | et 0x000 | 23282             |                | 0      | 0    | 0 0   | 0    | 0                                                                        | 0 | 0                                                     | 0 (  | ) ( | 0    | 0     | 0    | 1    | C   | ) (  | ) (  | ) 1  | L    | 1   | 0     | 0    | 1    | 0    | 1   | 0 (  | ) ( | 0 0 | 0   | 1 | . 0 |
| ID    |          |                   |                |        |      |       |      |                                                                          |   |                                                       |      |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
| Α     | RW       | NUMBEROF8US       |                |        |      |       | Т    | Т                                                                        | Т |                                                       | Len  | gth | of t | he A  | ٩o   | A/A  | lo  | ) p  | oc   | edı  | ıre  | ir  | n nu  | mb   | er   | of 8 | 3 μ | s ur | its | Т   | Т   | Т |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | Alw  | ays | use  | d in  | 1 T. | Χm   | 100 | de,  | bu   | t in | R۶   | ( n | nod   | e o  | nly  | wh   | ien |      |     |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | СТЕ  | NL  | INE  | CTR   | LE   | N is | 0   |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
| В     | RW       | DFEINEXTENSION    |                |        |      |       |      |                                                                          |   |                                                       | Add  | СТ  | E ex | ten   | sic  | on a | nc  | d d  | o a  | nte  | nn   | a s | wit   | chi  | ng,  | /sar | np  | ling | in  |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | this | ext | ens  | ion   |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | CRC            | 1      |      |       |      |                                                                          |   |                                                       | AoA  | /Ac | D p  | roc   | ed   | lure | tr  | igg  | ere  | ed a | ıt e | end | d of  | CR   | С    |      |     |      |     |     |     |   |     |
|       |          |                   | Payload        | 0      |      |       |      |                                                                          |   |                                                       | Ante | enn | a sv | vitcl | hir  | ng/s | sar | np   | in   | j is | do   | ne  | in '  | he   | pa   | cke  | t p | aylo | oac | ı   |     |   |     |
| С     | RW       | TSWITCHSPACING    |                |        |      |       |      |                                                                          |   |                                                       | Inte | rva | l be | twe   | en   | ev   | er  | y ti | me   | th   | e a  | nt  | enn   | a is | s ch | nan  | geo | d in | the | 9   |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | SWI  | TCŀ | HING | sta   | ate  | è    |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 4us            | 1      |      |       |      |                                                                          |   |                                                       | 4 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 2us            | 2      |      |       |      |                                                                          |   |                                                       | 2 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 1us            | 3      |      |       |      |                                                                          |   | 1 μs Interval between samples in the REFERENCE period |      |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
| E     | RW       | TSAMPLESPACINGREF |                |        |      |       |      |                                                                          |   |                                                       |      |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 4us            | 1      |      |       |      |                                                                          |   |                                                       | 4 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 2us            | 2      |      |       |      |                                                                          |   |                                                       | 2 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 1us            | 3      |      |       |      |                                                                          |   |                                                       | 1 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 500ns<br>250ns | 4<br>5 |      |       |      |                                                                          |   |                                                       | 0.5  |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 125ns          | 6      |      |       |      |                                                                          |   |                                                       | 0.23 |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
| F     | RW       | SAMPLETYPE        | 123113         | Ū      |      |       |      |                                                                          |   |                                                       | Whe  |     |      | saı   | mı   | ole  | 1/0 | ) o  | m    | agı  | niti | ud  | e/p   | has  | e    |      |     |      |     |     |     |   |     |
| ·     |          |                   | IQ             | 0      |      |       |      |                                                                          |   |                                                       | Con  |     |      |       |      |      |     |      |      | 0    |      |     | -,  - |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | MagPhase       | 1      |      |       |      |                                                                          |   |                                                       | Com  |     |      |       |      |      |     |      |      | ude  | aı   | nd  | pha   | ise  |      |      |     |      |     |     |     |   |     |
| G     | RW       | TSAMPLESPACING    |                |        |      |       |      |                                                                          |   |                                                       | Inte | rva | l be | twe   | en   | ı sa | mp  | oles | in   | the  | e S  | w   | ITCI  | HIN  | G p  | oeri | od  | wh   | en  |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | CTE  | NL  | INE  | CTR   | LE   | N is | 0   |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | Whe  | n ( | ^TFI | NI II | NF   | ·CTI | RH  | FN   | is ' |      | TF   | INI | LINI  | -R)  | (M)  | וחח  | -1I | ıs   |     |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | or C |     |      |       |      |      |     |      |      |      |      |     |       |      |      | 00.  |     | ,,   |     |     |     |   |     |
|       |          |                   |                |        |      |       |      |                                                                          |   |                                                       | TSA  |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 4us            | 1      |      |       |      |                                                                          |   |                                                       | 4 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 2us            | 2      |      |       |      |                                                                          |   |                                                       | 2 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 1us            | 3      |      |       |      |                                                                          |   |                                                       | 1 μs |     |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 500ns          | 4      |      |       |      |                                                                          |   |                                                       | 0.5  | ıs  |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 250ns          | 5      |      |       |      |                                                                          |   |                                                       | 0.25 | μs  |      |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
|       |          |                   | 125ns          | 6      |      |       |      |                                                                          |   |                                                       | 0.12 | 5 μ | ıs   |       |      |      |     |      |      |      |      |     |       |      |      |      |     |      |     |     |     |   |     |
| Н     | RW       | REPEATPATTERN     |                |        |      |       |      |                                                                          |   |                                                       | Rep  | eat | eac  | h in  | ıdi  | vid  | ua  | l ar | te   | nna  | ра   | att | ern   | N 1  | im   | es   |     |      |     |     |     |   |     |

4406\_640 v1.3 495



sequentially, i.e. P0, P0, P1, P1, P2, P2, P3, P3, etc.



#### 7.26.15.118 DFECTRL2

Address offset: 0x914

Start offset for Direction finding

| Bit n | umber   |               | 31 30 2 | 29 28 | 3 27 2 | 6 25 | 24 | 23 2               | 22 2                | 1 20                         | 19            | 18 1 <sup>-</sup>                                | 7 16        | 5 15          | 14 1                          | 3 12                    | 11              | 10 9           | 8          | 7    | 6     | 5 4   | 1 3 | 2 | 1 0 |
|-------|---------|---------------|---------|-------|--------|------|----|--------------------|---------------------|------------------------------|---------------|--------------------------------------------------|-------------|---------------|-------------------------------|-------------------------|-----------------|----------------|------------|------|-------|-------|-----|---|-----|
| ID    |         |               |         |       | ВЕ     | 3 B  | В  | В                  | ВЕ                  | 3 B                          | В             | ВВ                                               | В           |               |                               | Α                       | Α               | A A            | A          | Α    | Α     | A A   | A A | Α | АА  |
| Rese  | t 0x000 | 00000         | 0 0     | 0 0   | 0 0    | 0    | 0  | 0                  | 0 (                 | 0 0                          | 0             | 0 0                                              | 0           | 0             | 0 (                           | 0                       | 0               | 0 (            | 0          | 0    | 0     | 0 (   | 0   | 0 | 0 0 |
| ID    |         |               |         |       |        |      |    |                    |                     |                              |               |                                                  |             |               |                               |                         |                 |                |            |      |       |       |     |   |     |
| A     | RW      | TSWITCHOFFSET |         |       |        |      |    | swi                | tchi                | ng ir<br>sing                | n nu<br>; TSV | ffset<br>imbe<br>WITCI<br>edure                  | r of<br>HOI | 16 I          | MHz<br>T be                   | clo                     | ck cy           | ycles<br>e tri |            |      |       | rting | 3   |   |     |
| В     | RW      | TSAMPLEOFFSET |         |       |        |      |    | fine<br>TSA<br>the | e tui<br>AMP<br>sta | ning<br>LEO<br>rt of<br>sing | of to         | ffset<br>the sa<br>ET=0<br>refe<br>AMPL<br>edure | the<br>ren  | first<br>ce p | inst<br>t sar<br>erio<br>T be | ant<br>nple<br>d<br>yon | for a<br>s is t | all IC<br>aker | san<br>imr | nple | es. V | Vith  |     |   |     |

#### 7.26.15.119 SWITCHPATTERN

Address offset: 0x928

GPIO patterns to be used for each antenna

Maximum 8 GPIOs can be controlled. To secure correct signal levels on the pins, the pins must be configured in the GPIO peripheral as described in Pin configuration.

If, during switching, the total number of antenna slots is bigger than the number of written patterns, the RADIO loops back to the pattern used after the reference pattern.

A minimum number of three patterns must be written.





#### 7.26.15.120 CLEARPATTERN

Address offset: 0x92C

Clear the GPIO pattern array for antenna control



# 7.26.15.121 PSEL.DFEGPIO[n] (n=0..7)

Address offset:  $0x930 + (n \times 0x4)$ 

Pin select for DFE pin n

Must be set before enabling the radio



## 7.26.15.122 DFEPACKET.PTR

Address offset: 0x950

Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

#### 7.26.15.123 DFEPACKET.MAXCNT

Address offset: 0x954

Maximum number of buffer words to transfer



#### 7.26.15.124 DFEPACKET.AMOUNT

Address offset: 0x958

Number of samples transferred in the last transaction



#### 7.26.15.125 POWER

Address offset: 0xFFC

Peripheral power control

| Bit r | umber    |       |          | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|------------------|-----------------------------------------------------------------------|
| ID    |          |       |          |                  | A                                                                     |
| Rese  | et 0x000 | 00001 |          | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |       |          |                  |                                                                       |
| Α     | RW       | POWER |          |                  | Peripheral power control. The peripheral and its registers            |
|       |          |       |          |                  | will be reset to its initial state by switching the peripheral        |
|       |          |       |          |                  | off and then back on again.                                           |
|       |          |       | Disabled | 0                | Peripheral is powered off                                             |
|       |          |       | Enabled  | 1                | Peripheral is powered on                                              |



# 7.26.16 Electrical specification

# 7.26.16.1 General radio characteristics

| Symbol                           | Description                               | Min. | Тур. | Max. | Units   |
|----------------------------------|-------------------------------------------|------|------|------|---------|
| $f_{OP}$                         | Operating frequencies                     | 2360 |      | 2500 | MHz     |
| f <sub>PLL,CH,SP</sub>           | PLL channel spacing                       |      | 1.0  |      | MHz     |
| f <sub>DELTA,1M</sub>            | Frequency deviation @ 1 Mbps              |      | ±170 |      | kHz     |
| f <sub>DELTA,BLE,1M</sub>        | Frequency deviation @ Bluetooth LE 1 Mbps |      | ±250 |      | kHz     |
| f <sub>DELTA,2M</sub>            | Frequency deviation @ 2 Mbps              |      | ±320 |      | kHz     |
| f <sub>DELTA,BLE,2M</sub>        | Frequency deviation @ Bluetooth LE 2 Mbps |      | ±500 |      | kHz     |
| fsk <sub>BPS</sub>               | On-the-air data rate                      | 125  |      | 2000 | kbps    |
| f <sub>chip, IEEE 802.15.4</sub> | Chip rate in IEEE 802.15.4 mode           |      | 2000 |      | kchip/s |

# 7.26.16.2 Radio current consumption (transmitter)

| Symbol                          | Description                                               | Min. | Тур. | Max. | Units |
|---------------------------------|-----------------------------------------------------------|------|------|------|-------|
| I <sub>TX,PLUS3dBM,DCDC</sub>   | TX only run current DC/DC, 3 V, P <sub>RF</sub> = +3 dBm  |      | 5.1  |      | mA    |
| I <sub>TX,PLUS3dBM</sub>        | TX only run current P <sub>RF</sub> = +3 dBm              |      | 11.3 |      | mA    |
| I <sub>TX,0dBM,DCDC</sub>       | TX only run current DC/DC, 3 V, P <sub>RF</sub> = 0 dBm   |      | 3.4  |      | mA    |
| I <sub>TX,0dBM</sub>            | TX only run current P <sub>RF</sub> = 0 dBm               |      | 9.1  |      | mA    |
| I <sub>TX,MINUS4dBM,DCDC</sub>  | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -4 dBm  |      | 2.7  |      | mA    |
| I <sub>TX,MINUS4dBM</sub>       | TX only run current P <sub>RF</sub> = -4 dBm              |      | 7.2  |      | mA    |
| I <sub>TX,MINUS8dBM,DCDC</sub>  | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -8 dBm  |      | 2.2  |      | mA    |
| I <sub>TX,MINUS8dBM</sub>       | TX only run current P <sub>RF</sub> = -8 dBm              |      | 5.8  |      | mA    |
| I <sub>TX,MINUS12dBM,DCDC</sub> | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -12 dBm |      | 2.0  |      | mA    |
| I <sub>TX,MINUS12dBM</sub>      | TX only run current P <sub>RF</sub> = -12 dBm             |      | 5.0  |      | mA    |
| I <sub>TX,MINUS16dBM,DCDC</sub> | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -16 dBm |      | 1.8  |      | mA    |
| I <sub>TX,MINUS16dBM</sub>      | TX only run current P <sub>RF</sub> = -16 dBm             |      | 4.5  |      | mA    |
| $I_{TX,MINUS20dBM,DCDC}$        | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -20 dBm |      | 1.7  |      | mA    |
| I <sub>TX,MINUS20dBM</sub>      | TX only run current P <sub>RF</sub> = -20 dBm             |      | 4.2  |      | mA    |
| I <sub>TX,MINUS40dBM,DCDC</sub> | TX only run current DC/DC, 3 V, P <sub>RF</sub> = -40 dBm |      | 1.5  |      | mA    |
| I <sub>TX,MINUS40dBM</sub>      | TX only run current P <sub>RF</sub> = -40 dBm             |      | 3.8  |      | mA    |
| I <sub>START,TX,DCDC</sub>      | TX start-up current DC/DC, 3 V, P <sub>RF</sub> = 3 dBm   |      | 2.4  |      | mA    |
| I <sub>START,TX</sub>           | TX start-up current, P <sub>RF</sub> = 3 dBm              |      | 5.4  |      | mA    |

# 7.26.16.3 Radio current consumption (receiver)

| Symbol                        | Description                                              | Min. | Тур. | Max. | Units |
|-------------------------------|----------------------------------------------------------|------|------|------|-------|
| I <sub>RX,1M,DCDC</sub>       | RX only run current DC/DC, 3 V, 1 Mbps/1 Mbps Bluetooth  |      | 2.7  |      | mA    |
|                               | LE mode                                                  |      |      |      |       |
| I <sub>RX,1M</sub>            | RX only run current LDO, 3 V, 1 Mbps/1 Mbps Bluetooth LE |      | 6.7  |      | mA    |
|                               | mode                                                     |      |      |      |       |
| I <sub>RX,2M,DCDC</sub>       | RX only run current DC/DC, 3 V, 2 Mbps/2 Mbps Bluetooth  |      | 3.1  |      | mA    |
|                               | LE mode                                                  |      |      |      |       |
| I <sub>RX,2M</sub>            | RX only run current LDO, 3 V, 2 Mbps/2 Mbps Bluetooth LE |      | 7.9  |      | mA    |
|                               | mode                                                     |      |      |      |       |
| I <sub>START,RX,1M,DCDC</sub> | RX start-up current DC/DC, 3 V, 1 Mbps/1 Mbps Bluetooth  |      | 2.1  |      | mA    |
|                               | LE mode                                                  |      |      |      |       |
| I <sub>START,RX,1M</sub>      | RX start-up current 1 Mbps/1 Mbps Bluetooth LE mode      |      | 5.3  |      | mA    |



# 7.26.16.4 Transmitter specification

| Symbol                               | Description                                                 | Min. | Тур. | Max. | Units |
|--------------------------------------|-------------------------------------------------------------|------|------|------|-------|
| P <sub>RF</sub>                      | Maximum output power                                        |      | 3.0  |      | dBm   |
| P <sub>RFC</sub>                     | RF power control range                                      |      | 23.0 |      | dB    |
| P <sub>RFCR</sub>                    | RF power accuracy                                           |      | ±2   |      | dB    |
| P <sub>RF1,1</sub>                   | 1st Adjacent Channel Transmit Power 1 MHz (1 Mbps)          |      | -24  |      | dBc   |
| P <sub>RF2,1</sub>                   | 2nd Adjacent Channel Transmit Power 2 MHz (1 Mbps)          |      | -52  |      | dBc   |
| P <sub>RF1,2</sub>                   | 1st Adjacent Channel Transmit Power 2 MHz (2 Mbps)          |      | -25  |      | dBc   |
| P <sub>RF2,2</sub>                   | 2nd Adjacent Channel Transmit Power 4 MHz (2 Mbps)          |      | -50  |      | dBc   |
| E <sub>vm</sub>                      | Error vector magnitude in IEEE 802.15.4 mode                |      |      |      | %rms  |
| P <sub>harm2nd</sub> , IEEE 802.15.4 | 2nd harmonics in IEEE 802.15.4 mode                         |      | -51  |      | dBm   |
| P <sub>harm3rd, IEEE 802.15.4</sub>  | 3rd harmonics in IEEE 802.15.4 mode                         |      | -51  |      | dBm   |
| P <sub>ACP,R, IEEE 802.15.4</sub>    | IEEE 802.15.4 Relative adjacent Channel Power, offset > 3.5 |      | -36  |      | dBc   |
|                                      | MHz <sup>11</sup>                                           |      |      |      |       |
| P <sub>ACP,A, IEEE 802.15.4</sub>    | IEEE 802 15.4 Absolute adjacent Channel Power, offset > 3.5 |      | -36  |      | dBm   |
|                                      | MHz <sup>11</sup>                                           |      |      |      |       |
|                                      |                                                             |      |      |      |       |



Figure 171: Output power, 1 Mbps Bluetooth low energy mode, at maximum TXPOWER setting (typical values)



Output power set to maximum TXPOWER setting, resolution bandwidth (RBW) set to 100 kHz, and transmitter Duty-Cycle approximately 85%.



Figure 172: Output power, 1 Mbps Bluetooth low energy mode, at 0 dBm TXPOWER setting (typical values)

## 7.26.16.5 Receiver operation

| Symbol                          | Description                                                  | Min. | Тур. | Max. | Units |
|---------------------------------|--------------------------------------------------------------|------|------|------|-------|
| P <sub>RX,MAX</sub>             | Maximum received signal strength at < 0.1% PER               |      | 0    |      | dBm   |
| P <sub>SENS,IT,1M</sub>         | Sensitivity, 1 Mbps nRF mode ideal transmitter <sup>12</sup> |      | -95  |      | dBm   |
| P <sub>SENS,IT,2M</sub>         | Sensitivity, 2 Mbps nRF mode ideal transmitter <sup>12</sup> |      | -92  |      | dBm   |
| P <sub>SENS,IT,SP,1M,BLE</sub>  | Sensitivity, 1 Mbps Bluetooth LE ideal transmitter, packet   |      | -98  |      | dBm   |
|                                 | length ≤ 37 bytes BER = 1E-3 <sup>13</sup>                   |      |      |      |       |
| P <sub>SENS,IT,LP,1M,BLE</sub>  | Sensitivity, 1 Mbps Bluetooth LE ideal transmitter, packet   |      | -97  |      | dBm   |
|                                 | length ≥ 128 bytes BER = 1E-4 <sup>14</sup>                  |      |      |      |       |
| P <sub>SENS,IT,SP,2M,BLE</sub>  | Sensitivity, 2 Mbps Bluetooth LE ideal transmitter, packet   |      | -95  |      | dBm   |
|                                 | length ≤ 37 bytes                                            |      |      |      |       |
| P <sub>SENS,IT,BLE LE125k</sub> | Sensitivity, 125 kbps Bluetooth LE mode                      |      | -104 |      | dBm   |
| P <sub>SENS,IT,BLE LE500k</sub> | Sensitivity, 500 kbps Bluetooth LE mode                      |      | -100 |      | dBm   |
| P <sub>SENS,IEEE 802.15.4</sub> | Sensitivity in IEEE 802.15.4 mode                            |      | -101 |      | dBm   |



Typical sensitivity applies when ADDR0 is used for receiver address correlation. When ADDR[1...7] are used for receiver address correlation, the typical sensitivity for this mode is degraded by 3 dB.

As defined in the Bluetooth Core Specification v4.0 Volume 6: Core System Package (Low Energy Controller Volume).

<sup>&</sup>lt;sup>14</sup> Equivalent BER limit < 10E-04.



Figure 173: Sensitivity, 1 Mbps Bluetooth low energy mode, Regulator = DCDC (typical values)

# 7.26.16.6 Receiver selectivity

Receiver selectivity with equal modulation on interfering signal <sup>15</sup>

| Symbol                          | Description                                              | Min. | Тур. | Max. | Units |
|---------------------------------|----------------------------------------------------------|------|------|------|-------|
| C/I <sub>1M,co-channel</sub>    | 1Mbps mode, co-channel interference                      |      |      |      | dB    |
| C/I <sub>1M,-1MHz</sub>         | 1 Mbps mode, Adjacent (-1 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,+1MHz</sub>         | 1 Mbps mode, Adjacent (+1 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,-2MHz</sub>         | 1 Mbps mode, Adjacent (-2 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,+2MHz</sub>         | 1 Mbps mode, Adjacent (+2 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,-3MHz</sub>         | 1 Mbps mode, Adjacent (-3 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,+3MHz</sub>         | 1 Mbps mode, Adjacent (+3 MHz) interference              |      |      |      | dB    |
| C/I <sub>1M,±6MHz</sub>         | 1 Mbps mode, Adjacent (≥6 MHz) interference              |      |      |      | dB    |
| C/I <sub>1MBLE,co-channel</sub> | 1 Mbps Bluetooth LE mode, co-channel interference        |      | 6.9  |      | dB    |
| C/I <sub>1MBLE,-1MHz</sub>      | 1 Mbps Bluetooth LE mode, Adjacent (-1 MHz) interference |      | -2.6 |      | dB    |
| C/I <sub>1MBLE,+1MHz</sub>      | 1 Mbps Bluetooth LE mode, Adjacent (+1 MHz) interference |      | -8.5 |      | dB    |
| C/I <sub>1MBLE,-2MHz</sub>      | 1 Mbps Bluetooth LE mode, Adjacent (-2 MHz) interference |      | -27  |      | dB    |
| C/I <sub>1MBLE,+2MHz</sub>      | 1 Mbps Bluetooth LE mode, Adjacent (+2 MHz) interference |      | -45  |      | dB    |
| C/I <sub>1MBLE,&gt;3MHz</sub>   | 1 Mbps Bluetooth LE mode, Adjacent (≥3 MHz) interference |      | -50  |      | dB    |
| C/I <sub>1MBLE,image</sub>      | Image frequency interference                             |      | -27  |      | dB    |
| C/I <sub>1MBLE,image,1MHz</sub> | Adjacent (1 MHz) interference to in-band image frequency |      | -41  |      | dB    |
| C/I <sub>2M,co-channel</sub>    | 2 Mbps mode, co-channel interference                     |      |      |      | dB    |
| C/I <sub>2M,-2MHz</sub>         | 2 Mbps mode, Adjacent (-2 MHz) interference              |      |      |      | dB    |
| C/I <sub>2M,+2MHz</sub>         | 2 Mbps mode, Adjacent (+2 MHz) interference              |      |      |      | dB    |
| C/I <sub>2M,-4MHz</sub>         | 2 Mbps mode, Adjacent (-4 MHz) interference              |      |      |      | dB    |
| C/I <sub>2M,+4MHz</sub>         | 2 Mbps mode, Adjacent (+4 MHz) interference              |      |      |      | dB    |

Desired signal level at  $P_{IN}$  = -67 dBm. One interferer is used, having equal modulation as the desired signal. The input power of the interferer where the sensitivity equals BER = 1E-4 is presented.

| Symbol                              | Description                                              | Min. | Тур. | Max. | Units |
|-------------------------------------|----------------------------------------------------------|------|------|------|-------|
| C/I <sub>2M,-6MHz</sub>             | 2 Mbps mode, Adjacent (-6 MHz) interference              |      |      |      | dB    |
| C/I <sub>2M,+6MHz</sub>             | 2 Mbps mode, Adjacent (+6 MHz) interference              |      |      |      | dB    |
| C/I <sub>2M,≥12MHz</sub>            | 2 Mbps mode, Adjacent (≥12 MHz) interference             |      |      |      | dB    |
| C/I <sub>2MBLE,co-channel</sub>     | 2 Mbps Bluetooth LE mode, co-channel interference        |      | 7.1  |      | dB    |
| C/I <sub>2MBLE,-2MHz</sub>          | 2 Mbps Bluetooth LE mode, Adjacent (-2 MHz) interference |      | -2   |      | dB    |
| C/I <sub>2MBLE,+2MHz</sub>          | 2 Mbps Bluetooth LE mode, Adjacent (+2 MHz) interference |      | -11  |      | dB    |
| C/I <sub>2MBLE,-4MHz</sub>          | 2 Mbps Bluetooth LE mode, Adjacent (-4 MHz) interference |      | -22  |      | dB    |
| C/I <sub>2MBLE,+4MHz</sub>          | 2 Mbps Bluetooth LE mode, Adjacent (+4 MHz) interference |      | -47  |      | dB    |
| C/I <sub>2MBLE,≥6MHz</sub>          | 2 Mbps Bluetooth LE mode, Adjacent (≥6 MHz) interference |      | -54  |      | dB    |
| C/I <sub>2MBLE,image</sub>          | Image frequency interference                             |      | -22  |      | dB    |
| C/I <sub>2MBLE,image, 2MHz</sub>    | Adjacent (2 MHz) interference to in-band image frequency |      | -42  |      | dB    |
| C/I <sub>125k BLE LR,co</sub> -     | 125 kbps Bluetooth LE LR mode, co-channel interference   |      |      |      | dB    |
| channel                             |                                                          |      |      |      |       |
| C/I <sub>125k BLE LR,-1MHz</sub>    | 125 kbps Bluetooth LE LR mode, Adjacent (-1 MHz)         |      |      |      | dB    |
|                                     | interference                                             |      |      |      |       |
| C/I <sub>125k BLE LR,+1MHz</sub>    | 125 kbps Bluetooth LE LR mode, Adjacent (+1 MHz)         |      |      |      | dB    |
|                                     | interference                                             |      |      |      |       |
| C/I <sub>125k BLE LR,-2MHz</sub>    | 125 kbps Bluetooth LE LR mode, Adjacent (-2 MHz)         |      |      |      | dB    |
|                                     | interference                                             |      |      |      |       |
| C/I <sub>125k BLE LR,+2MHz</sub>    | 125 kbps Bluetooth LE LR mode, Adjacent (+2 MHz)         |      |      |      | dB    |
|                                     | interference                                             |      |      |      |       |
| C/I <sub>125k BLE LR,&gt;3MHz</sub> | 125 kbps Bluetooth LE LR mode, Adjacent (≥3 MHz)         |      |      |      | dB    |
|                                     | interference                                             |      |      |      |       |
| C/I <sub>125k BLE LR,image</sub>    | Image frequency interference                             |      |      |      | dB    |
| C/I <sub>IEEE 802.15.4,-5MHz</sub>  | IEEE 802.15.4 mode, Adjacent (-5 MHz) rejection          |      | -33  |      | dB    |
| C/I <sub>IEEE 802.15.4,+5MHz</sub>  | IEEE 802.15.4 mode, Adjacent (+5 MHz) rejection          |      | -38  |      | dB    |
| C/I <sub>IEEE 802.15.4</sub> ,      | IEEE 802.15.4 mode, Alternate (±10 MHz) rejection        |      | -50  |      | dB    |
| ±10MHz                              |                                                          |      |      |      |       |

# 7.26.16.7 Receiver intermodulation

Receiver intermodulation. Desired signal level at  $P_{\text{IN}}$  = -64 dBm. Two interferers with equal input power are used. The interferer closest in frequency is not modulated, the other interferer is modulated equal with the desired signal. The input power of the interferers where the sensitivity equals BER = 1E-3 is presented.

| Symbol                      | Description                                               | Min. | Тур. | Max. | Units |
|-----------------------------|-----------------------------------------------------------|------|------|------|-------|
| P <sub>IMD,5TH,1M</sub>     | IMD performance, 1 Mbps, 5th offset channel, packet       |      |      |      | dBm   |
|                             | length ≤ 37 bytes                                         |      |      |      |       |
| P <sub>IMD,5TH,1M,BLE</sub> | IMD performance, Bluetooth LE 1 Mbps, 5th offset channel, |      | -26  |      | dBm   |
|                             | packet length ≤ 37 bytes                                  |      |      |      |       |
| P <sub>IMD,5TH,2M</sub>     | IMD performance, 2 Mbps, 5th offset channel, packet       |      |      |      | dBm   |
|                             | length ≤ 37 bytes                                         |      |      |      |       |
| P <sub>IMD,5TH,2M,BLE</sub> | IMD performance, Bluetooth LE 2 Mbps, 5th offset channel, |      | -22  |      | dBm   |
|                             | packet length ≤ 37 bytes                                  |      |      |      |       |

# 7.26.16.8 Radio timing

| Symbol                   | Description                                               | Min. | Тур. | Max. | Units |
|--------------------------|-----------------------------------------------------------|------|------|------|-------|
| t <sub>TXEN,BLE,1M</sub> | Time between TXEN task and READY event after channel      |      | 140  |      | μs    |
|                          | FREQUENCY configured (1 Mbps Bluetooth LE and 150 $\mu s$ |      |      |      |       |
|                          | TIFS)                                                     |      |      |      |       |



| Symbol                               | Description                                            | Min. | Тур. | Max. | Units |
|--------------------------------------|--------------------------------------------------------|------|------|------|-------|
| t <sub>TXEN,FAST,BLE,1M</sub>        | Time between TXEN task and READY event after channel   |      | 40   |      | μs    |
|                                      | FREQUENCY configured (1 Mbps Bluetooth LE with fast    |      |      |      |       |
|                                      | ramp-up and 150 $\mu s$ TIFS)                          |      |      |      |       |
| t <sub>TXDIS,BLE,1M</sub>            | When in TX, delay between DISABLE task and DISABLED    |      | 6    |      | μs    |
|                                      | event for MODE = Nrf_1Mbit and MODE = Ble_1Mbit        |      |      |      |       |
| t <sub>RXEN,BLE,1M</sub>             | Time between the RXEN task and READY event after       |      | 140  |      | μs    |
|                                      | channel FREQUENCY configured (1 Mbps Bluetooth LE)     |      |      |      |       |
| t <sub>RXEN,FAST,BLE,1M</sub>        | Time between the RXEN task and READY event after       |      | 40   |      | μs    |
|                                      | channel FREQUENCY configured (1 Mbps Bluetooth LE with |      |      |      |       |
|                                      | fast ramp-up)                                          |      |      |      |       |
| t <sub>RXDIS,BLE,1M</sub>            | When in RX, delay between DISABLE task and DISABLED    |      | 0    |      | μs    |
|                                      | event for MODE = Nrf_1Mbit and MODE = Ble_1Mbit        |      |      |      |       |
| t <sub>TXDIS,BLE,2M</sub>            | When in TX, delay between DISABLE task and DISABLED    |      | 4    |      | μs    |
|                                      | event for MODE = Nrf_2Mbit and MODE = Ble_2Mbit        |      |      |      |       |
| t <sub>RXDIS,BLE,2M</sub>            | When in RX, delay between DISABLE task and DISABLED    |      | 0    |      | μs    |
|                                      | event for MODE = Nrf_2Mbit and MODE = Ble_2Mbit        |      |      |      |       |
| t <sub>TXEN,IEEE 802.15.4</sub>      | Time between TXEN task and READY event after channel   |      | 130  |      | μs    |
|                                      | FREQUENCY configured (IEEE 802.15.4 mode)              |      |      |      |       |
| t <sub>TXEN,FAST,IEEE</sub> 802.15.4 | Time between TXEN task and READY event after channel   |      | 40   |      | μs    |
|                                      | FREQUENCY configured (IEEE 802.15.4 mode with fast     |      |      |      |       |
|                                      | ramp-up)                                               |      |      |      |       |
| t <sub>TXDIS,IEEE 802.15.4</sub>     | When in TX, delay between DISABLE task and DISABLED    |      | 21   |      | μs    |
|                                      | event (IEEE 802.15.4 mode)                             |      |      |      |       |
| t <sub>RXEN,IEEE</sub> 802.15.4      | Time between the RXEN task and READY event after       |      | 130  |      | μs    |
|                                      | channel FREQUENCY configured (IEEE 802.15.4 mode)      |      |      |      |       |
| t <sub>RXEN,FAST,IEEE</sub> 802.15.4 | Time between the RXEN task and READY event after       |      | 40   |      | μs    |
|                                      | channel FREQUENCY configured (IEEE 802.15.4 mode with  |      |      |      |       |
|                                      | fast ramp-up)                                          |      |      |      |       |
| t <sub>rxdis,ieee 802.15.4</sub>     | When in RX, delay between DISABLE task and DISABLED    |      | 0.5  |      | μs    |
|                                      | event (IEEE 802.15.4 mode)                             |      |      |      |       |
| t <sub>RX-to-TX</sub> turnaround     | Maximum TX-to-RX or RX-to-TX turnaround time in IEEE   |      | 40   |      | μs    |
|                                      | 802.15.4 mode                                          |      |      |      |       |

# 7.26.16.9 Received signal strength indicator (RSSI) specifications

| Symbol                     | Description                                  | Min. | Тур. | Max. | Units |
|----------------------------|----------------------------------------------|------|------|------|-------|
| RSSI <sub>ACC</sub>        | RSSI accuracy                                |      | ±2   |      | dB    |
| RSSI <sub>RESOLUTION</sub> | RSSI resolution                              |      | 1    |      | dB    |
| RSSI <sub>PERIOD</sub>     | RSSI sampling time from RSSI_START task      |      | 0.25 |      | μs    |
| RSSI <sub>SETTLE</sub>     | RSSI settling time after signal level change |      | 15   |      | μs    |

# 7.26.16.10 Jitter

| Symbol                      | Description                                          | Min. | Тур. | Max. | Units |
|-----------------------------|------------------------------------------------------|------|------|------|-------|
| t <sub>DISABLEDJITTER</sub> | Jitter on DISABLED event relative to END event when  |      | 0.25 |      | μs    |
|                             | shortcut between END and DISABLE is enabled          |      |      |      |       |
| t <sub>READYJITTER</sub>    | Jitter on READY event relative to TXEN and RXEN task |      | 0.25 |      | μs    |





# 7.26.16.11 IEEE 802.15.4 mode energy detection constants

| Symbol       | Description                                             | Min. | Тур. | Max. | Units |
|--------------|---------------------------------------------------------|------|------|------|-------|
| ED_RSSISCALE | Scaling value when converting between hardware-reported |      | 4    |      |       |
|              | value and dBm                                           |      |      |      |       |
| ED_RSSIOFFS  | Offset value when converting between hardware-reported  |      | -93  |      |       |
|              | value and dBm                                           |      |      |      |       |

# 7.27 RNG — Random number generator

The Random number generator (RNG) generates true non-deterministic random numbers based on internal thermal noise that are suitable for cryptographic purposes. The RNG does not require a seed value.



Figure 174: Random number generator

The RNG is started by triggering the START task and stopped by triggering the STOP task. When started, new random numbers are generated continuously and written to the VALUE register when ready. A VALRDY event is generated for every new random number that is written to the VALUE register. This means that after a VALRDY event is generated, the CPU has the time until the next VALRDY event to read out the random number from the VALUE register before it is overwritten by a new random number.

## 7.27.1 Bias correction

A bias correction algorithm is employed on the internal bit stream to remove any bias toward 1 or 0. The bits are then queued into an eight-bit register for parallel readout from the VALUE register.

It is possible to enable bias correction in the CONFIG register. This will result in slower value generation, but will ensure a statistically uniform distribution of the random values.

# 7.27.2 Speed

The time needed to generate one random byte of data is unpredictable, and may vary from one byte to the next. This is especially true when bias correction is enabled.

# 7.27.3 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description            | Configuration |
|---------------------|------------|----------|----------------|--------------|------------------------|---------------|
| 0x41009000 NETWORK  | RNG        | RNG      | NS             | NA           | Random number generato | r             |

Table 132: Instances

| Register        | Offset | Security | Description                               |
|-----------------|--------|----------|-------------------------------------------|
| TASKS_START     | 0x000  |          | Task starting the random number generator |
| TASKS_STOP      | 0x004  |          | Task stopping the random number generator |
| SUBSCRIBE_START | 0x080  |          | Subscribe configuration for task START    |
| SUBSCRIBE_STOP  | 0x084  |          | Subscribe configuration for task STOP     |



| Register       | Offset | Security | Description                                                                     |
|----------------|--------|----------|---------------------------------------------------------------------------------|
| EVENTS_VALRDY  | 0x100  |          | Event being generated for every new random number written to the VALUE register |
| PUBLISH_VALRDY | 0x180  |          | Publish configuration for event VALRDY                                          |
| SHORTS         | 0x200  |          | Shortcuts between local events and tasks                                        |
| INTENSET       | 0x304  |          | Enable interrupt                                                                |
| INTENCLR       | 0x308  |          | Disable interrupt                                                               |
| CONFIG         | 0x504  |          | Configuration register                                                          |
| VALUE          | 0x508  |          | Output random number                                                            |

Table 133: Register overview

# 7.27.3.1 TASKS\_START

Address offset: 0x000

Task starting the random number generator

| Bit n | umber   |             |         | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------|---------|---------------------|---------------------------------------------------------------------|
| ID    |         |             |         |                     | А                                                                   |
| Rese  | t 0x000 | 00000       |         | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |             |         |                     | Description                                                         |
| Α     | W       | TASKS_START |         |                     | Task starting the random number generator                           |
|       |         |             | Trigger | 1                   | Trigger task                                                        |

# 7.27.3.2 TASKS\_STOP

Address offset: 0x004

Task stopping the random number generator

| Bit n | umber            |            |         | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|------------|---------|------------------|-----------------------------------------------------------------------|
| ID    |                  |            |         |                  | A                                                                     |
| Rese  | Reset 0x00000000 |            |         | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |                  |            |         |                  |                                                                       |
| Α     | W                | TASKS_STOP |         |                  | Task stopping the random number generator                             |
|       |                  |            | Trigger | 1                | Trigger task                                                          |

# 7.27.3.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START

| Bit n | umber                                     |       |          | 31 30 29 28 27 26 25 24                 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 |
|-------|-------------------------------------------|-------|----------|-----------------------------------------|-------------------------------------------------------------|---|
| ID    |                                           |       |          | В                                       | A A A A A A                                                 | Α |
| Rese  | set 0x000000000 0 0 0 0 0 0 0 0 0 0 0 0 0 |       |          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0                                                           |   |
| ID    |                                           |       |          |                                         |                                                             |   |
| Α     | RW                                        | CHIDX |          | [2550]                                  | DPPI channel that task START will subscribe to              |   |
| В     | RW                                        | EN    |          |                                         |                                                             |   |
|       |                                           |       | Disabled | 0                                       | Disable subscription                                        |   |
|       |                                           |       | Enabled  | 1                                       | Enable subscription                                         |   |

# 7.27.3.4 SUBSCRIBE\_STOP

Address offset: 0x084



#### Subscribe configuration for task STOP



# 7.27.3.5 EVENTS\_VALRDY

Address offset: 0x100

Event being generated for every new random number written to the VALUE register

| Bit n | umber                |               |              | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |                                                   |  |
|-------|----------------------|---------------|--------------|-----------------------------------------------------------------------------------|---------------------------------------------------|--|
| ID    |                      |               |              |                                                                                   | A                                                 |  |
| Rese  | Reset 0x00000000 0 0 |               |              | 0 0 0 0 0 0 0                                                                     | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0           |  |
| ID    |                      |               |              |                                                                                   |                                                   |  |
| Α     | RW                   | EVENTS_VALRDY |              |                                                                                   | Event being generated for every new random number |  |
|       |                      |               |              | written to the VALUE register                                                     |                                                   |  |
|       |                      |               |              |                                                                                   |                                                   |  |
|       |                      |               | NotGenerated | 0                                                                                 | Event not generated                               |  |

## 7.27.3.6 PUBLISH\_VALRDY

Address offset: 0x180

Publish configuration for event VALRDY



#### 7.27.3.7 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks





#### **7.27.3.8 INTENSET**

Address offset: 0x304

Enable interrupt

| Bit n | umber                           |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------------------------------|--------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |                                 |        |          |                         | A                                                               |
| Rese  | Reset 0x000000000 0 0 0 0 0 0 0 |        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                                 |        |          |                         |                                                                 |
| Α     | RW                              | VALRDY |          |                         | Write '1' to enable interrupt for event VALRDY                  |
|       |                                 |        | Set      | 1                       | Enable                                                          |
|       |                                 |        |          |                         |                                                                 |
|       |                                 |        | Disabled | 0                       | Read: Disabled                                                  |

## **7.27.3.9 INTENCLR**

Address offset: 0x308

Disable interrupt

| Bit n | umber    |        |          | 31 30 29 28                             | 3 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |
|-------|----------|--------|----------|-----------------------------------------|-----------------------------------------------------------------------------|--|
| ID    |          |        |          |                                         | A                                                                           |  |
| Rese  | et 0x000 | 00000  |          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                             |  |
| ID    |          |        |          |                                         |                                                                             |  |
| Α     | RW       | VALRDY |          |                                         | Write '1' to disable interrupt for event VALRDY                             |  |
|       |          |        | Clear    | 1                                       | Disable                                                                     |  |
|       |          |        | Disabled | 0                                       | Read: Disabled                                                              |  |
|       |          |        | Enabled  | 1                                       | Read: Enabled                                                               |  |

## 7.27.3.10 CONFIG

Address offset: 0x504 Configuration register

| Bit n | umber    |        |          | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|----------|----------------|------------------------------------------------------------------------|
| ID    |          |        |          |                | А                                                                      |
| Rese  | et 0x000 | 00000  |          | 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |          |        |          |                |                                                                        |
| Α     | RW       | DERCEN |          |                | Bias correction                                                        |
|       |          |        | Disabled | 0              | Disabled                                                               |
|       |          |        | Enabled  | 1              | Enabled                                                                |

## 7.27.3.11 VALUE

Address offset: 0x508

Output random number





# 7.27.4 Electrical specification

# 7.27.4.1 RNG Electrical Specification

| Symbol                 | Description                                                 | Min. | Тур. | Max. | Units |
|------------------------|-------------------------------------------------------------|------|------|------|-------|
| t <sub>RNG,START</sub> | Time from setting the START task to generation begins.      |      | 128  |      | μs    |
|                        | This is a one-time delay on START signal and does not apply |      |      |      |       |
|                        | between samples.                                            |      |      |      |       |
| t <sub>RNG,RAW</sub>   | Run time per byte without bias correction. Uniform          |      | 32   |      | μs    |
|                        | distribution of 0 and 1 is not guaranteed.                  |      |      |      |       |
| t <sub>RNG,BC</sub>    | Run time per byte with bias correction. Uniform             |      |      | 122  | μs    |
|                        | distribution of 0 and 1 is guaranteed. Time to generate a   |      |      |      |       |
|                        | byte cannot be guaranteed.                                  |      |      |      |       |

# 7.28 RTC — Real-time counter

The real-time counter (RTC) module provides a generic, low-power timer on the low frequency clock source (LFCLK).



Figure 175: RTC block diagram

The RTC module features a 24-bit COUNTER, a 12-bit (1/X) prescaler, capture/compare registers, and a tick event generator.

## 7.28.1 Clock source

The RTC will run off the LFCLK.

When started, the RTC will automatically request the LFCLK source with RC oscillator if the LFCLK is not already running.

See CLOCK — Clock control on page 73 for more information about clock sources.

# 7.28.2 Resolution versus overflow and the prescaler

The relationship between the prescaler, counter resolution, and overflow is summarized in the following table.



| Prescaler          | Counter resolution | Overflow       |
|--------------------|--------------------|----------------|
| 0                  | 30.517 μs          | 512 seconds    |
| 2 <sup>8</sup> -1  | 7812.5 μs          | 131072 seconds |
| 2 <sup>12</sup> -1 | 125 ms             | 582.542 hours  |

Table 134: RTC resolution versus overflow

The counter increment frequency is given by the following equation:

```
f_{RTC} [kHz] = 32.768 / (PRESCALER + 1 )
```

The PRESCALER register can only be written when the RTC is stopped.

The prescaler is restarted on tasks START, CLEAR and TRIGOVRFLW. That is, the prescaler value is latched to an internal register (<<PRESC>>) on these tasks.

#### Examples:

1. Desired COUNTER frequency 100 Hz (10 ms counter period)

```
PRESCALER = round(32.768 kHz / 100 Hz) - 1 = 327 f_{RTC} = 99.9 Hz
```

10009.576 μs counter period

2. Desired COUNTER frequency 8 Hz (125 ms counter period)

```
PRESCALER = round(32.768 kHz / 8 Hz) - 1 = 4095 f_{RTC} = 8 Hz
125 ms counter period
```

# 7.28.3 Counter register

The internal <<COUNTER>> register increments on LFCLK when the internal PRESCALER register (<<PRESC>>) is 0x00. <<PRESC>> is reloaded from the PRESCALER register. If enabled, the TICK event occurs on each increment of the COUNTER.



Figure 176: Timing diagram - COUNTER\_PRESCALER\_0





Figure 177: Timing diagram - COUNTER\_PRESCALER\_1

## 7.28.3.1 Reading the counter register

To read the COUNTER register, the internal <<COUNTER>> value is sampled.

To ensure that the <<COUNTER>> is safely sampled (considering that an LFCLK transition may occur during a read), the CPU and core memory bus are halted for four PCLK16M cycles. In addition, the read takes the CPU two PCLK16M cycles, resulting in the COUNTER register read taking maximum six PCLK16M clock cycles.

#### 7.28.4 Overflow

An OVRFLW event is generated on COUNTER register overflow (overflowing from <code>Oxfffffff</code> to <code>O</code>).

The TRIGOVRFLW task will set the COUNTER value to 0xFFFFFF0, to allow software test of the overflow condition.

Note: The OVRFLW event is disabled by default.

#### 7.28.5 Tick event

The TICK event enables low-power tickless RTOS implementation, as it optionally provides a regular interrupt source for an RTOS with no need for use of the ARM SysTick feature.

Using the TICK event, rather than the SysTick, allows the CPU to be powered down while keeping RTOS scheduling active.

**Note:** The TICK event is disabled by default.

#### 7.28.6 Event control

To optimize the RTC power consumption, events in the RTC can be individually disabled to prevent PCLK16M and HFCLK from being requested when those events are triggered. This is managed using the EVTEN register.

This means that the RTC implements a slightly different task and event system compared to the standard system described in Peripheral interface on page 150. The RTC task and event system is illustrated in the following figure.





Figure 178: Tasks, events, and interrupts in the RTC

# 7.28.7 Capture

The RTC implements one capture task for every available capture/compare register.

Every time TASKS\_CAPTURE[n] is triggered, <<COUNTER>> is copied to the corresponding CC[n] register.

If the CAPTURE and CLEAR tasks are triggered at the same time, the CAPTURE task will be prioritized. This means that the CC[n] register for the corresponding CAPTURE[n] task will be set to the captured value before the counter is reset. There is a delay of 6 PCLK16M periods from when the TASKS\_CAPTURE[n] is triggered until the corresponding CC[n] register is updated.

The CAPTURE[n] tasks will not generate COMPARE[n] events, even though CC[n] will then equal the COUNTER.

# 7.28.8 Compare

The RTC implements one COMPARE event for every available compare register.

When the COUNTER is incremented and then becomes equal to the value specified in the register CC[n], the corresponding compare event COMPARE[n] is generated.

When writing a CC[n] register, the RTC COMPARE event exhibits several behaviors. See the following figures for more information.

If a CC value is 0 when a CLEAR task is set, this will not trigger a COMPARE event.





Figure 179: Timing diagram - COMPARE\_CLEAR

If a CC value is N and the COUNTER value is N when the START task is set, this will not trigger a COMPARE event.



Figure 180: Timing diagram - COMPARE\_START

A COMPARE event occurs when a CC value is N, and the COUNTER value transitions from N-1 to N.



Figure 181: Timing diagram - COMPARE

If the COUNTER value is N, writing N+2 to a CC register is guaranteed to trigger a COMPARE event at N+2.





Figure 182: Timing diagram - COMPARE\_N+2

If the COUNTER value is N, writing N or N+1 to a CC register may not trigger a COMPARE event.



Figure 183: Timing diagram - COMPARE N+1

If the COUNTER value is N, and the current CC value is N+1 or N+2 when a new CC value is written, a match may trigger on the previous CC value before the new value takes effect. If the current CC value is greater than N+2 when the new value is written, there will be no event due to the old value.



Figure 184: Timing diagram - COMPARE\_N-1

If the COMPARE[i]\_CLEAR short is enabled, the COUNTER will be cleared one LFClk after the COMPARE event.





Figure 185: Timing diagram - COMPARE CLEAR

# 7.28.9 Task and event jitter/delay

Jitter or delay in the RTC, is due to the peripheral clock being a low frequency clock (LFCLK), which is not synchronous to the faster PCLK16M.

Registers in the peripheral interface that are part of the PCLK16M domain, have a set of mirrored registers in the LFCLK domain. For example, the COUNTER value accessible from the CPU is in the PCLK16M domain, and is latched on a read from an internal COUNTER register in the LFCLK domain. The COUNTER register is modified each time the RTC ticks. The registers are synchronised between the two clock domains (PCLK16M and LFCLK).

CLEAR and STOP (and TRIGOVRFLW, which is not shown) will be delayed as long as it takes for the peripheral to clock a falling edge and a rising edge of the LFCLK. This is between 15.2585  $\mu$ s and 45.7755  $\mu$ s – rounded to 15  $\mu$ s and 46  $\mu$ s for the remainder of the section.



Figure 186: Timing diagram - DELAY CLEAR

When a STOP task is triggered, the PCLK16M domain will immediately prevent the generation of any EVENTS from the RTC. However, as seen in the following figure, the COUNTER value can still increment one final time.





Figure 187: Timing diagram - DELAY STOP

The START task will start the RTC. Assuming that the LFCLK was previously running and stable, the first increment of COUNTER (and instance of TICK event) will be typically after 30.5  $\mu$ s ±15  $\mu$ s. Additional delay will occur if the RTC is started before the LFCLK is running, see CLOCK — Clock control on page 73 for LFLK startup times. The software should therefore wait for the first TICK if it has to make sure that the RTC is running. Sending a TRIGOVRFLW task sets the COUNTER to a value close to overflow. However, since the update of COUNTER relies on a stable LFCLK, sending this task while LFCLK is not running will also add additional delay as previously described. The figures show the smallest and largest delays on the START task, appearing as a ±15  $\mu$ s jitter on the first COUNTER increment.



Figure 188: Timing diagram - JITTER\_START-



Figure 189: Timing diagram - JITTER\_START+

The following tables summarize jitter introduced for tasks and events. Any 32.768 kHz clock jitter will come in addition to these numbers.



| Task                            | Delay        |
|---------------------------------|--------------|
| CLEAR, START, STOP, TRIGOVRFLOW | +15 to 46 μs |

Table 135: RTC jitter magnitudes on tasks

| Operation/Function               | Jitter    |
|----------------------------------|-----------|
| START to COUNTER increment       | ± 15 μs   |
| COMPARE to COMPARE <sup>16</sup> | ± 62.5 ns |

Table 136: RTC jitter magnitudes on events

# 7.28.10 Registers

| Base address Domain      | Peripheral | Instance | Secure mapping | DMA security | Description         | Configuration |
|--------------------------|------------|----------|----------------|--------------|---------------------|---------------|
| 0x50014000<br>APPLICATIO | N DTC      | RTC0:S   | US             | NA           | Real time counter 0 |               |
| 0x40014000               | N KIC      | RTC0: NS | 03             | NA           | Real time counter o |               |
| 0x50015000 APPLICATIO    | N DTC      | RTC1:S   | US             | NA           | Real time counter 1 |               |
| 0x40015000               | N NIC      | RTC1: NS | 03             | NA           | Real time counter 1 |               |
| 0x41011000 NETWORK       | RTC        | RTC0     | NS             | NA           | Real-time counter 0 |               |
| 0x41016000 NETWORK       | RTC        | RTC1     | NS             | NA           | Real-time counter 1 |               |

Table 137: Instances

| Register             | Offset | Security | Description                                                                       |
|----------------------|--------|----------|-----------------------------------------------------------------------------------|
| TASKS_START          | 0x000  |          | Start RTC counter                                                                 |
| TASKS_STOP           | 0x004  |          | Stop RTC counter                                                                  |
| TASKS_CLEAR          | 0x008  |          | Clear RTC counter                                                                 |
| TASKS_TRIGOVRFLW     | 0x00C  |          | Set counter to 0xFFFFF0                                                           |
| TASKS_CAPTURE[n]     | 0x040  |          | Capture RTC counter to CC[n] register                                             |
| SUBSCRIBE_START      | 0x080  |          | Subscribe configuration for task START                                            |
| SUBSCRIBE_STOP       | 0x084  |          | Subscribe configuration for task STOP                                             |
| SUBSCRIBE_CLEAR      | 0x088  |          | Subscribe configuration for task CLEAR                                            |
| SUBSCRIBE_TRIGOVRFLW | 0x08C  |          | Subscribe configuration for task TRIGOVRFLW                                       |
| SUBSCRIBE_CAPTURE[n] | 0x0C0  |          | Subscribe configuration for task CAPTURE[n]                                       |
| EVENTS_TICK          | 0x100  |          | Event on counter increment                                                        |
| EVENTS_OVRFLW        | 0x104  |          | Event on counter overflow                                                         |
| EVENTS_COMPARE[n]    | 0x140  |          | Compare event on CC[n] match                                                      |
| PUBLISH_TICK         | 0x180  |          | Publish configuration for event TICK                                              |
| PUBLISH_OVRFLW       | 0x184  |          | Publish configuration for event OVRFLW                                            |
| PUBLISH_COMPARE[n]   | 0x1C0  |          | Publish configuration for event COMPARE[n]                                        |
| SHORTS               | 0x200  |          | Shortcuts between local events and tasks                                          |
| INTENSET             | 0x304  |          | Enable interrupt                                                                  |
| INTENCLR             | 0x308  |          | Disable interrupt                                                                 |
| EVTEN                | 0x340  |          | Enable or disable event routing                                                   |
| EVTENSET             | 0x344  |          | Enable event routing                                                              |
| EVTENCLR             | 0x348  |          | Disable event routing                                                             |
| COUNTER              | 0x504  |          | Current counter value                                                             |
| PRESCALER            | 0x508  |          | 12-bit prescaler for counter frequency (32768 / (PRESCALER + 1)). Must be written |
|                      |        |          | when RTC is stopped.                                                              |
|                      |        |          |                                                                                   |

<sup>&</sup>lt;sup>16</sup> Assumes RTC runs continuously between these events.



| Register | Offset | Security | Description        |
|----------|--------|----------|--------------------|
| CC[n]    | 0x540  |          | Compare register n |

Table 138: Register overview

# 7.28.10.1 TASKS\_START

Address offset: 0x000

Start RTC counter

| Bit n | umber   |             |         | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ( |
|-------|---------|-------------|---------|------------------|------------------------------------------------------------------------|
| ID    |         |             |         |                  | A                                                                      |
| Rese  | t 0x000 | 00000       |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |             |         |                  |                                                                        |
| Α     | W       | TASKS_START |         |                  | Start RTC counter                                                      |
|       |         |             | Trigger | 1                | Trigger task                                                           |

# 7.28.10.2 TASKS\_STOP

Address offset: 0x004

Stop RTC counter

| Bit n | umber   |            |         | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------|------------------|------------------------------------------------------------------------|
| ID    |         |            |         |                  | A                                                                      |
| Rese  | t 0x000 | 00000      |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |            |         |                  |                                                                        |
| Α     | W       | TASKS_STOP |         |                  | Stop RTC counter                                                       |
|       |         |            | Trigger | 1                | Trigger task                                                           |

# 7.28.10.3 TASKS\_CLEAR

Address offset: 0x008 Clear RTC counter

| Bit n | umber    |             |         | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------|---------|---------------------|--------------------------------------------------------------------|
| ID    |          |             |         |                     | A                                                                  |
| Rese  | et 0x000 | 00000       |         | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID    |          |             |         |                     | Description                                                        |
| Α     | W        | TASKS_CLEAR |         |                     | Clear RTC counter                                                  |
|       |          |             | Trigger | 1                   | Trigger task                                                       |

# 7.28.10.4 TASKS\_TRIGOVRFLW

Address offset: 0x00C

Set counter to 0xFFFFF0





## 7.28.10.5 TASKS\_CAPTURE[n] (n=0..3)

Address offset:  $0x040 + (n \times 0x4)$ 

Capture RTC counter to CC[n] register

# 7.28.10.6 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



## 7.28.10.7 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP

| Bit n | number   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|-----|
| ID    |          |       |          | В                       | A A A A A A                                                 | А А |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID    |          |       |          |                         |                                                             |     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to               |     |
| В     | RW       | EN    |          |                         |                                                             |     |
|       |          |       | Disabled | 0                       | Disable subscription                                        |     |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |     |

## 7.28.10.8 SUBSCRIBE\_CLEAR

Address offset: 0x088

Subscribe configuration for task CLEAR





# 7.28.10.9 SUBSCRIBE\_TRIGOVRFLW

Address offset: 0x08C

Subscribe configuration for task TRIGOVRFLW



# 7.28.10.10 SUBSCRIBE\_CAPTURE[n] (n=0..3)

Address offset:  $0x0C0 + (n \times 0x4)$ 

Subscribe configuration for task CAPTURE[n]

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task CAPTURE[n] will subscribe to             |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.28.10.11 EVENTS\_TICK

Address offset: 0x100

Event on counter increment







## 7.28.10.12 EVENTS\_OVRFLW

Address offset: 0x104

Event on counter overflow



## 7.28.10.13 EVENTS\_COMPARE[n] (n=0..3)

Address offset:  $0x140 + (n \times 0x4)$ Compare event on CC[n] match



# 7.28.10.14 PUBLISH\_TICK

Address offset: 0x180

Publish configuration for event TICK



## 7.28.10.15 PUBLISH\_OVRFLW

Address offset: 0x184

Publish configuration for event OVRFLW





# 7.28.10.16 PUBLISH\_COMPARE[n] (n=0..3)

Address offset:  $0x1C0 + (n \times 0x4)$ 

Publish configuration for event COMPARE[n]



## 7.28.10.17 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit no | umber   |                         |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0    |
|--------|---------|-------------------------|----------|------------------------|--------------------------------------------------------------------|
| ID     |         |                         |          |                        | D C B A                                                            |
| Rese   | t 0x000 | 00000                   |          | 0 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID     |         |                         |          |                        | Description                                                        |
|        |         |                         |          |                        |                                                                    |
| A-D    | RW      | COMPARE[i]_CLEAR        |          |                        | Shortcut between event COMPARE[i] and task CLEAR                   |
| A-D    | RW      | COMPARE[i]_CLEAR (i=03) |          |                        | Shortcut between event COMPARE[i] and task CLEAR                   |
| A-D    | RW      |                         | Disabled | 0                      | Shortcut between event COMPARE[i] and task CLEAR  Disable shortcut |

#### 7.28.10.18 INTENSET

Address offset: 0x304

**Enable interrupt** 







| Bit number               |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|--------------------------|----------|------------------------|-------------------------------------------------------------|-----|
| ID                       |          |                        | F E D C                                                     | ВА  |
| Reset 0x00000000         |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID R/W Field             |          |                        |                                                             |     |
|                          | Disabled | 0                      | Read: Disabled                                              |     |
|                          | Enabled  | 1                      | Read: Enabled                                               |     |
| C-F RW COMPARE[i] (i=03) |          |                        | Write '1' to enable interrupt for event COMPARE[i]          |     |
|                          | Set      | 1                      | Enable                                                      |     |
|                          | Disabled | 0                      | Read: Disabled                                              |     |
|                          | Enabled  | 1                      | Read: Enabled                                               |     |

# 7.28.10.19 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber                            |                   |                                         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------------------------------|-------------------|-----------------------------------------|------------------------|-----------------------------------------------------------------|
| ID    |                                  |                   |                                         |                        | F E D C B A                                                     |
| Rese  | Reset 0x00000000 0 0 0 0 0 0 0 0 |                   | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                        |                                                                 |
| ID    |                                  |                   |                                         |                        | Description                                                     |
| Α     | RW                               | TICK              |                                         |                        | Write '1' to disable interrupt for event TICK                   |
|       |                                  |                   | Clear                                   | 1                      | Disable                                                         |
|       |                                  |                   | Disabled                                | 0                      | Read: Disabled                                                  |
|       |                                  |                   | Enabled                                 | 1                      | Read: Enabled                                                   |
| В     | RW                               | OVRFLW            |                                         |                        | Write '1' to disable interrupt for event OVRFLW                 |
|       |                                  |                   | Clear                                   | 1                      | Disable                                                         |
|       |                                  |                   | Disabled                                | 0                      | Read: Disabled                                                  |
|       |                                  |                   | Enabled                                 | 1                      | Read: Enabled                                                   |
| C-F   | RW                               | COMPARE[i] (i=03) |                                         |                        | Write '1' to disable interrupt for event COMPARE[i]             |
|       |                                  |                   | Clear                                   | 1                      | Disable                                                         |
|       |                                  |                   | Disabled                                | 0                      | Read: Disabled                                                  |
|       |                                  |                   | Enabled                                 | 1                      | Read: Enabled                                                   |
|       |                                  |                   |                                         |                        |                                                                 |

# 7.28.10.20 EVTEN

Address offset: 0x340

Enable or disable event routing

| Bit n | umber   |                   |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                   |          |                         | F E D C                                                         |
| Rese  | t 0x000 | 00000             |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                   |          |                         |                                                                 |
| Α     | RW      | TICK              |          |                         | Enable or disable event routing for event TICK                  |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| В     | RW      | OVRFLW            |          |                         | Enable or disable event routing for event OVRFLW                |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |
| C-F   | RW      | COMPARE[i] (i=03) |          |                         | Enable or disable event routing for event COMPARE[i]            |
|       |         |                   | Disabled | 0                       | Disable                                                         |
|       |         |                   | Enabled  | 1                       | Enable                                                          |



# 7.28.10.21 EVTENSET

Address offset: 0x344 Enable event routing

| Bit n | umber   |                   |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |                   |          |                        | F E D C B A                                                     |
| Rese  | t 0x000 | 00000             |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                   |          |                        | Description                                                     |
| Α     | RW      | TICK              |          |                        | Write '1' to enable event routing for event TICK                |
|       |         |                   | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                   | Enabled  | 1                      | Read: Enabled                                                   |
|       |         |                   | Set      | 1                      | Enable                                                          |
| В     | RW      | OVRFLW            |          |                        | Write '1' to enable event routing for event OVRFLW              |
|       |         |                   | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                   | Enabled  | 1                      | Read: Enabled                                                   |
|       |         |                   | Set      | 1                      | Enable                                                          |
| C-F   | RW      | COMPARE[i] (i=03) |          |                        | Write '1' to enable event routing for event COMPARE[i]          |
|       |         |                   | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                   | Enabled  | 1                      | Read: Enabled                                                   |
|       |         |                   | Set      | 1                      | Enable                                                          |
|       |         |                   |          |                        |                                                                 |

# 7.28.10.22 EVTENCLR

Address offset: 0x348

Disable event routing

| Bit n | umber                          |                   |               | 31 30 29 28 27 26 25 2                  | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|--------------------------------|-------------------|---------------|-----------------------------------------|-----------------------------------------------------------------|
| ID    |                                |                   |               |                                         | F E D C B A                                                     |
| Rese  | Reset 0x00000000 0 0 0 0 0 0 0 |                   | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                                                                 |
| ID    |                                |                   |               |                                         | Description                                                     |
| Α     | RW                             | TICK              |               |                                         | Write '1' to disable event routing for event TICK               |
|       |                                |                   | Disabled      | 0                                       | Read: Disabled                                                  |
|       |                                |                   | Enabled       | 1                                       | Read: Enabled                                                   |
|       |                                |                   | Clear         | 1                                       | Disable                                                         |
| В     | RW                             | OVRFLW            |               |                                         | Write '1' to disable event routing for event OVRFLW             |
|       |                                |                   | Disabled      | 0                                       | Read: Disabled                                                  |
|       |                                |                   | Enabled       | 1                                       | Read: Enabled                                                   |
|       |                                |                   | Clear         | 1                                       | Disable                                                         |
| C-F   | RW                             | COMPARE[i] (i=03) |               |                                         | Write '1' to disable event routing for event COMPARE[i]         |
|       |                                |                   | Disabled      | 0                                       | Read: Disabled                                                  |
|       |                                |                   | Enabled       | 1                                       | Read: Enabled                                                   |
|       |                                |                   | Clear         | 1                                       | Disable                                                         |

## 7.28.10.23 COUNTER

Address offset: 0x504 Current counter value





#### 7.28.10.24 PRESCALER

Address offset: 0x508

12-bit prescaler for counter frequency (32768 / (PRESCALER + 1)). Must be written when RTC is stopped.



## 7.28.10.25 CC[n] (n=0..3)

Address offset:  $0x540 + (n \times 0x4)$ 

Compare register n



# 7.28.11 Electrical specification

# 7.29 SAADC — Successive approximation analog-to-digital converter

SAADC is a differential successive approximation register (SAR) analog-to-digital converter (ADC).

The main features of SAADC are the following:

- 8/10/12-bit resolution, 14-bit resolution with oversampling
- Multiple analog inputs:
  - AINO to AIN7 pins
  - VDD pin
  - VDDHDIV5 (through **VDDH** pin)
- Up to eight input channels:
  - One channel per single-ended input and two channels per differential input
  - · Scan mode can be configured with both single-ended channels and differential channels
  - Each channel can be configured to select any of the above analog inputs
- Full scale input range (0 to VDD)
- Sampling triggered via a task from software or a PPI channel for full flexibility on sample frequency source from a low-power 32.768 kHz RTC or more accurate 1/16 MHz timers



- One-shot conversion mode to sample a single channel
- Scan mode to sample a series of channels in sequence with configurable sample delay
- Support for direct sample transfer to RAM using EasyDMA
- Interrupts on single sample and full buffer events
- Samples stored as 16-bit two's complement values for differential and single-ended sampling
- · Continuous sampling without the need of an external timer
- Internal resistor string
- · On-the-fly limit checking

#### 7.29.1 Shared resources

The ADC can coexist with COMP and other peripherals using one of **AINO-AIN7**, provided these are assigned to different pins.

It is not recommended to select the same analog input pin for both modules.

#### 7.29.2 Overview

The ADC supports up to eight external analog input channels. It can be operated in One-shot mode with sampling under software control, or Continuous mode with a programmable sampling rate.

The analog inputs can be configured as eight single-ended inputs, four differential inputs, or a combination of these. Each channel can be configured to select one of the following:

- AINO to AIN7 pins
- VDD pin
- VDDHDIV5 (through VDDH pin)

Channels can be sampled individually in One-shot or Continuous sampling modes. Using Scan mode, multiple channels can be sampled in sequence. Channels can also be oversampled to improve noise performance.



Figure 190: Simplified ADC block diagram

Internally, the ADC is always a differential analog-to-digital converter, but by default it is configured with single-ended input SE in the MODE field of the CH[n].CONFIG register. In Single-ended (SE) mode, the negative input will be shorted to ground internally.

In Single-ended mode, the assumption is that the internal ground of the ADC is the same as the external ground that the measured voltage is referred to. The ADC is thus sensitive to ground bounce on the PCB.



This can be reduced by configuring SAADC to use differential measurent setting the MODE field of the CH[n].CONFIG register to Diff (differential).

# 7.29.3 Digital output

The output result of the ADC depends on the settings in the CH[n].CONFIG and RESOLUTION registers as shown in the following equation.

```
RESULT = [V(P) - V(N)] * GAIN/REFERENCE * 2 (RESOLUTION - m)
```

| Variable  | Description                                                          |
|-----------|----------------------------------------------------------------------|
| V(P)      | Voltage at input P                                                   |
| V(N)      | Voltage at input N                                                   |
| GAIN      | Selected gain setting                                                |
| m         | Mode setting (Use m=0 if CONFIG.MODE=SE, or m=1 if CONFIG.MODE=Diff) |
| REFERENCE | Selected reference voltage                                           |

Table 139: Equation variables

The result generated by the ADC will deviate from the expected due DC errors like offset, gain, differential non-linearity (DNL), and integral non-linearity (INL). See Electrical specification for details on these parameters. The result can also vary due to AC errors like non-linearities in the GAIN block, settling errors due to high source impedance and sampling jitter. For battery measurement, the DC errors are most noticeable.

The ADC has a wide selection of gains controlled in the GAIN field of the CH[n].CONFIG register. If CH[n].CONFIG.REFSEL=0, the input range of the ADC core is nominally ±0.6 V differential, and the input must be scaled accordingly.

The ADC has a temperature dependent offset. If the ADC is to operate over a large temperature range, it is recommended to run CALIBRATEOFFSET at regular intervals. The CALIBRATEDONE, DONE, and RESULTDONE events will be generated when the calibration has completed.

# 7.29.4 Analog inputs and channels

Up to eight analog input channels, CH[n](n=0..7), can be configured.

See Shared resources on page 526 for shared input with comparators.

Any of the available channels can be enabled for the ADC to operate in One-shot mode. If more than one CH[n] is configured, the ADC enters Scan mode.

An analog input is selected as a positive converter input if CH[n].PSELP is set, setting CH[n].PSELP also enables the particular channel.

An analog input is selected as a negative converter input if CH[n].PSELN is set. The CH[n].PSELN register will have no effect unless Differential mode is enabled, see MODE field in the CH[n].CONFIG register.

If more than one of the CH[n].PSELP registers is set, the device enters Scan mode. Input selections in Scan mode are controlled by the CH[n].PSELP and CH[n].PSELN registers, where CH[n].PSELN is only used if the particular scan channel is specified as differential, see MODE field in the CH[n].CONFIG register.

**Note:** Channels selected for COMP cannot be used at the same time for ADC sampling, though channels not selected for use by these blocks can be used by the ADC.



# 7.29.5 Operation modes

The ADC input configuration supports One-shot mode, Continuous mode, and Scan mode.

The ADC indicates a single ongoing conversion via the register STATUS on page 546. During Scan mode, oversampling, or Continuous modes, more than a single conversion take place in the ADC. As a consequence, the value reflected in the STATUS register will toggle at the end of each single conversion.

Note: Scan mode and oversampling cannot be combined.

#### 7.29.5.1 One-shot mode

One-shot operation is configured by enabling only one of the available channels defined by the CH[n].PSELP, CH[n].PSELN, and CH[n].CONFIG registers.

Once a SAMPLE task is triggered, the ADC starts to sample the input voltage. The CH[n].CONFIG.TACQ controls the acquisition time.

A DONE event signals that one sample has been taken.

In this mode, the RESULTDONE event has the same meaning as DONE when no oversampling takes place. Both events may occur before the actual value has been transferred into RAM by EasyDMA. For more information, see EasyDMA on page 529.

#### 7.29.5.2 Continuous mode

Continuous sampling can be achieved by using the internal timer in the ADC, or triggering the SAMPLE task from one of the general purpose timers through the PPI system.

Care shall be taken to ensure that the sample rate fulfills the following criteria, depending on how many channels are active.

```
f_{SAMFLE} < 1/(t_{ACQ} + t_{conv})
```

The SAMPLERATE register can be used as a local timer instead of triggering individual SAMPLE tasks. When SAMPLERATE.MODE is set to Timers, it is sufficient to trigger SAMPLE task only once in order to start the SAADC and triggering the STOP task will stop sampling. The SAMPLERATE.CC field controls the sample rate.

The SAMPLERATE timer mode cannot be combined with Scan mode, and only one channel can be enabled in this mode.

A DONE event signals that one sample has been taken.

In this mode, the RESULTDONE event has the same meaning as DONE when no oversampling takes place. Both events may occur before the actual value has been transferred into RAM by EasyDMA.

#### 7.29.5.3 Oversampling

An accumulator in the ADC can be used to average noise on the analog input. In general, oversampling improves the signal-to-noise ratio (SNR). Oversampling, however, does not improve the integral non-linearity (INL), or differential non-linearity (DNL).

Oversampling and Scan mode should not be combined, since oversampling and scan will average over input channels.

The accumulator is controlled in the OVERSAMPLE register. The SAMPLE task must be set 2<sup>OVERSAMPLE</sup> number of times before the result is written to RAM. This can be achieved by the following:

- Configuring a fixed sampling rate using the local timer or a general purpose timer and the PPI system to trigger a SAMPLE task
- Triggering SAMPLE 2<sup>OVERSAMPLE</sup> times from software
- Enabling BURST mode



CH[n].CONFIG.BURST can be enabled to avoid setting SAMPLE task  $2^{\text{OVERSAMPLE}}$  times. With BURST = 1 the ADC will sample the input  $2^{\text{OVERSAMPLE}}$  times as fast as it can (actual timing:  $<(t_{ACQ}+t_{CONV})\times 2^{\text{OVERSAMPLE}}$ ). Thus, for the user it will just appear like the conversion took a bit longer time, but other than that, it is similar to One-shot mode.

A DONE event signals that one sample has been taken.

In this mode, the RESULTDONE event signals that enough conversions have taken place for an oversampled result to get transferred into RAM. Both events may occur before the actual value has been transferred into RAM by EasyDMA.

#### 7.29.5.4 Scan mode

A channel is considered enabled if CH[n].PSELP is set. If more than one channel, CH[n], is enabled, the ADC enters Scan mode.

In Scan mode, one SAMPLE task will trigger one conversion per enabled channel. The time it takes to sample all channels is given by the following equation:

```
Total time < Sum(CH[x].t_{ACQ}+t_{CONV}), x=0..enabled channels
```

A DONE event signals that one sample has been taken.

In this mode, the RESULTDONE event signals has the same meaning as DONE when no oversampling takes place. Both events may occur before the actual values have been transferred into RAM by EasyDMA.

The following figure shows an example of the placement of results in Data RAM, with an even RESULT.MAXCNT. In this example, channels 1, 2, and 5 are enabled, all others are disabled.

|                                    | 31 16                        | 15 0                         |
|------------------------------------|------------------------------|------------------------------|
| RESULT.PTR                         | CH[2] 1 <sup>st</sup> result | CH[1] 1 <sup>st</sup> result |
| RESULT.PTR + 4                     | CH[1] 2 <sup>nd</sup> result | CH[5] 1 <sup>st</sup> result |
| RESULT.PTR + 8                     | CH[5] 2 <sup>nd</sup> result | CH[2] 2 <sup>nd</sup> result |
|                                    | (                            | )                            |
| RESULT.PTR + 2*(RESULT.MAXCNT – 2) | CH[5] last result            | CH[2] last result            |

Figure 191: Example of RAM placement (even RESULT.MAXCNT), channels 1, 2 and, 5 enabled

The following figure shows an example of the placement of results in Data RAM, with an odd RESULT.MAXCNT. In this example, channels 1, 2 and, 5 are enabled, all others are disabled. The last 32-bit word is populated only with one 16-bit result.

|                                       | 31 16                        | 15 0                         |
|---------------------------------------|------------------------------|------------------------------|
| RESULT.PTR                            | CH[2] 1 <sup>st</sup> result | CH[1] 1 <sup>st</sup> result |
| RESULT.PTR + 4                        | CH[1] 2 <sup>nd</sup> result | CH[5] 1 <sup>st</sup> result |
| RESULT.PTR + 8                        | CH[5] 2 <sup>nd</sup> result | CH[2] 2 <sup>nd</sup> result |
|                                       | (                            | )                            |
| RESULT.PTR +<br>2*(RESULT.MAXCNT – 1) |                              | CH[5] last result            |

Figure 192: Example of RAM placement (odd RESULT.MAXCNT), channels 1, 2 and, 5 enabled

# 7.29.6 EasyDMA

After configuring RESULT.PTR and RESULT.MAXCNT, the ADC resources are started by triggering the START task. The ADC is using EasyDMA to store results in a Result buffer in RAM.



The Result buffer is located at the address specified in the RESULT.PTR register. The RESULT.PTR register is double-buffered and it can be updated and prepared for the next START task immediately after the STARTED event is generated. The size of the Result buffer is specified in the RESULT.MAXCNT register and the ADC will generate an END event when it has filled up the Result buffer, see ADC on page 530. Results are stored in little-endian byte order in Data RAM. Every sample will be sign extended to 16 bit before stored in the Result buffer.

The ADC is stopped by triggering the STOP task. The STOP task will terminate an ongoing sampling. The ADC will generate a STOPPED event when it has stopped. If the ADC is already stopped when the STOP task is triggered, the STOPPED event will still be generated.



Figure 193: ADC

If the RESULT.PTR is not pointing to a RAM region accessible from the peripheral, an EasyDMA transfer may result in a HardFault and/or memory corruption. See Memory on page 19 for more information about the different memory regions.

The EasyDMA will have finished accessing the RAM when the END or STOPPED event has been generated.

The RESULT.AMOUNT register can be read following an END event or a STOPPED event to see how many results have been transferred to the Result buffer in RAM since the START task was triggered.

In Scan mode, SAMPLE tasks can be triggered once the START task is triggered. The END event is generated when the number of samples transferred to memory reaches the value specified by RESULT.MAXCNT. After an END event, the START task needs to be triggered again before new samples can be taken. By specifying RESULT.MAXCNT ≥ number of channels enabled, the size of the Result buffer should be large enough for a minimum of one result from each of the enabled channels. See Scan mode on page 529 for more information.

#### 7.29.7 Resistor ladder

The ADC has an internal resistor string for positive and negative input.

The resistors in the following figure are controlled in the CH[n].CONFIG.RESP and CH[n].CONFIG.RESN registers.





Figure 194: Resistor ladder for positive input

## 7.29.8 Reference

The ADC can use the following two references, controlled in the REFSEL field of the CH[n].CONFIG register.

- Internal reference
- VDD as reference

The internal reference results in an input range of  $\pm 0.6$  V on the ADC core. VDD as reference results in an input range of  $\pm VDD/4$  on the ADC core. The gain block can be used to change the effective input range of the ADC.

```
Input range = (+- 0.6 V or +-VDD/4)/Gain
```

For example, choosing VDD as reference, single ended input (grounded negative input), and a gain of 1/4 the input range is the following:

```
Input range = (VDD/4)/(1/4) = VDD
```

With internal reference, single ended input (grounded negative input), and a gain of 1/6 the input range is the following:

```
Input range = (0.6 \text{ V})/(1/6) = 3.6 \text{ V}
```

The **AIN0** - **AIN7** inputs cannot exceed VDD, or be lower than VSS.

# 7.29.9 Acquisition time

To sample the input voltage, the ADC connects a capacitor to the input.

The acquisition time indicates how long the capacitor is connected, see TACQ field in register CH[n].CONFIG (n=0..7) on page 547. The required acquisition time depends on the source ( $R_{source}$ ) resistance. For high source resistance, the acquisition time should be increased. See the following table for more information.





Figure 195: Simplified ADC sample network

| TACQ [µs] | Maximum source resistance [kOhm] |
|-----------|----------------------------------|
| 3         | 10                               |
| 5         | 40                               |
| 10        | 100                              |
| 15        | 200                              |
| 20        | 400                              |
| 40        | 800                              |

Table 140: Acquisition time

When using **VDDHDIV5** as input, the acquisition time needs to be 10  $\mu s$  or higher.

# 7.29.10 Limits event monitoring

A channel can be event monitored by configuring limit register CH[n].LIMIT.

If the conversion result is higher than the defined high limit, or lower than the defined low limit, the appropriate event will get fired.



Figure 196: Example of limits monitoring on channel 'n'



The CH[n].LIMIT.HIGH shall always be higher than or equal to CH[n].LIMIT.LOW . In other words, an event can be generated only when the input signal has been sampled outside of the defined limits. It is not possible to generate an event when the input signal is inside a defined range by swapping high and low limits.

The comparison to limits always takes place, there is no need to enable it. If comparison is not required on a channel, the software shall simply ignore the related events. In that situation, the value of the limits registers is irrelevant, so it does not matter if CH[n].LIMIT.LOW is lower than CH[n].LIMIT.HIGH or not.

# 7.29.11 Registers

| Base address Domain | Peripheral             | Instance  | Secure mapping | DMA security | Description                 | Configuration |
|---------------------|------------------------|-----------|----------------|--------------|-----------------------------|---------------|
| 0x5000E000          | IN CAADC               | SAADC : S | LIC            | 5.4          | Successive approximation    |               |
| 0x4000E000          | APPLICATION SAADC<br>0 |           | 03             | SA           | analog-to-digital converter |               |

Table 141: Instances

| Register                  | Offset | Security | Description                                                                       |
|---------------------------|--------|----------|-----------------------------------------------------------------------------------|
| TASKS_START               | 0x000  |          | Start the ADC and prepare the result buffer in RAM                                |
| TASKS_SAMPLE              | 0x004  |          | Take one ADC sample, if scan is enabled all channels are sampled                  |
| TASKS_STOP                | 0x008  |          | Stop the ADC and terminate any ongoing conversion                                 |
| TASKS_CALIBRATEOFFSET     | 0x00C  |          | Starts offset auto-calibration                                                    |
| SUBSCRIBE_START           | 0x080  |          | Subscribe configuration for task START                                            |
| SUBSCRIBE_SAMPLE          | 0x084  |          | Subscribe configuration for task SAMPLE                                           |
| SUBSCRIBE_STOP            | 0x088  |          | Subscribe configuration for task STOP                                             |
| SUBSCRIBE_CALIBRATEOFFSET | 0x08C  |          | Subscribe configuration for task CALIBRATEOFFSET                                  |
| EVENTS_STARTED            | 0x100  |          | The ADC has started                                                               |
| EVENTS_END                | 0x104  |          | The ADC has filled up the Result buffer                                           |
| EVENTS_DONE               | 0x108  |          | A conversion task has been completed. Depending on the mode, multiple conversions |
|                           |        |          | might be needed for a result to be transferred to RAM.                            |
| EVENTS_RESULTDONE         | 0x10C  |          | A result is ready to get transferred to RAM                                       |
| EVENTS_CALIBRATEDONE      | 0x110  |          | Calibration is complete                                                           |
| EVENTS_STOPPED            | 0x114  |          | The ADC has stopped                                                               |
| EVENTS_CH[n].LIMITH       | 0x118  |          | Last results is equal or above CH[n].LIMIT.HIGH                                   |
| EVENTS_CH[n].LIMITL       | 0x11C  |          | Last results is equal or below CH[n].LIMIT.LOW                                    |
| PUBLISH_STARTED           | 0x180  |          | Publish configuration for event STARTED                                           |
| PUBLISH_END               | 0x184  |          | Publish configuration for event END                                               |
| PUBLISH_DONE              | 0x188  |          | Publish configuration for event DONE                                              |
| PUBLISH_RESULTDONE        | 0x18C  |          | Publish configuration for event RESULTDONE                                        |
| PUBLISH_CALIBRATEDONE     | 0x190  |          | Publish configuration for event CALIBRATEDONE                                     |
| PUBLISH_STOPPED           | 0x194  |          | Publish configuration for event STOPPED                                           |
| PUBLISH_CH[n].LIMITH      | 0x198  |          | Publish configuration for event CH[n].LIMITH                                      |
| PUBLISH_CH[n].LIMITL      | 0x19C  |          | Publish configuration for event CH[n].LIMITL                                      |
| INTEN                     | 0x300  |          | Enable or disable interrupt                                                       |
| INTENSET                  | 0x304  |          | Enable interrupt                                                                  |
| INTENCLR                  | 0x308  |          | Disable interrupt                                                                 |
| STATUS                    | 0x400  |          | Status                                                                            |
| ENABLE                    | 0x500  |          | Enable or disable ADC                                                             |
| CH[n].PSELP               | 0x510  |          | Input positive pin selection for CH[n]                                            |
| CH[n].PSELN               | 0x514  |          | Input negative pin selection for CH[n]                                            |
| CH[n].CONFIG              | 0x518  |          | Input configuration for CH[n]                                                     |
| CH[n].LIMIT               | 0x51C  |          | High/low limits for event monitoring a channel                                    |
| RESOLUTION                | 0x5F0  |          | Resolution configuration                                                          |
|                           |        |          |                                                                                   |



| Register      | Offset | Security | Description                                                                   |
|---------------|--------|----------|-------------------------------------------------------------------------------|
| OVERSAMPLE    | 0x5F4  |          | Oversampling configuration. OVERSAMPLE should not be combined with SCAN.      |
|               |        |          | The RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher |
|               |        |          | RESOLUTION should be used.                                                    |
| SAMPLERATE    | 0x5F8  |          | Controls normal or continuous sample rate                                     |
| RESULT.PTR    | 0x62C  |          | Data pointer                                                                  |
| RESULT.MAXCNT | 0x630  |          | Maximum number of buffer words to transfer                                    |
| RESULT.AMOUNT | 0x634  |          | Number of buffer words transferred since last START                           |

Table 142: Register overview

## 7.29.11.1 TASKS\_START

Address offset: 0x000

Start the ADC and prepare the result buffer in RAM

| Bit number |                  |             |         | 31 30 29 28 27 26 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|------------|------------------|-------------|---------|-------------------|---------------------------------------------------------------------------------------|--|--|--|
| ID         |                  |             |         |                   | A                                                                                     |  |  |  |
| Rese       | Reset 0x00000000 |             |         | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |  |  |  |
| ID         |                  |             |         |                   |                                                                                       |  |  |  |
| Α          | W                | TASKS_START |         |                   | Start the ADC and prepare the result buffer in RAM                                    |  |  |  |
|            |                  |             | Trigger | 1                 | Trigger task                                                                          |  |  |  |

# 7.29.11.2 TASKS\_SAMPLE

Address offset: 0x004

Take one ADC sample, if scan is enabled all channels are sampled



## 7.29.11.3 TASKS STOP

Address offset: 0x008

Stop the ADC and terminate any ongoing conversion

| Bit r | Bit number       |            |         | 31 30 29 28 27 2 | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------|------------------|------------|---------|------------------|---------------------------------------------------------------------------------------|--|--|--|
| ID    | ID               |            |         |                  | A                                                                                     |  |  |  |
| Res   | Reset 0x00000000 |            |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                               |  |  |  |
| ID    |                  |            |         |                  | Description                                                                           |  |  |  |
| Α     | W                | TASKS_STOP |         |                  | Stop the ADC and terminate any ongoing conversion                                     |  |  |  |
|       |                  |            | Trigger | 1                | Trigger task                                                                          |  |  |  |

## 7.29.11.4 TASKS\_CALIBRATEOFFSET

Address offset: 0x00C

Starts offset auto-calibration





#### Do not trigger when the ADC has been started



## 7.29.11.5 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



## 7.29.11.6 SUBSCRIBE\_SAMPLE

Address offset: 0x084

Subscribe configuration for task SAMPLE



## 7.29.11.7 SUBSCRIBE STOP

Address offset: 0x088

Subscribe configuration for task STOP





## 7.29.11.8 SUBSCRIBE\_CALIBRATEOFFSET

Address offset: 0x08C

Subscribe configuration for task CALIBRATEOFFSET

Do not trigger when the ADC has been started



## **7.29.11.9 EVENTS STARTED**

Address offset: 0x100 The ADC has started



## 7.29.11.10 EVENTS\_END

Address offset: 0x104

The ADC has filled up the Result buffer



## 7.29.11.11 EVENTS\_DONE

Address offset: 0x108

A conversion task has been completed. Depending on the mode, multiple conversions might be needed for a result to be transferred to RAM.



| Bit n | Bit number       |             |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|-------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    | ID               |             |              |                         | A                                                               |
| Rese  | Reset 0x00000000 |             |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                  |             |              |                         |                                                                 |
| Α     | RW               | EVENTS_DONE |              |                         | A conversion task has been completed. Depending on the          |
|       |                  |             |              |                         | mode, multiple conversions might be needed for a result to      |
|       |                  |             |              |                         | be transferred to RAM.                                          |
|       |                  |             | NotGenerated | 0                       | Event not generated                                             |
|       |                  |             | Generated    | 1                       | Event generated                                                 |

## 7.29.11.12 EVENTS\_RESULTDONE

Address offset: 0x10C

A result is ready to get transferred to RAM



## 7.29.11.13 EVENTS\_CALIBRATEDONE

Address offset: 0x110
Calibration is complete



## 7.29.11.14 EVENTS STOPPED

Address offset: 0x114
The ADC has stopped



# 7.29.11.15 EVENTS\_CH[n].LIMITH (n=0..7)

Address offset:  $0x118 + (n \times 0x8)$ 



## Last results is equal or above CH[n].LIMIT.HIGH



## 7.29.11.16 EVENTS CH[n].LIMITL (n=0..7)

Address offset: 0x11C + (n × 0x8)

Last results is equal or below CH[n].LIMIT.LOW



## 7.29.11.17 PUBLISH STARTED

Address offset: 0x180

Publish configuration for event STARTED



## 7.29.11.18 PUBLISH END

Address offset: 0x184

Publish configuration for event END







# 7.29.11.19 PUBLISH\_DONE

Address offset: 0x188

Publish configuration for event DONE



# 7.29.11.20 PUBLISH\_RESULTDONE

Address offset: 0x18C

Publish configuration for event RESULTDONE



## 7.29.11.21 PUBLISH CALIBRATEDONE

Address offset: 0x190

Publish configuration for event CALIBRATEDONE



## 7.29.11.22 PUBLISH\_STOPPED

Address offset: 0x194

Publish configuration for event STOPPED





# 7.29.11.23 PUBLISH\_CH[n].LIMITH (n=0..7)

Address offset:  $0x198 + (n \times 0x8)$ 

Publish configuration for event CH[n].LIMITH

| Bit number |                  |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------|------------------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID         |                  |       |          | В                       | A A A A A A A                                                   |
| Rese       | Reset 0x00000000 |       |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID         |                  |       |          |                         |                                                                 |
| Α          | RW               | CHIDX |          | [2550]                  | DPPI channel that event CH[n].LIMITH will publish to.           |
| В          | RW               | EN    |          |                         |                                                                 |
|            |                  |       | Disabled | 0                       | Disable publishing                                              |
|            |                  |       | Enabled  | 1                       | Enable publishing                                               |

# 7.29.11.24 PUBLISH\_CH[n].LIMITL (n=0..7)

Address offset:  $0x19C + (n \times 0x8)$ 

Publish configuration for event CH[n].LIMITL

| Bit n | umber            |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |                  |       |          | В                       | A A A A A A A                                                   |
| Rese  | Reset 0x00000000 |       |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                  |       |          |                         | Description                                                     |
| Α     | RW               | CHIDX |          | [2550]                  | DPPI channel that event CH[n].LIMITL will publish to.           |
| В     | RW               | EN    |          |                         |                                                                 |
|       |                  |       | Disabled | 0                       | Disable publishing                                              |
|       |                  |       | Enabled  | 1                       | Enable publishing                                               |

## 7.29.11.25 INTEN

Address offset: 0x300

Enable or disable interrupt







| Bit r | umber    |               |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|----------------------|------------------------------------------------------------------|
| ID    |          |               |          |                      | V U T S R Q P O N M L K J I H G F E D C B A                      |
| Res   | et 0x000 | 00000         |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |          |               |          |                      |                                                                  |
| С     | RW       | DONE          |          |                      | Enable or disable interrupt for event DONE                       |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| D     | RW       | RESULTDONE    |          |                      | Enable or disable interrupt for event RESULTDONE                 |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| E     | RW       | CALIBRATEDONE |          |                      | Enable or disable interrupt for event CALIBRATEDONE              |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| F     | RW       | STOPPED       |          |                      | Enable or disable interrupt for event STOPPED                    |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| G     | RW       | CHOLIMITH     |          |                      | Enable or disable interrupt for event CHOLIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| Н     | RW       | CHOLIMITL     |          |                      | Enable or disable interrupt for event CHOLIMITL                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| 1     | RW       | CH1LIMITH     |          |                      | Enable or disable interrupt for event CH1LIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| J     | RW       | CH1LIMITL     |          |                      | Enable or disable interrupt for event CH1LIMITL                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| K     | RW       | CH2LIMITH     |          |                      | Enable or disable interrupt for event CH2LIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| L     | RW       | CH2LIMITL     |          |                      | Enable or disable interrupt for event CH2LIMITL                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| М     | RW       | CH3LIMITH     |          |                      | Enable or disable interrupt for event CH3LIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
|       |          |               | Enabled  | 1                    | Enable                                                           |
| N     | RW       | CH3LIMITL     |          |                      | Enable or disable interrupt for event CH3LIMITL                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
| _     |          |               | Enabled  | 1                    | Enable                                                           |
| 0     | RW       | CH4LIMITH     |          | _                    | Enable or disable interrupt for event CH4LIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
| _     |          |               | Enabled  | 1                    | Enable                                                           |
| Р     | RW       | CH4LIMITL     | 5        |                      | Enable or disable interrupt for event CH4LIMITL                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
| 0     | DV4      | CHELINATU     | Enabled  | 1                    | Enable  Enable or disable interrupt for event CHELIMITH          |
| Q     | RW       | CH5LIMITH     | Disabled | 0                    | Enable or disable interrupt for event CH5LIMITH                  |
|       |          |               | Disabled | 0                    | Disable                                                          |
| P     | RW       | CHELINATI     | Enabled  | 1                    | Enable  Feable or disable interrupt for event CHSLIMITI          |
| R     | IV VV    | CH5LIMITL     | Disabled | 0                    | Enable or disable interrupt for event CH5LIMITL  Disable         |
|       |          |               |          |                      | Enable                                                           |
| ç     | D/V      | CH6LIMITH     | Enabled  | 1                    |                                                                  |
| S     | RW       | CHOLIMITH     | Disabled | 0                    | Enable or disable interrupt for event CH6LIMITH                  |
|       |          |               | Disabled | U                    | Disable                                                          |





| Bit n | umber   |           |          | 31 30 29 28 2 | 7 26 25 24 | 4 23 22 21 | 1 20 19 | 18 1   | 7 16 1 | .5 14 | 13 1  | 2 11 | 10 9  | 8    | 7 | 6 ! | 5 4 | 3 | 2 | 1 0 |
|-------|---------|-----------|----------|---------------|------------|------------|---------|--------|--------|-------|-------|------|-------|------|---|-----|-----|---|---|-----|
| ID    |         |           |          |               |            | ٧          | ′ U T   | S F    | QI     | РО    | N N   | ИL   | K J   | -1   | Н | G I | E   | D | С | ВА  |
| Rese  | t 0x000 | 00000     |          | 0 0 0 0 0     | 0 0 0      | 0 0 0      | 0 0     | 0 (    | 0 (    | 0 0   | 0 (   | 0 0  | 0 0   | 0    | 0 | 0 ( | 0 0 | 0 | 0 | 0 0 |
| ID    |         |           |          |               |            |            |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1             |            | Enable     |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
| Т     | RW      | CH6LIMITL |          |               |            | Enable     | or disa | ble in | terru  | pt fo | r eve | nt C | H6LIN | ИITL |   |     |     |   |   |     |
|       |         |           | Disabled | 0             |            | Disable    |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1             |            | Enable     |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
| U     | RW      | CH7LIMITH |          |               |            | Enable     | or disa | ble in | terru  | pt fo | r eve | nt C | H7LIN | ИITH | 1 |     |     |   |   |     |
|       |         |           | Disabled | 0             |            | Disable    |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1             |            | Enable     |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
| ٧     | RW      | CH7LIMITL |          |               |            | Enable     | or disa | ble in | terru  | pt fo | r eve | nt C | H7LIN | ЛITL |   |     |     |   |   |     |
|       |         |           | Disabled | 0             |            | Disable    |         |        |        |       |       |      |       |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1             |            | Enable     |         |        |        |       |       |      |       |      |   |     |     |   |   |     |

## 7.29.11.26 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber    |               |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|------------------------|------------------------------------------------------------------|
| ID    |          |               |          |                        | V U T S R Q P O N M L K J I H G F E D C B A                      |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |          |               |          |                        | Description                                                      |
| Α     | RW       | STARTED       |          |                        | Write '1' to enable interrupt for event STARTED                  |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| В     | RW       | END           |          |                        | Write '1' to enable interrupt for event END                      |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| С     | RW       | DONE          |          |                        | Write '1' to enable interrupt for event DONE                     |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| D     | RW       | RESULTDONE    |          |                        | Write '1' to enable interrupt for event RESULTDONE               |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| E     | RW       | CALIBRATEDONE |          |                        | Write '1' to enable interrupt for event CALIBRATEDONE            |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| F     | RW       | STOPPED       |          |                        | Write '1' to enable interrupt for event STOPPED                  |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| G     | RW       | CHOLIMITH     |          |                        | Write '1' to enable interrupt for event CH0LIMITH                |
|       |          |               | Set      | 1                      | Enable                                                           |
|       |          |               | Disabled | 0                      | Read: Disabled                                                   |
|       |          |               | Enabled  | 1                      | Read: Enabled                                                    |
| Н     | RW       | CHOLIMITL     |          |                        | Write '1' to enable interrupt for event CHOLIMITL                |
|       |          |               |          |                        |                                                                  |





| Note      | Bit n | umber   |           |          | 31 30 29 28 27 26 25 24 | 1 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| Note      |       |         |           |          |                         |                                                                 |
| No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | + 0~000 | 00000     |          | 0 0 0 0 0 0 0           |                                                                 |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           |          |                         |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | וט    | 11/ VV  | rielu     |          |                         |                                                                 |
| RW   CHILIMITH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |           |          |                         |                                                                 |
| RW   CHILIMITH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |           |          |                         |                                                                 |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       | RW/     | CH1LIMITH | Eliablea | -                       |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | 11.00   | CHILINATH | Set      | 1                       |                                                                 |
| Finable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |         |           |          |                         |                                                                 |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           |          |                         |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | J     | RW      | CH1LIMITL | 2.100.00 | -                       |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |         |           | Set      | 1                       |                                                                 |
| Read: Enabled   No.   Read: Enabled   No.   Read: Enabled   No.    |       |         |           |          |                         | Read: Disabled                                                  |
| K         RW         CH2LIMITH         Set         1         Enable         Enable           L         Read Disabled         0         Read: Disabled         1         Read: Disabled           L         RW         CH2LIMITL         Write "1" to enable interrupt for event CH2LIMITL         1         Read: Disabled           L         RW         CH3LIMITH         Set         1         Read: Disabled           M         RW         CH3LIMITH         Write "1" to enable interrupt for event CH3LIMITH         Finable           M         RW         CH3LIMITH         Set         1         Enabled           M         RW         CH3LIMITH         Write "1" to enable interrupt for event CH3LIMITH         Finable           M         RW         CH3LIMITL         Write "1" to enable interrupt for event CH3LIMITH         Finable           M         RW         CH4LIMITH         Write "1" to enable interrupt for event CH4LIMITH         Finable           M         RW         CH4LIMITH         Write "1" to enable interrupt for event CH4LIMITH         Finable           Disabled         1         Read: Disabled         Finable           P         RW         CH4LIMITH         Set         1         Enable           P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |           | Enabled  |                         | Read: Enabled                                                   |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | K     | RW      | CH2LIMITH |          |                         |                                                                 |
| Read      |       |         |           | Set      | 1                       |                                                                 |
| L RW CH2UMITL Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | L     | RW      | CH2LIMITL |          |                         | Write '1' to enable interrupt for event CH2LIMITL               |
| Read      |       |         |           | Set      | 1                       | Enable                                                          |
| M RW CH3LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enable 1 Read: Enabled  N RW CH3LIMITL  Set 1 Enable Disabled 1 Read: Enabled  N RW CH3LIMITL  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH3LIMITL  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH4LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH4LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH4LIMITL  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITH  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITL  Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  Read: Enabled  Read: Disabled Enabled 1 Read: Enabled  Read: Disabled 1 Read: Enabled  Read: D |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | M     | RW      | CH3LIMITH |          |                         | Write '1' to enable interrupt for event CH3LIMITH               |
| Read: Enabled   Final Price    |       |         |           | Set      | 1                       | Enable                                                          |
| N         RW         CH3LIMITL         Set         1         Enable           O         RW         CH4LIMITL         Set         1         Enable           O         RW         CH4LIMITH         Set         1         Read: Disabled           O         RW         CH4LIMITH         Set         1         Enable           O         RW         CH4LIMITH         Set         1         Enable           P         RW         CH4LIMITL         Set         1         Enable           P         RW         CH5LIMITH         Write '1' to enable interrupt for event CH5LIMITH         Enable           P         RW         CH5LIMITL         Set         1         Enable           P         RW         CH5LIMITL         Set         1         Enable           P         RW         CH5LIMITL         Set         1         Enable           P         RW         CH6LIMITL <td></td> <td></td> <td></td> <td>Disabled</td> <td>0</td> <td>Read: Disabled</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| Disabled    | N     | RW      | CH3LIMITL |          |                         | Write '1' to enable interrupt for event CH3LIMITL               |
| Read: Enabled  Characteristic Charac |       |         |           | Set      | 1                       | Enable                                                          |
| O RW CH4LIMITH  Set 1 Enable  CH4LIMITH  Set 1 Enable  CH4LIMITL  Set 1 Enable  CH4LIMITL  Set 1 Enable  CH4LIMITL  Set 1 Enable  CH4LIMITL  Set 1 Enable  CH5LIMITH  Set 1 Enable  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  CH6LIMITH  Set 1 To enable interrupt for event CH6LIMITH  CH6LIMITH  CH6LIMITH  CH6LIMITH  CH6LIMITH  CH6LIMITH  CH6LIMITH  CH6 |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH4LIMITL Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITL Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  Q RW CH5LIMITH Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  R RW CH5LIMITH Set 1 Enable Disabled 1 Read: Enabled  R RW CH5LIMITL Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  R RW CH5LIMITL Set 1 Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled  S RW CH6LIMITH Set 1 Enable Disabled 1 Read: Enabled  S RW CH6LIMITH Set 1 Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled  S RW CH6LIMITH Set 1 Enable Disabled 0 Read: Disabled Enable Disabled 0 Read: Disabled Enable Disabled 1 Read: Enabled  T RW CH6LIMITL Set 1 Enable Disabled 1 Read: Enabled  T RW CH6LIMITL Set 1 Write '1' to enable interrupt for event CH6LIMITL Set 1 Read: Enabled  T RW CH6LIMITL Set 1 Write '1' to enable interrupt for event CH6LIMITL Set 1 Write '1' to enable interrupt for event CH6LIMITL Set 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| P RW CHALIMITL Set 1 Cenabled 0 Read: Disabled  P RW CHALIMITL Set 1 Cenable  CO Read: Enabled  CO Read: Disabled  CO Read: Dis | 0     | RW      | CH4LIMITH |          |                         | Write '1' to enable interrupt for event CH4LIMITH               |
| P RW CHALIMITL Set 1 CHALIMITL Set 1 CHALIMITL  P RW CHALIMITL Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITL  Set 1 CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Set 1 CHALIMITH  Set 1 CHALIMITH  Set 2 CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Set 1 CHALIMITH  Set 2 CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Write '1' to enable interrupt for event CHALIMITH  Write '1' to enable interrup |       |         |           | Set      | 1                       | Enable                                                          |
| P RW CHALIMITL  Set 1 Enable Disabled 0 Read: Disabled Enabled  C Read: Disabled  C Read: Disabled  C Read: Enabled  C Read: Enabled  C Read: Disabled  C Read: Enabled  C Read: Disabled  C Read: Disabled  C Read: Enabled  C Read: Disabled  C Read: Enabled  C Read: Enabled  C Read: Enabled  C Read: Disabled  C Read: Disabl |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set 1 Disabled 0 Read: Disabled 0 Read: Disabled 0 Read: Disabled 0 Read: Enabled 0 Read: Disabled 0 Read: Enabled 0 Read: Disabled 0 Read: Enabled 0 Read: Disabled 0 Read: Enabled 0 Read: En |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| RW CHSLIMITH  Set 1 Enabled 0 Read: Disabled  OR RW CHSLIMITH  Set 1 Enabled  OR Read: Enabled  OR Read: Enabled  OR Read: Enabled  OR Read: Disabled  OR Read: Disabled  OR Read: Disabled  OR Read: Disabled  OR Read: Enabled  OR Read: Enabled  OR Read: Enabled  OR Read: Enabled  OR Read: Disabled  OR Read: Enabled  OR Read: Enabled  OR Read: Disabled  OR Read: Enabled  OR Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Р     | RW      | CH4LIMITL |          |                         | Write '1' to enable interrupt for event CH4LIMITL               |
| R W CHSLIMITH Set 1 Read: Enabled  Q RW CHSLIMITH Set 1 CHSLIMITH  Set 1 Enable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  R RW CHSLIMITL Write '1' to enable interrupt for event CHSLIMITH  Set 1 Read: Enabled  Write '1' to enable interrupt for event CHSLIMITL  Finable 1 Read: Disabled  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  S RW CH6LIMITH Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  Disabled 0 Read: Enabled  Set 1 Enable  Finable Properties of event CH6LIMITH  Set 1 Read: Disabled  Read: Disabled  Write '1' to enable interrupt for event CH6LIMITH  Finable Properties of event CH6LIMITH  Read: Enabled  T RW CH6LIMITL Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |           | Set      | 1                       | Enable                                                          |
| Q RW CH5LIMITH  Set 1 Enable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  RRW CH5LIMITL  Set 1 Enable  CH5LIMITL  Set 1 Enable  Write '1' to enable interrupt for event CH5LIMITL  Write '1' to enable interrupt for event CH5LIMITL  Set 1 Enable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  SRW CH6LIMITH  Set 1 Enable  Write '1' to enable interrupt for event CH6LIMITH  Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  Read: Disabled  Read: Disabled  Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  TRW CH6LIMITL  Set 1 Enable  TRW CH6LIMITL  Enable  Try RW CH6LIMITL  Set 1 Enable  Finable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set 1 Enable  R RW CH5LIMITL Set 1 Enable  Set 1 Read: Disabled  R RW CH5LIMITL Set 1 Read: Enabled  R RW CH6LIMITH Set 1 Read: Enabled  R RW CH6LIMITH Set 1 Read: Disabled  R Read: Disabled Read: Disabled Read: Enabled  Set 1 Read: Enabled  Read: Enabled  Set 1 Enable Read: Enabled  Read: Enabled  Read: Disabled Read: Enabled  Read: Disabled Read: Enabled  Read: Enabled  Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| R RW CHSLIMITL Set 1 Disabled 0 Read: Disabled RR RW CHSLIMITL Set 1 Disabled 0 Read: Enabled RR RW CHSLIMITL Set 1 Disabled 0 Read: Disabled Read: Enabled Read: Disabled Read: Disabled Read: Disabled Read: Disabled Read: Enabled Read: Enabled Read: Enabled Read: Enabled Read: Enabled Read: Enabled Read: Disabled Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Q     | RW      | CH5LIMITH |          |                         | Write '1' to enable interrupt for event CH5LIMITH               |
| R RW CH5LIMITL Set 1 Enabled  Set 1 Enabled  Read: Enabled  Read: Enabled  Finable  CH6LIMITH Set 1 Enable  Set 1 Enable  Enabled  T RW CH6LIMITL  Enabled 1 Read: Enabled  T RW CH6LIMITL  Enabled 1 Read: Enabled  T RW CH6LIMITL  Enabled 1 Read: Enabled  T RW CH6LIMITL  Enable  Finable Write '1' to enable interrupt for event CH6LIMITL  Read: Enabled  Write '1' to enable interrupt for event CH6LIMITL  Enable  Write '1' to enable interrupt for event CH6LIMITL  Enable  Finable  Finable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |           | Set      | 1                       | Enable                                                          |
| R RW CH5LIMITL  Set 1 Enable  Disabled 0 Read: Disabled  Enabled  Set 1 Read: Enabled  Finabled 1 Read: Enabled  Set 1 Enabled  Set 1 Enabled  Write '1' to enable interrupt for event CH6LIMITH  Finable Enabled  Set 1 Enable  Disabled 0 Read: Disabled  Read: Disabled  T RW CH6LIMITL  Set 1 Read: Enabled  T RW CH6LIMITL  Finable Enabled  Write '1' to enable interrupt for event CH6LIMITL  Enable  Finable  Write '1' to enable interrupt for event CH6LIMITL  Enable  Finable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set 1 Enable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Set 1 Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  Disabled 0 Read: Disabled  Enable  T RW CH6LIMITL  Set 1 Write '1' to enable interrupt for event CH6LIMITH  Enable  Write '1' to enable interrupt for event CH6LIMITH  Read: Enabled  Write '1' to enable interrupt for event CH6LIMITL  Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| Bisabled 0 Read: Disabled  Read: Disabled  Read: Enabled  S RW CH6LIMITH  Set 1 Enable  Disabled 0 Read: Enabled  Write '1' to enable interrupt for event CH6LIMITH  Set 1 Enable  Read: Disabled  Read: Disabled  Write '1' to enable interrupt for event CH6LIMITH  Write '1' to enable interrupt for event CH6LIMITL  Enabled  T RW CH6LIMITL  Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R     | RW      | CH5LIMITL |          |                         | Write '1' to enable interrupt for event CH5LIMITL               |
| S RW CH6LIMITH Set 1 Read: Enabled Write '1' to enable interrupt for event CH6LIMITH Enable Disabled 0 Read: Disabled Read: Enabled T RW CH6LIMITL Set 1 Enable Write '1' to enable interrupt for event CH6LIMITH Write '1' to enable interrupt for event CH6LIMITL Enable Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |           | Set      | 1                       | Enable                                                          |
| S RW CH6LIMITH  Set 1 Enable  Disabled 0 Read: Disabled  Enabled  T RW CH6LIMITL  Set 1 Enable  Write '1' to enable interrupt for event CH6LIMITH  Read: Enabled  Write '1' to enable interrupt for event CH6LIMITL  Enabled  Enabled  Enabled  Frable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |           | Disabled | 0                       | Read: Disabled                                                  |
| Set 1 Enable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  T RW CH6LIMITL Set 1 Enable Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |           | Enabled  | 1                       |                                                                 |
| Disabled 0 Read: Disabled Enabled 1 Read: Enabled  T RW CH6LIMITL Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | S     | RW      | CH6LIMITH |          |                         |                                                                 |
| Enabled 1 Read: Enabled  T RW CH6LIMITL Set 1 Enable  Enabled  Write '1' to enable interrupt for event CH6LIMITL  Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |           |          |                         |                                                                 |
| T RW CH6LIMITL Write '1' to enable interrupt for event CH6LIMITL  Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |           |          |                         |                                                                 |
| Set 1 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |           | Enabled  | 1                       |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Т     | RW      | CH6LIMITL |          |                         |                                                                 |
| Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |           |          |                         |                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |         |           | Disabled | 0                       | Read: Disabled                                                  |





| Bit n | umber   |           |          | 313 | 30 29 | 28 27 | 7 26 . | 25 2 | 4 2 | 3 22  | 21    | 20 : | 19 1 | 18 1 | 7 16 | 15   | 14    | 13 1  | .2 1 | 1 10 | 9    | 8    | 7 | 6 5 | 5 4 | 3 | 2 | 1 0 |
|-------|---------|-----------|----------|-----|-------|-------|--------|------|-----|-------|-------|------|------|------|------|------|-------|-------|------|------|------|------|---|-----|-----|---|---|-----|
| ID    |         |           |          |     |       |       |        |      |     |       | ٧     | U    | Т    | S F  | ≀ Q  | Р    | 0     | N I   | И L  | . K  | J    | 1    | Н | G F | E   | D | С | ВА  |
| Rese  | t 0x000 | 00000     |          | 0 ( | 0 0   | 0 0   | 0      | 0 0  | ) ( | 0 0   | 0     | 0    | 0    | 0 (  | 0    | 0    | 0     | 0     | 0 0  | 0    | 0    | 0    | 0 | 0 ( | 0   | 0 | 0 | 0 0 |
| ID    |         |           |          |     |       |       |        |      |     |       |       |      |      |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1   |       |       |        |      | R   | lead  | : En  | able | ed   |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
| U     | RW      | CH7LIMITH |          |     |       |       |        |      | ٧   | Vrite | · '1' | to e | ena  | ble  | inte | rrup | ot fo | or ev | /ent | CH   | 7LIN | ЛITН | 1 |     |     |   |   |     |
|       |         |           | Set      | 1   |       |       |        |      | Е   | nab   | le    |      |      |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
|       |         |           | Disabled | 0   |       |       |        |      | R   | lead  | : Di  | sabl | ed   |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1   |       |       |        |      | R   | Read  | : En  | able | ed   |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
| ٧     | RW      | CH7LIMITL |          |     |       |       |        |      | ٧   | Vrite | · '1' | to e | ena  | ble  | inte | rrup | ot fo | or ev | /ent | CH   | 7LIN | ΛΙΤL |   |     |     |   |   |     |
|       |         |           | Set      | 1   |       |       |        |      | Е   | nab   | le    |      |      |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
|       |         |           | Disabled | 0   |       |       |        |      | R   | lead  | : Di  | sabl | ed   |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |
|       |         |           | Enabled  | 1   |       |       |        |      | R   | lead  | : En  | able | ed   |      |      |      |       |       |      |      |      |      |   |     |     |   |   |     |

## 7.29.11.27 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit r | umber    |               |          | 31 30 29 28 27 26 25 24 23 | 3 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|----------------------------|--------------------------------------------------------------|
| ID    |          |               |          |                            | V U T S R Q P O N M L K J I H G F E D C B A                  |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0 0 0            | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                      |
|       |          |               |          |                            |                                                              |
| Α     | RW       | STARTED       |          | W                          | rite '1' to disable interrupt for event STARTED              |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| В     | RW       | END           |          | W                          | rite '1' to disable interrupt for event END                  |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| С     | RW       | DONE          |          | W                          | rite '1' to disable interrupt for event DONE                 |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| D     | RW       | RESULTDONE    |          | W                          | rite '1' to disable interrupt for event RESULTDONE           |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| E     | RW       | CALIBRATEDONE |          | W                          | rite '1' to disable interrupt for event CALIBRATEDONE        |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| F     | RW       | STOPPED       |          | W                          | rite '1' to disable interrupt for event STOPPED              |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| G     | RW       | CHOLIMITH     |          | W                          | rite '1' to disable interrupt for event CHOLIMITH            |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               | Disabled | 0 Re                       | ead: Disabled                                                |
|       |          |               | Enabled  | 1 Re                       | ead: Enabled                                                 |
| Н     | RW       | CHOLIMITL     |          | W                          | rite '1' to disable interrupt for event CHOLIMITL            |
|       |          |               | Clear    | 1 Di                       | sable                                                        |
|       |          |               |          |                            |                                                              |





| Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 7 6 5 4 3 2 1 0 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| D   R/W   Felo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | H G F E D C B A |
| Disabled   Enabled   1   Read: Enabled   1   Read: Enabled   1   RW   CHILIMITH   Clear   1   Disable   Read: Enabled   1      | 0000000         |
| Final                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |
| RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                 |
| Clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | l               |
| Read: Enabled   1   Read   |                 |
| The content of the    |                 |
| Clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |
| Disabled   Enabled   1   Read: Enabled   1     |                 |
| Enabled 1 Read: Enabled  K RW CH2LIMITH  Clear 1 Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |
| K RW CH2LIMITH  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  Clear 1 Disable  Enabled 1 Read: Enabled  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  M RW CH3LIMITH  Clear 1 Disable Enabled 1 Read: Enabled  M RW CH3LIMITH  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH3LIMITL  Clear 1 Disable Enabled 1 Read: Enabled  N RW CH3LIMITL  Clear 1 Disable Enabled 1 Read: Enabled  N RW CH3LIMITL  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH4LIMITL  Clear 1 Disable Enabled 1 Read: Enabled  N Read: Enabled  Clear 1 Disable Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |
| Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  L RW CH2LIMITL Clear 1 Disable Enabled 0 Read: Disabled Enabled 0 Read: Disable interrupt for event CH2LIMITI Disabled 0 Read: Disabled Enabled 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Enabled 1 Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |
| Disabled 0 Read: Disabled Enabled 1 Read: Enabled  L RW CH2LIMITL Clear 1 Disable Enabled 1 Read: Enabled  Clear 1 Disable Enabled 1 Read: Disable Enabled 1 Read: Disable Enabled 1 Read: Disable Enabled 1 Read: Disabled Enabled 1 Read: Disabled Enabled 1 Read: Disabled Enabled 1 Read: Disabled Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH4LIMITL Clear 1 Disable Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  P RW CH4LIMITL Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH4LIMITL Clear 1 Disable Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  P RW CH5LIMITL Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  P Read: Enabled  CLear 1 Disable Enabled 1 Read: Enabled  Read: Enabled  CLear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ł               |
| Enabled 1 Read: Enabled  L RW CHZLIMITL Clear 1 Disable Disabled 0 Read: Disable Enabled 1 Read: Enabled  CHZLIMITL Clear 1 Disable Enabled 1 Read: Enabled  M RW CHZLIMITH Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  M RW CHZLIMITH Clear 1 Disable Enabled 1 Read: Enabled  N RW CHZLIMITL Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CHZLIMITL Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  P RW CHZLIMITL Clear 1 Disable Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  P RW CHZLIMITL Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| L RW CH2LIMITL  Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |
| Clear   1   Disabled   Clear   1   Clear   |                 |
| Disabled 0 Read: Disabled 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable 1 Read: Enabled  M RW CH3LIMITH Clear 1 Disable 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable 1 Read: Enabled  N RW CH3LIMITL Clear 1 Disable 1 Read: Enabled  N RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  O RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  P RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  P RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  Clear 1 Disabled 0 Read: Disabled 1 Read: Enabled  P RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  Clear 1 Disabled 0 Read: Disabled 1 Read: Enabled  P RW CH4LIMITH Clear 1 Disable 1 Read: Enabled  Clear 1 Disabled 0 Read: Disabled 1 Read: Enabled  CLear 1 Disabled 0 Read: Disabled 1 Read: Enabled  CLear 1 Disable 1 Read: Disable 1 Read: Disable 1 Read: Enabled  CLear 1 Disable 1 Read: Enabled  CLear 1 Disable 1 Read: Disable 1 Read: Disable 1 Read: Disable 1 Read: Enabled  CLear 1 Disable 1 Read: Disabl |                 |
| Enabled 1 Read: Enabled  M RW CH3LIMITH  Clear 1 Disable  Disabled 0 Read: Disabled Enabled 1 Read: Enabled  N Read: Enabled  N RW CH3LIMITL  Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  N Read: Enabled  N Read: Enabled  N Read: Enabled  N Read: Enabled  Disabled 0 Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 0 Read: Disabled Enabled 1 Disable  Clear 1 Disable  Disabled 0 Read: Disabled Enabled 1 Read: Enabled  P RW CH4LIMITL  Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Disable  Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  O Read: Disabled Enabled 1 Read: Enabled  R Read: Enabled  Clear 1 Disable Enabled 1 Read: Enabled  Clear 1 Disable Enabled 0 Read: Disable Enabled 1 Read: Enabled  R Read: Enabled  R Read: Enabled  R Read: Enabled  R Read: Disabled Enabled 0 Read: Disable Enabled 1 Read: Enabled  R Read: Enabled  R Read: Enabled  R Read: Enabled  R Read: Disabled Enabled 0 Read: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |
| M RW CH3LIMITH  Clear 1 Disable  Disabled 0 Read: Disabled  Read: Enabled  N RW CH3LIMITL  Clear 1 Disable  Disabled 0 Read: Enabled  N RW CH3LIMITL  Clear 1 Disable  Disabled 0 Read: Disable  Enabled 1 Read: Enabled  Clear 1 Disable  Disabled 0 Read: Disabled  Read: Enabled  Clear 1 Disabled  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disabled  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  P RW CH4LIMITL  Clear 1 Disable  Enabled 1 Read: Enabled  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disabled  Clear 1 Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| Clear   1   Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |
| Disabled   Disabled   Disabled   Read: Disabled   Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1               |
| RW CHALIMITE  Clear 1 Disabled  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  O RW CHALIMITH  Clear 1 Disable  Disabled 0 Read: Disabled  Clear 1 Disabled  O Read: Enabled  O Read: Enabled  O Read: Disabled  Enabled 1 Read: Enabled  O Read: Disabled  O Read: Disabled  Enabled 1 Read: Enabled  O Read: Disabled  O Read: Disabled  Enabled 1 Read: Enabled  O Read: Disabled  Enabled 1 Read: Enabled  O Read: Disabled  Enabled 1 Read: Enabled  O Read: Disabled  Enabled 1 Read: Enabled  Read: Enabled  Read: Enabled  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                 |
| N RW CH3LIMITL  Clear 1 Disable Disabled 0 Read: Disabled  Clear 1 Price |                 |
| Clear 1 Disabled  O RW CHALIMITH  Clear 1 Disabled  Disabled  Clear 1 Read: Enabled  Read: Disabled  Read: Disabled  Clear 1 Disabled  Clear 1 Disabled  Clear 1 Disabled  Clear 1 Disabled  Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |
| Disabled 0 Read: Disabled 0 Read: Enabled 0 Read: Disabled 0 Read: Disabled 0 Read: Disabled 1 Read: Enabled 0 Read: Disabled 0 Read: Enabled 0 Read: Enabled 0 Read: Enabled 0 Read: Enabled 0 Read: Disabled 0 Read: Enabled 0 Read: Enabled 0 Read: Disabled 0 Read: Disabled 0 Read: Disabled 0 Read: Disabled 0 Read: Enabled 0 Read: Disabled 0 R |                 |
| Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Disable interrupt for event CH4LIMITE  Clear 1 Disable  Enabled 0 Read: Disabled  Enabled 1 Read: Enabled  PRW CH4LIMITL  Clear 1 Disable  Disable interrupt for event CH4LIMITE  Clear 1 Disable  Enabled 0 Read: Disabled  Enabled 1 Read: Enabled  CLEAR 1 Disabled  Enabled 1 Read: Enabled  CLEAR 1 Disabled  Enabled 1 Read: Enabled  CLEAR 1 Disable  Enabled 0 Read: Disabled  Enabled 1 Read: Enabled  Read: Disabled  Enabled 1 Read: Enabled  CLEAR 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Disabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| O RW CH4LIMITH  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  P RW CH4LIMITL  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Disabled 0 Read: Disabled  Read: Enabled  Read: Enabled  Q RW CH5LIMITH  Clear 1 Disable  Enabled 1 Read: Enabled  Q RW CH5LIMITH  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Read: Disabled  Read: Disabled  Clear 1 Disable  Clear 1 Disabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Enabled  Read: Disabled  Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |
| Clear 1 Disabled  P RW CH4LIMITL Clear 1 Disabled CH5LIMITH Clear 1 Disable CH5LIMITH Clear 1 Disabled CH5LIMITH Clear 1 Disable CH5LIMITH CH |                 |
| Disabled 0 Read: Disabled  P RW CHALIMITL  Clear 1 Disabled  Disabled 0 Read: Enabled  Clear 1 Disable  Enabled 1 Read: Enabled  Clear 1 Disable  Enabled 1 Read: Disabled  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Read: Disabled  Enabled 1 Read: Enabled  Read: Disabled  Clear 1 Disabled  Enabled 1 Read: Enabled  Clear 1 Disabled  Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disable  Enabled 0 Read: Disabled  Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | H               |
| RW CHALIMITE  RW CHALIMITE  Clear  Disabled  Read: Disabled  Read: Enabled  Read: Disabled  Read: Disabled  Read: Disabled  Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |
| P RW CH4LIMITL  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled  Clear 1 Disable  Read: Enabled  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Disable  Read: Disabled  Read: Disabled  Read: Disabled  Clear 1 Disabled  Enabled 1 Read: Enabled  Read: Disabled  Read: Disabled  Enabled 1 Read: Enabled  Read: Disabled  Read: Disabled  Read: Disabled  Read: Disabled  Read: Disabled  Enabled 1 Read: Disabled  Read: Disabled  Disable  Disabled 0 Read: Disabled  Read: Disabled  Disabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                 |
| Clear 1 Disable  Read: Disabled  Read: Enabled  Clear 1 Disable  Clear 1 Disable  Clear 1 Disable  Disable  Read: Disable  Clear 1 Disable  Enabled 1 Read: Disabled  Read: Disabled  Clear 1 Disable  Enabled 1 Read: Enabled  Read: Disabled  Enabled 1 Read: Enabled  Read: Disabled  Read: Disabled  Enabled 1 Read: Enabled  Read: Disable Interrupt for event CH5LIMITE  Clear 1 Disable  Disable  Disable Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |
| Disabled 0 Read: Disabled Q RW CHSLIMITH Clear 1 Disable Enabled 0 Read: Enabled  Rad: Enabled  Clear 1 Disable Enabled 0 Read: Disabled Enabled 1 Read: Enabled  R RW CHSLIMITL Clear 1 Disable Enabled 1 Read: Enabled  R RW CHSLIMITL Clear 1 Disable Disable Enabled 0 Read: Disable Read: Enabled  R RW CHSLIMITL Clear 1 Disable Disable Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |
| RW CH5LIMITH Clear Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |
| Q RW CHSLIMITH  Clear  Disable  Disable  Read: Disabled  Enabled  Read: Enabled  Clear  Disabled  Enabled  Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| Clear 1 Disable Disabled 0 Read: Disabled  R RW CHSLIMITL Clear 1 Write '1' to disable interrupt for event CHSLIMITE Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |
| Disabled 0 Read: Disabled  R RW CH5LIMITL  Clear 1 Disable  Disabled 0 Read: Enabled  Read: Enabled  Mrite '1' to disable interrupt for event CH5LIMITE  Clear 1 Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | l .             |
| R RW CH5LIMITL Clear Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |
| R RW CH5LIMITL  Clear 1 Disable  Disable  Disabled 0 Read: Disabled  Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |
| Clear 1 Disable Disabled 0 Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| Disabled 0 Read: Disabled Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |
| S RW CH6LIMITH Write '1' to disable interrunt for event CH6LIMITE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| when I to disable meaning for event children                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | l .             |
| Clear 1 Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |
| Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |
| T RW CH6LIMITL Write '1' to disable interrupt for event CH6LIMITL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |
| Clear 1 Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 |
| Disabled 0 Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |
| Enabled 1 Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |





| Bit n | umber   |           |          | 313 | 30 : | 29 28 | 3 27 | 26 2 | 5 24 | 23 | 3 22 : | 21  | 20 1  | 9 18 | 3 17  | 16   | 15  | 14 1 | 3 1  | 2 11 | 10  | 9 8 | 3 7 | 6 | 5 | 4 | 3 2 | ! 1 | 0 |
|-------|---------|-----------|----------|-----|------|-------|------|------|------|----|--------|-----|-------|------|-------|------|-----|------|------|------|-----|-----|-----|---|---|---|-----|-----|---|
| ID    |         |           |          |     |      |       |      |      |      |    |        | ٧   | U 1   | ΓS   | R     | Q    | Р   | 0 1  | N N  | 1 L  | K   | JI  | Н   | G | F | Ε | D C | В   | Α |
| Rese  | t 0x000 | 00000     |          | 0   | 0    | 0 0   | 0    | 0 0  | 0    | 0  | 0      | 0   | 0 (   | 0    | 0     | 0    | 0   | 0 (  | ) (  | 0    | 0   | 0 0 | 0   | 0 | 0 | 0 | 0 0 | 0   | 0 |
| ID    |         |           |          |     |      |       |      |      |      |    |        |     |       |      |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
| U     | RW      | CH7LIMITH |          |     |      |       |      |      |      | W  | rite   | '1' | to d  | isab | le ir | nter | rup | t fo | r ev | ent  | CH7 | LIM | ITH |   |   |   |     |     |   |
|       |         |           | Clear    | 1   |      |       |      |      |      | Di | sabl   | e   |       |      |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
|       |         |           | Disabled | 0   |      |       |      |      |      | Re | ead:   | Dis | able  | ed   |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
|       |         |           | Enabled  | 1   |      |       |      |      |      | Re | ead:   | Ena | able  | d    |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
| V     | RW      | CH7LIMITL |          |     |      |       |      |      |      | W  | rite   | '1' | to di | isab | le ir | nter | rup | t fo | r ev | ent  | CH7 | LIM | ITL |   |   |   |     |     |   |
|       |         |           | Clear    | 1   |      |       |      |      |      | Di | sabl   | e   |       |      |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
|       |         |           | Disabled | 0   |      |       |      |      |      | Re | ead:   | Dis | able  | d    |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |
|       |         |           | Enabled  | 1   |      |       |      |      |      | Re | ead:   | Ena | able  | d    |       |      |     |      |      |      |     |     |     |   |   |   |     |     |   |

#### 7.29.11.28 STATUS

Address offset: 0x400

Status



#### 7.29.11.29 ENABLE

Address offset: 0x500 Enable or disable ADC



## 7.29.11.30 CH[n].PSELP (n=0..7)

Address offset:  $0x510 + (n \times 0x10)$ 

Input positive pin selection for CH[n]



| Bit n | umber   |       |              | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|--------------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |              |                         | АААА                                                          |
| Rese  | t 0x000 | 00000 |              | 0 0 0 0 0 0 0 0         | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                     |
| ID    |         |       |              |                         | Description                                                   |
| Α     | RW      | PSELP |              |                         | Analog positive input channel                                 |
|       |         |       | NC           | 0                       | Not connected                                                 |
|       |         |       | AnalogInput0 | 1                       | AINO                                                          |
|       |         |       | AnalogInput1 | 2                       | AIN1                                                          |
|       |         |       | AnalogInput2 | 3                       | AIN2                                                          |
|       |         |       | AnalogInput3 | 4                       | AIN3                                                          |
|       |         |       | AnalogInput4 | 5                       | AIN4                                                          |
|       |         |       | AnalogInput5 | 6                       | AIN5                                                          |
|       |         |       | AnalogInput6 | 7                       | AIN6                                                          |
|       |         |       | AnalogInput7 | 8                       | AIN7                                                          |
|       |         |       | VDD          | 9                       | VDD                                                           |
|       |         |       | VDDHDIV5     | 0xD                     | VDDH/5                                                        |

# 7.29.11.31 CH[n].PSELN (n=0..7)

Address offset:  $0x514 + (n \times 0x10)$ Input negative pin selection for CH[n]

| Bit n | umber   |       |              | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|--------------|---------------------|---------------------------------------------------------------------|
| ID    |         |       |              |                     | АААА                                                                |
| Rese  | t 0x000 | 00000 |              | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |       |              |                     |                                                                     |
| Α     | RW      | PSELN |              |                     | Analog negative input, enables differential channel                 |
|       |         |       | NC           | 0                   | Not connected                                                       |
|       |         |       | AnalogInput0 | 1                   | AIN0                                                                |
|       |         |       | AnalogInput1 | 2                   | AIN1                                                                |
|       |         |       | AnalogInput2 | 3                   | AIN2                                                                |
|       |         |       | AnalogInput3 | 4                   | AIN3                                                                |
|       |         |       | AnalogInput4 | 5                   | AIN4                                                                |
|       |         |       | AnalogInput5 | 6                   | AIN5                                                                |
|       |         |       | AnalogInput6 | 7                   | AIN6                                                                |
|       |         |       | AnalogInput7 | 8                   | AIN7                                                                |
|       |         |       | VDD          | 9                   | VDD                                                                 |
|       |         |       | VDDHDIV5     | 0xD                 | VDDH/5                                                              |

# 7.29.11.32 CH[n].CONFIG (n=0..7)

Address offset:  $0x518 + (n \times 0x10)$ Input configuration for CH[n]

| Bit number       |          | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|------------------|----------|---------------------|------------------------------------------------------------------|
| ID               |          |                     | G F E E E D C C C B B A                                          |
| Reset 0x00020000 |          | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0                          |
|                  |          |                     |                                                                  |
| A RW RESP        |          |                     | Positive channel resistor control                                |
|                  | Bypass   | 0                   | Bypass resistor ladder                                           |
|                  | Pulldown | 1                   | Pull-down to GND                                                 |
|                  | Pullup   | 2                   | Pull-up to VDD                                                   |
|                  | VDD1 2   | 3                   | Set input at VDD/2                                               |



| Bit n | umber   |        |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |        |          | G                       | FEEE DCCC BB AA                                               |
| Rese  | t 0x000 | 20000  |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
|       |         |        |          |                         |                                                               |
| В     | RW      | RESN   |          |                         | Negative channel resistor control                             |
|       |         |        | Bypass   | 0                       | Bypass resistor ladder                                        |
|       |         |        | Pulldown | 1                       | Pull-down to GND                                              |
|       |         |        | Pullup   | 2                       | Pull-up to VDD                                                |
|       |         |        | VDD1_2   | 3                       | Set input at VDD/2                                            |
| С     | RW      | GAIN   |          |                         | Gain control                                                  |
|       |         |        | Gain1_6  | 0                       | 1/6                                                           |
|       |         |        | Gain1_5  | 1                       | 1/5                                                           |
|       |         |        | Gain1_4  | 2                       | 1/4                                                           |
|       |         |        | Gain1_3  | 3                       | 1/3                                                           |
|       |         |        | Gain1_2  | 4                       | 1/2                                                           |
|       |         |        | Gain1    | 5                       | 1                                                             |
|       |         |        | Gain2    | 6                       | 2                                                             |
|       |         |        | Gain4    | 7                       | 4                                                             |
| D     | RW      | REFSEL |          |                         | Reference control                                             |
|       |         |        | Internal | 0                       | Internal reference (0.6 V)                                    |
|       |         |        | VDD1_4   | 1                       | VDD/4 as reference                                            |
| E     | RW      | TACQ   |          |                         | Acquisition time, the time the ADC uses to sample the         |
|       |         |        |          |                         | input voltage                                                 |
|       |         |        | 3us      | 0                       | 3 μs                                                          |
|       |         |        | 5us      | 1                       | 5 μs                                                          |
|       |         |        | 10us     | 2                       | 10 μs                                                         |
|       |         |        | 15us     | 3                       | 15 μs                                                         |
|       |         |        | 20us     | 4                       | 20 μs                                                         |
|       |         |        | 40us     | 5                       | 40 μs                                                         |
| F     | RW      | MODE   |          |                         | Enable differential mode                                      |
|       |         |        | SE       | 0                       | Single-ended, PSELN will be ignored, negative input to ADC    |
|       |         |        |          |                         | shorted to GND                                                |
|       |         |        | Diff     | 1                       | Differential                                                  |
| G     | RW      | BURST  |          |                         | Enable burst mode                                             |
|       |         |        | Disabled | 0                       | Burst mode is disabled (normal operation)                     |
|       |         |        | Enabled  | 1                       | Burst mode is enabled. SAADC takes 2^OVERSAMPLE               |
|       |         |        |          |                         | number of samples as fast as it can, and sends the average    |
|       |         |        |          |                         | to Data RAM.                                                  |

# 7.29.11.33 CH[n].LIMIT (n=0..7)

Address offset: 0x51C + (n × 0x10)

High/low limits for event monitoring a channel

| Bit n | umber    |       | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|------------------------|-----------------------------------------------------------------|
| ID    |          |       | B B B B B B B I        | 3                                                               |
| Rese  | et 0x7FF | F8000 | 0 1 1 1 1 1 1 :        | 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |                        | Description                                                     |
| Α     | RW       | LOW   | [-32768 to +32767]     | Low level limit                                                 |
| В     | RW       | HIGH  | [-32768 to +32767]     | High level limit                                                |

# 7.29.11.34 RESOLUTION

Address offset: 0x5F0



#### Resolution configuration



### 7.29.11.35 OVERSAMPLE

Address offset: 0x5F4

Oversampling configuration. OVERSAMPLE should not be combined with SCAN. The RESOLUTION is applied before averaging, thus for high OVERSAMPLE a higher RESOLUTION should be used.



#### 7.29.11.36 SAMPLERATE

Address offset: 0x5F8

Controls normal or continuous sample rate



#### 7.29.11.37 RESULT.PTR

Address offset: 0x62C

Data pointer





See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.29.11.38 RESULT.MAXCNT

Address offset: 0x630

Maximum number of buffer words to transfer



#### 7.29.11.39 RESULT.AMOUNT

Address offset: 0x634

Number of buffer words transferred since last START



# 7.29.12 Electrical specification

## 7.29.12.1 SAADC Electrical Specification

| Symbol                | Description                                                                  | Min. | Тур. | Max. | Units  |
|-----------------------|------------------------------------------------------------------------------|------|------|------|--------|
| DNL <sub>10</sub>     | Differential non-linearity, 10-bit resolution                                | -0.9 | <1   |      | LSB10b |
| INL <sub>10</sub>     | Integral non-linearity, 10-bit resolution                                    |      | ±1   |      | LSB10b |
| V <sub>OS</sub>       | Differential offset error (calibrated), 10-bit resolution <sup>17</sup>      |      | ±2   |      | LSB10b |
| DNL <sub>12</sub>     | Differential non-linearity, 12-bit resolution                                | -0.9 | 1.3  |      | LSB12b |
| INL <sub>12</sub>     | Integral non-linearity, 12-bit resolution                                    |      | 3.7  |      | LSB12b |
| E <sub>VDDHDIV5</sub> | Error on VDDHDIV5 input                                                      |      | ±1   |      | %      |
| C <sub>EG</sub>       | Gain error temperature coefficient                                           |      | 0.02 |      | %/°C   |
| f <sub>SAMPLE</sub>   | Maximum sampling rate                                                        |      |      | 200  | kHz    |
| t <sub>ACQ,10k</sub>  | Acquisition time (configurable), source Resistance $\leq 10~\text{k}\Omega$  |      | 3    |      | μs     |
| t <sub>ACQ,40k</sub>  | Acquisition time (configurable), source Resistance $\leq 40~\text{k}\Omega$  |      | 5    |      | μs     |
| t <sub>ACQ,100k</sub> | Acquisition time (configurable), source Resistance $\leq 100~\text{k}\Omega$ |      | 10   |      | μs     |
| t <sub>ACQ,200k</sub> | Acquisition time (configurable), source Resistance $\leq$ 200 k $\Omega$     |      | 15   |      | μs     |
| t <sub>ACQ,400k</sub> | Acquisition time (configurable), source Resistance $\leq 400~\text{k}\Omega$ |      | 20   |      | μs     |

<sup>&</sup>lt;sup>17</sup> Digital output code at zero volt differential input.



| Symbol                | Description                                                                  | Min. | Тур. | Max. | Units |
|-----------------------|------------------------------------------------------------------------------|------|------|------|-------|
| t <sub>ACQ,800k</sub> | Acquisition time (configurable), source Resistance $\leq 800~\text{k}\Omega$ |      | 40   |      | μs    |
| $t_{CONV}$            | Conversion time                                                              |      | 2    |      | μs    |
| E <sub>G1/6</sub>     | Error <sup>18</sup> for Gain = 1/6                                           | -3   |      | 3    | %     |
| E <sub>G1/4</sub>     | Error <sup>18</sup> for Gain = 1/4                                           | -3   |      | 3    | %     |
| E <sub>G1/2</sub>     | Error <sup>18</sup> for Gain = 1/2                                           | -3   |      | 4    | %     |
| E <sub>G1</sub>       | Error <sup>18</sup> for Gain = 1                                             | -3   |      | 4    | %     |
| C <sub>SAMPLE</sub>   | Sample and hold capacitance at maximum gain <sup>19</sup>                    |      | 2.5  |      | pF    |
| R <sub>INPUT</sub>    | Input resistance                                                             |      | >1   |      | ΜΩ    |
| E <sub>NOB</sub>      | Effective number of bits, differential mode, 12-bit                          |      | 9.8  |      | Bit   |
|                       | resolution, 1/1 gain, 3 μs acquisition time, HFXO, 32 ksps,                  |      |      |      |       |
|                       | F <sub>in</sub> = 3 kHz                                                      |      |      |      |       |
| S <sub>NDR</sub>      | Peak signal to noise and distortion ratio, differential mode,                |      | 61   |      | dB    |
|                       | 12-bit resolution, 1/1 gain, 3 $\mu s$ acquisition time, HFXO, 32            |      |      |      |       |
|                       | ksps, F <sub>in</sub> = 3 kHz                                                |      |      |      |       |
| S <sub>FDR</sub>      | Spurious free dynamic range, differential mode, 12-bit                       |      | 73   |      | dBc   |
|                       | resolution, 1/1 gain, 3 μs acquisition time, HFXO, 32 ksps,                  |      |      |      |       |
|                       | F <sub>in</sub> = 3 kHz                                                      |      |      |      |       |
| R <sub>LADDER</sub>   | Ladder resistance                                                            |      | 160  |      | kΩ    |

## 7.29.13 Performance factors

Clock jitter, affecting sample timing accuracy, and circuit noise can affect ADC performance.

Jitter can be between START tasks or from START task to acquisition. START timer accuracy and startup times of regulators and references will contribute to variability. Sources of circuit noise may include CPU activity and the DC/DC regulator. The best ADC performance is achieved using START timing based on the TIMER module, HFXO clock source, and Constant Latency mode.

# 7.30 SPIM — Serial peripheral interface master with EasyDMA

The SPI master can communicate with multiple SPI slaves using individual chip select signals for each slave.

The the main features of SPIM are:

- EasyDMA direct transfer to/from RAM
- SPI mode 0-3
- Individual selection of I/O pins
- Optional D/CX output line for distinguishing between command and data bytes



<sup>&</sup>lt;sup>18</sup> Temperature drift is not included.

<sup>&</sup>lt;sup>19</sup> Maximum gain corresponds to highest capacitance.



Figure 197: SPIM — SPI master with EasyDMA

# 7.30.1 SPI master transaction sequence

An SPI master transaction is started by triggering the START task. When started, a number of bytes will be transmitted/received on MOSI/MISO.

The following figure illustrates an SPI master transaction.





Figure 198: SPI master transaction

The ENDTX is generated when all bytes in buffer TXD.PTR on page 567 are transmitted. The number of bytes in the transmit buffer is specified in register TXD.MAXCNT on page 567. The ENDRX event will be generated when buffer RXD.PTR on page 566 is full, that is when the number of bytes specified in register RXD.MAXCNT on page 566 have been received. The transaction stops automatically after all bytes have been transmitted/received. When the maximum number of bytes in receive buffer is larger than the number of bytes in the transmit buffer, the contents of register ORC on page 570 will be transmitted after the last byte in the transmit buffer has been transmitted.

The END event will be generated after both the ENDRX and ENDTX events have been generated.

The SPI master can be stopped by triggering the STOP task. A STOPPED event is generated when the SPI master has stopped. If the STOP task is triggered in the middle of a transaction, SPIM will complete the transmission/reception of the current byte before stopping. The STOPPED event is generated even if the STOP task is triggered while there is no ongoing transaction.

If the ENDTX event has not already been generated when the SPI master has come to a stop, the ENDTX event will be generated even if all bytes in the buffer TXD.PTR on page 567 have not been transmitted.

If the ENDRX event has not already been generated when the SPI master has come to a stop, the ENDRX event will be generated even if the buffer RXD.PTR on page 566 is not full.

A transaction can be suspended and resumed using the SUSPEND and RESUME tasks, receptively. When the SUSPEND task is triggered, the SPI master will complete transmitting and receiving the current ongoing byte before it is suspended.

# 7.30.2 D/CX functionality

Some SPI slaves, for example display drivers, require an additional signal from the SPI master to distinguish between command and data bytes. For display drivers this line is often called D/CX.

The SPIM provides support for such a D/CX output line. The D/CX line is set low during transmission of command bytes and high during transmission of data bytes.

The D/CX pin number is selected using PSELDCX on page 569 and the number of command bytes preceding the data bytes is configured using DCXCNT on page 570.

It is not allowed to write to the DCXCNT on page 570 during an ongoing transmission.

The following figure shows the use of D/CX, using SPIM.DCXCNT=1.





Figure 199: D/CX example. SPIM.DCXCNT = 1.

## 7.30.3 Pin configuration

The SCK, CSN, DCX, MOSI, and MISO signals associated with the SPIM are mapped to physical pins according to the configuration specified in the PSEL.n registers.

The contents of registers PSEL.SCK on page 564, PSEL.CSN on page 565, PSELDCX on page 569, PSEL.MOSI on page 565, and PSEL.MISO on page 565 are only used when the SPIM is enabled and retained only as long as the device is in System ON mode. The PSEL.n registers can only be configured when the SPIM is disabled. Enabling/disabling is done using register ENABLE on page 564.

To ensure correct behavior, the pins used by the SPIM must be configured in the GPIO peripheral as described in GPIO configuration on page 554 before the SPIM is enabled. Make sure to activate the dedicated peripheral setting of the GPIO pin. See GPIO — General purpose input/output on page 224 for details on how to assign pins between cores, peripherals, or subsystems. For pin recommendations, see Pin assignments on page 790.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| SPI master signal | SPI master pin                      | Direction | Output value        |
|-------------------|-------------------------------------|-----------|---------------------|
| SCK               | As specified in PSEL.SCK on page    | Output    | Same as CONFIG.CPOL |
|                   | 564                                 |           |                     |
| CSN               | As specified in PSEL.CSN on page    | Output    | Same as CONFIG.CPOL |
|                   | 565                                 |           |                     |
| DCX               | As specified in PSELDCX on page 569 | Output    | 1                   |
| MOSI              | As specified in PSEL.MOSI on page   | Output    | 0                   |
|                   | 565                                 |           |                     |
| MISO              | As specified in PSEL.MISO on page   | Input     | Not applicable      |
|                   | 565                                 |           |                     |

Table 143: GPIO configuration

Some SPIM instances do not support automatic control of CSN, and for those the available GPIO pins need to be used to control CSN directly. See <u>Instances</u> on page 556 for information about what features are supported in the various SPIM instances.

The SPIM supports SPI modes 0 through 3. The clock polarity (CPOL) and the clock phase (CPHA) are configured in register CONFIG on page 568.

| Mode      | Clock polarity  | Clock phase  |
|-----------|-----------------|--------------|
|           | CPOL            | СРНА         |
| SPI_MODE0 | 0 (Active High) | 0 (Leading)  |
| SPI_MODE1 | 0 (Active High) | 1 (Trailing) |
| SPI_MODE2 | 1 (Active Low)  | 0 (Leading)  |
| SPI_MODE3 | 1 (Active Low)  | 1 (Trailing) |

Table 144: SPI modes



#### 7.30.4 Shared resources

The SPI shares registers and other resources with other peripherals that have the same ID as the SPI. Therefore, the user must disable all peripherals that have the same ID as the SPI before the SPI can be configured and used.

Disabling a peripheral that has the same ID as the SPI will not reset any of the registers that are shared with the SPI. It is therefore important to configure all relevant SPI registers explicitly to secure that it operates correctly.

See the Instantiation table in Peripherals on page 150 for details on peripherals and their IDs.

## 7.30.5 EasyDMA

SPIM implements EasyDMA for accessing RAM without CPU involvement.

SPIM implements the following EasyDMA channels.

| Channel | Туре   | Register Cluster |
|---------|--------|------------------|
| TXD     | READER | TXD              |
| RXD     | WRITER | RXD              |

Table 145: SPIM EasyDMA Channels

For detailed information regarding the use of EasyDMA, see EasyDMA on page 154.

The .PTR and .MAXCNT registers are double-buffered. They can be updated and prepared for the next transmission immediately after having received the STARTED event.

The SPI master will automatically stop transmitting after TXD.MAXCNT bytes have been transmitted and RXD.MAXCNT bytes have been received. If RXD.MAXCNT is larger than TXD.MAXCNT, the remaining transmitted bytes will contain the value defined in the ORC register. If TXD.MAXCNT is larger than RXD.MAXCNT, the additional received bytes will be discarded.

The ENDRX/ENDTX events indicate that EasyDMA has finished accessing respectively the RX/TX buffer in RAM. The END event gets generated when both RX and TX are finished accessing the buffers in RAM.

If several AHB bus masters try to access the same AHB slave at the same time, AHB bus congestion might occur, and the behavior of the EasyDMA channel will depend on the SPIM instance. Refer to Instances on page 556 for information about what behavior is supported in the various instances.

## 7.30.6 Low power

To ensure lowest possible power consumption when the peripheral is not needed stop and disable SPIM.

The STOP task may not be always needed (the peripheral might already be stopped), but if it is sent, software shall wait until the STOPPED event was received as a response before disabling the peripheral through the ENABLE register.



# 7.30.7 Registers

| Base address             | Domain              | Peripheral | Instance                | Secure mapping | DMA security | Description               | Configuration                |
|--------------------------|---------------------|------------|-------------------------|----------------|--------------|---------------------------|------------------------------|
|                          |                     |            |                         |                |              |                           | Not supported: > 8           |
|                          | APPLICATION         |            |                         |                |              |                           | Mbps data rate, CSNPOL       |
| 0 5000000                |                     |            | CDIMAG C                |                |              |                           | register, DCX functionality, |
|                          |                     | SPIM       | SPIM0 : S               | US             | SA           | SPI master 0              | IFTIMING.x registers,        |
| 0x40008000               |                     |            | SPIM0 : NS              |                |              |                           | hardware CSN control         |
|                          |                     |            |                         |                |              |                           | (PSEL.CSN), stalling         |
|                          |                     |            |                         |                |              |                           | mechanism during AHB         |
|                          |                     |            |                         |                |              |                           | bus contention               |
|                          |                     |            |                         |                |              |                           | Not supported: > 8           |
| 0x50009000<br>0x40009000 |                     |            |                         |                |              |                           | Mbps data rate, CSNPOL       |
|                          |                     |            |                         |                |              |                           | register, DCX functionality, |
|                          | APPLICATION         | SPIM       | SPIM1:S                 | US             | SA           | SPI master 1              | IFTIMING.x registers,        |
|                          |                     |            | SPIM1 : NS              |                |              |                           | hardware CSN control         |
|                          |                     |            |                         |                |              |                           | (PSEL.CSN), stalling         |
| 0x5000A000               |                     |            |                         |                |              |                           | mechanism during AHB         |
|                          |                     |            |                         |                |              |                           | bus contention               |
|                          | APPLICATION         | SPIM       | SPIM4 : S               | US             | SA           | SPI master 4 (high-speed) | Up to 32 Mbps SPI when       |
| 0x4000A000               |                     |            | SPIM4 : NS              |                |              | ( ) .,,                   | using dedicated pins         |
|                          |                     |            |                         |                |              |                           | Not supported: > 8           |
|                          |                     | i spim     | SPIM2 : S<br>SPIM2 : NS | US             | SA           | SPI master 2              | Mbps data rate, CSNPOL       |
|                          |                     |            |                         |                |              |                           | register, DCX functionality, |
| 0x5000B000               | APPLICATION         |            |                         |                |              |                           | IFTIMING.x registers,        |
| 0x4000B000               | 7 II I Elex III OIV |            |                         |                |              |                           | hardware CSN control         |
|                          |                     |            |                         |                |              |                           | (PSEL.CSN), stalling         |
|                          |                     |            |                         |                |              |                           | mechanism during AHB         |
|                          |                     |            |                         |                |              |                           | bus contention               |
|                          |                     |            |                         |                |              |                           | Not supported: > 8           |
|                          |                     |            |                         |                |              |                           | Mbps data rate, CSNPOL       |
|                          |                     |            |                         |                |              |                           | register, DCX functionality, |
| 0x5000C000               | APPLICATION         | CDINA      | SPIM3:S                 | US             | SA           | SPI master 3              | IFTIMING.x registers,        |
| 0x4000C000               | APPLICATION         | SPIIVI     | SPIM3 : NS              | 03             | SA           | SPI Master 3              | hardware CSN control         |
|                          |                     |            |                         |                |              |                           | (PSEL.CSN), stalling         |
|                          |                     |            |                         |                |              |                           | mechanism during AHB         |
|                          |                     |            |                         |                |              |                           | bus contention               |
| 0x41013000               | NETWORK             | SPIM       | SPIM0                   | NS             | NA           | SPI master 0              | Not supported: > 8 Mbps      |
|                          |                     |            |                         |                |              |                           | data rate, IFTIMING.x        |
|                          |                     |            |                         |                |              |                           | registers, hardware CSN      |
|                          |                     |            |                         |                |              |                           | control (PSEL.CSN), stalling |
|                          |                     |            |                         |                |              |                           | mechanism during AHB         |
|                          |                     |            |                         |                |              |                           | bus contention               |
|                          |                     |            |                         |                |              |                           |                              |

Table 146: Instances

| Register        | Offset | Security | Description                            |
|-----------------|--------|----------|----------------------------------------|
| TASKS_START     | 0x010  |          | Start SPI transaction                  |
| TASKS_STOP      | 0x014  |          | Stop SPI transaction                   |
| TASKS_SUSPEND   | 0x01C  |          | Suspend SPI transaction                |
| TASKS_RESUME    | 0x020  |          | Resume SPI transaction                 |
| SUBSCRIBE_START | 0x090  |          | Subscribe configuration for task START |
| SUBSCRIBE_STOP  | 0x094  |          | Subscribe configuration for task STOP  |





| Register          | Offset | Security | Description                                                                            |
|-------------------|--------|----------|----------------------------------------------------------------------------------------|
| SUBSCRIBE_SUSPEND | 0x09C  |          | Subscribe configuration for task SUSPEND                                               |
| SUBSCRIBE_RESUME  | 0x0A0  |          | Subscribe configuration for task RESUME                                                |
| EVENTS_STOPPED    | 0x104  |          | SPI transaction has stopped                                                            |
| EVENTS_ENDRX      | 0x110  |          | End of RXD buffer reached                                                              |
| EVENTS_END        | 0x118  |          | End of RXD buffer and TXD buffer reached                                               |
| EVENTS_ENDTX      | 0x120  |          | End of TXD buffer reached                                                              |
| EVENTS_STARTED    | 0x14C  |          | Transaction started                                                                    |
| PUBLISH_STOPPED   | 0x184  |          | Publish configuration for event STOPPED                                                |
| PUBLISH_ENDRX     | 0x190  |          | Publish configuration for event ENDRX                                                  |
| PUBLISH_END       | 0x198  |          | Publish configuration for event END                                                    |
| PUBLISH_ENDTX     | 0x1A0  |          | Publish configuration for event ENDTX                                                  |
| PUBLISH_STARTED   | 0x1CC  |          | Publish configuration for event STARTED                                                |
| SHORTS            | 0x200  |          | Shortcuts between local events and tasks                                               |
| INTENSET          | 0x304  |          | Enable interrupt                                                                       |
| INTENCLR          | 0x308  |          | Disable interrupt                                                                      |
| STALLSTAT         | 0x400  |          | Stall status for EasyDMA RAM accesses. The fields in this register are set to STALL by |
|                   |        |          | hardware whenever a stall occurres and can be cleared (set to NOSTALL) by the CPU.     |
| ENABLE            | 0x500  |          | Enable SPIM                                                                            |
| PSEL.SCK          | 0x508  |          | Pin select for SCK                                                                     |
| PSEL.MOSI         | 0x50C  |          | Pin select for MOSI signal                                                             |
| PSEL.MISO         | 0x510  |          | Pin select for MISO signal                                                             |
| PSEL.CSN          | 0x514  |          | Pin select for CSN                                                                     |
| FREQUENCY         | 0x524  |          | SPI frequency. Accuracy depends on the HFCLK source selected.                          |
| RXD.PTR           | 0x534  |          | Data pointer                                                                           |
| RXD.MAXCNT        | 0x538  |          | Maximum number of bytes in receive buffer                                              |
| RXD.AMOUNT        | 0x53C  |          | Number of bytes transferred in the last transaction                                    |
| RXD.LIST          | 0x540  |          | EasyDMA list type                                                                      |
| TXD.PTR           | 0x544  |          | Data pointer                                                                           |
| TXD.MAXCNT        | 0x548  |          | Number of bytes in transmit buffer                                                     |
| TXD.AMOUNT        | 0x54C  |          | Number of bytes transferred in the last transaction                                    |
| TXD.LIST          | 0x550  |          | EasyDMA list type                                                                      |
| CONFIG            | 0x554  |          | Configuration register                                                                 |
| IFTIMING.RXDELAY  | 0x560  |          | Sample delay for input serial data on MISO                                             |
| IFTIMING.CSNDUR   | 0x564  |          | Minimum duration between edge of CSN and edge of SCK. When SHORTS.END_START            |
|                   |        |          | is used, this is also the minimum duration CSN must stay high between transactions.    |
| CSNPOL            | 0x568  |          | Polarity of CSN output                                                                 |
| PSELDCX           | 0x56C  |          | Pin select for DCX signal                                                              |
| DCXCNT            | 0x570  |          | DCX configuration                                                                      |
| ORC               | 0x5C0  |          | Byte transmitted after TXD.MAXCNT bytes have been transmitted in the case when         |
|                   |        |          | RXD.MAXCNT is greater than TXD.MAXCNT                                                  |

Table 147: Register overview

# 7.30.7.1 TASKS\_START

Address offset: 0x010 Start SPI transaction





## 7.30.7.2 TASKS STOP

Address offset: 0x014 Stop SPI transaction



## 7.30.7.3 TASKS\_SUSPEND

Address offset: 0x01C Suspend SPI transaction



### 7.30.7.4 TASKS RESUME

Address offset: 0x020 Resume SPI transaction



# 7.30.7.5 SUBSCRIBE\_START

Address offset: 0x090

Subscribe configuration for task START





## 7.30.7.6 SUBSCRIBE\_STOP

Address offset: 0x094

Subscribe configuration for task STOP

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to                   |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.30.7.7 SUBSCRIBE\_SUSPEND

Address offset: 0x09C

Subscribe configuration for task SUSPEND

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task SUSPEND will subscribe to                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.30.7.8 SUBSCRIBE\_RESUME

Address offset: 0x0A0

Subscribe configuration for task RESUME

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|---|
| ID    |          |       |          | В                       | A A A A A A                                                 | Α |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 |
| ID    |          |       |          |                         |                                                             |   |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task RESUME will subscribe to             |   |
| В     | RW       | EN    |          |                         |                                                             |   |
|       |          |       | Disabled | 0                       | Disable subscription                                        |   |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |   |





## 7.30.7.9 EVENTS\_STOPPED

Address offset: 0x104

SPI transaction has stopped

| Bit n | umber   |                |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |                |              |                        | A                                                               |
| Rese  | t 0x000 | 00000          |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |              |                        |                                                                 |
| Α     | RW      | EVENTS_STOPPED |              |                        | SPI transaction has stopped                                     |
|       |         |                | NotGenerated | 0                      | Event not generated                                             |
|       |         |                | Generated    | 1                      | Event generated                                                 |

## 7.30.7.10 **EVENTS\_ENDRX**

Address offset: 0x110

End of RXD buffer reached

| Bit r | umber    |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |          |              |              |                        | А                                                               |
| Rese  | et 0x000 | 00000        |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |              |                        | Description                                                     |
| Α     | RW       | EVENTS_ENDRX |              |                        | End of RXD buffer reached                                       |
|       |          |              | NotGenerated | 0                      | Event not generated                                             |
|       |          |              | Generated    | 1                      | Event generated                                                 |

## 7.30.7.11 EVENTS\_END

Address offset: 0x118

End of RXD buffer and TXD buffer reached

| Bit n | umber   |            |              | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|--------------|-------------------|---------------------------------------------------------------------|
| ID    |         |            |              |                   | A                                                                   |
| Rese  | t 0x000 | 00000      |              | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |            |              |                   |                                                                     |
| Α     | RW      | EVENTS_END |              |                   | End of RXD buffer and TXD buffer reached                            |
|       |         |            | NotGenerated | 0                 | Event not generated                                                 |
|       |         |            | Generated    | 1                 | Event generated                                                     |

## 7.30.7.12 EVENTS\_ENDTX

Address offset: 0x120

End of TXD buffer reached





## 7.30.7.13 EVENTS\_STARTED

Address offset: 0x14C

Transaction started



## 7.30.7.14 PUBLISH STOPPED

Address offset: 0x184

Publish configuration for event STOPPED



## 7.30.7.15 PUBLISH\_ENDRX

Address offset: 0x190

Publish configuration for event ENDRX



# 7.30.7.16 PUBLISH\_END

Address offset: 0x198

Publish configuration for event END





## 7.30.7.17 PUBLISH\_ENDTX

Address offset: 0x1A0

Publish configuration for event ENDTX

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                     |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event ENDTX will publish to.                  |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

## 7.30.7.18 PUBLISH\_STARTED

Address offset: 0x1CC

Publish configuration for event STARTED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event STARTED will publish to.              |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       |          |                         |                                                               |

## 7.30.7.19 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks





## 7.30.7.20 INTENSET

Address offset: 0x304

Enable interrupt

| Bit number       |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|------------------------|------------------------------------------------------------------|
| ID               |          |                        | E D C B A                                                        |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field     |          |                        |                                                                  |
| A RW STOPPED     |          |                        | Write '1' to enable interrupt for event STOPPED                  |
|                  | Set      | 1                      | Enable                                                           |
|                  | Disabled | 0                      | Read: Disabled                                                   |
|                  | Enabled  | 1                      | Read: Enabled                                                    |
| B RW ENDRX       |          |                        | Write '1' to enable interrupt for event ENDRX                    |
|                  | Set      | 1                      | Enable                                                           |
|                  | Disabled | 0                      | Read: Disabled                                                   |
|                  | Enabled  | 1                      | Read: Enabled                                                    |
| C RW END         |          |                        | Write '1' to enable interrupt for event END                      |
|                  | Set      | 1                      | Enable                                                           |
|                  | Disabled | 0                      | Read: Disabled                                                   |
|                  | Enabled  | 1                      | Read: Enabled                                                    |
| D RW ENDTX       |          |                        | Write '1' to enable interrupt for event ENDTX                    |
|                  | Set      | 1                      | Enable                                                           |
|                  | Disabled | 0                      | Read: Disabled                                                   |
|                  | Enabled  | 1                      | Read: Enabled                                                    |
| E RW STARTED     |          |                        | Write '1' to enable interrupt for event STARTED                  |
|                  | Set      | 1                      | Enable                                                           |
|                  | Disabled | 0                      | Read: Disabled                                                   |
|                  | Enabled  | 1                      | Read: Enabled                                                    |

## 7.30.7.21 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit r | umber    |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |          |                         | E D C B A                                                       |
| Rese  | et 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |          |                         |                                                                 |
| Α     | RW       | STOPPED |          |                         | Write '1' to disable interrupt for event STOPPED                |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | ENDRX   |          |                         | Write '1' to disable interrupt for event ENDRX                  |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | END     |          |                         | Write '1' to disable interrupt for event END                    |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| D     | RW       | ENDTX   |          |                         | Write '1' to disable interrupt for event ENDTX                  |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         |          |                         |                                                                 |





#### 7.30.7.22 STALLSTAT

Address offset: 0x400

Stall status for EasyDMA RAM accesses. The fields in this register are set to STALL by hardware whenever a stall occurres and can be cleared (set to NOSTALL) by the CPU.

| Bit n | umber    |       |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |         |                         | B A                                                             |
| Rese  | et 0x000 | 00000 |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |         |                         | Description                                                     |
| Α     | RW       | TX    |         | [10]                    | Stall status for EasyDMA RAM reads                              |
|       |          |       | NOSTALL | 0                       | No stall                                                        |
|       |          |       | STALL   | 1                       | A stall has occurred                                            |
| В     | RW       | RX    |         | [10]                    | Stall status for EasyDMA RAM writes                             |
|       |          |       | NOSTALL | 0                       | No stall                                                        |
|       |          |       |         |                         |                                                                 |

#### 7.30.7.23 ENABLE

Address offset: 0x500

**Enable SPIM** 



## 7.30.7.24 PSEL.SCK

Address offset: 0x508

Pin select for SCK





#### 7.30.7.25 PSEL.MOSI

Address offset: 0x50C

Pin select for MOSI signal



#### 7.30.7.26 PSEL.MISO

Address offset: 0x510

Pin select for MISO signal



## 7.30.7.27 PSEL.CSN

Address offset: 0x514

Pin select for CSN





## 7.30.7.28 FREQUENCY

Address offset: 0x524

SPI frequency. Accuracy depends on the HFCLK source selected.

| Bit n | umber   |           |      | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|------|------------------------|------------------------------------------------------------------|
| ID    |         |           |      | AAAAAA                 | A A A A A A A A A A A A A A A A A A A                            |
| Rese  | t 0x040 | 00000     |      | 0 0 0 0 0 1 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |         |           |      |                        |                                                                  |
| Α     | RW      | FREQUENCY |      |                        | SPI master data rate                                             |
|       |         |           | K125 | 0x02000000             | 125 kbps                                                         |
|       |         |           | K250 | 0x04000000             | 250 kbps                                                         |
|       |         |           | K500 | 0x08000000             | 500 kbps                                                         |
|       |         |           | M1   | 0x10000000             | 1 Mbps                                                           |
|       |         |           | M2   | 0x20000000             | 2 Mbps                                                           |
|       |         |           | M4   | 0x40000000             | 4 Mbps                                                           |
|       |         |           | M8   | 0x80000000             | 8 Mbps                                                           |
|       |         |           | M16  | 0x0A000000             | 16 Mbps                                                          |
|       |         |           | M32  | 0x14000000             | 32 Mbps                                                          |
|       |         |           |      |                        |                                                                  |

#### 7.30.7.29 RXD.PTR

Address offset: 0x534

Data pointer



See the Memory chapter for details about which memories are available for EasyDMA.

## 7.30.7.30 RXD.MAXCNT

Address offset: 0x538

Maximum number of bytes in receive buffer





#### 7.30.7.31 RXD.AMOUNT

Address offset: 0x53C

Number of bytes transferred in the last transaction



#### 7.30.7.32 RXD.LIST

Address offset: 0x540 EasyDMA list type



#### 7.30.7.33 TXD.PTR

Address offset: 0x544

Data pointer

| A     | R    | RW   | PTR   |  |    |     |    |      |     |      |    | Dat | ta p | oint | er   |    |    |      |     |      |    |    |      |   |   |   |   |     |     |   |   |
|-------|------|------|-------|--|----|-----|----|------|-----|------|----|-----|------|------|------|----|----|------|-----|------|----|----|------|---|---|---|---|-----|-----|---|---|
| ID    |      |      |       |  |    |     |    |      |     |      |    |     |      |      |      |    |    |      |     |      |    |    |      |   |   |   |   |     |     |   |   |
| Res   | et 0 | x000 | 00000 |  | 0  | 0   | 0  | 0 (  | 0   | 0    | 0  | 0   | 0    | 0 (  | 0    | 0  | 0  | 0    | 0 ( | 0    | 0  | 0  | 0 0  | 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID    |      |      |       |  | Α  | Α   | Α  | A A  | . Δ | A    | Α  | Α   | Α    | A A  | A A  | Α  | Α  | A    | Δ , | A    | Α  | Α  | ДД   | A | Α | Α | Α | A A | A   | Α | Α |
| Bit r | num  | ber  |       |  | 31 | .30 | 29 | 28 2 | 7 2 | 6 25 | 24 | 23  | 22 2 | 21 2 | 0 19 | 18 | 17 | 16 1 | 5 1 | 4 13 | 12 | 11 | 10 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 |

See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.30.7.34 TXD.MAXCNT

Address offset: 0x548

Number of bytes in transmit buffer



| Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 0 1 0 1 0 0 1 0 0 0 0 0 0 0 0 0 | A RW MAXCNT      | [10xFFFF]              | Maximum number of bytes in transmit buffer                       |
|------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|------------------------------------------------------------------|
| ID A A A A A A A A A A A A A A A A A A A                                                                                           |                  |                        | Description                                                      |
|                                                                                                                                    | Reset 0x00000000 | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| Bit number 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                   | ID               |                        | A A A A A A A A A A A A A A A A A A A                            |
|                                                                                                                                    | Bit number       | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

## 7.30.7.35 TXD.AMOUNT

Address offset: 0x54C

Number of bytes transferred in the last transaction

| Α     | R        | AMOUNT | [10xFFFF]            | Number of bytes transferred in the last transaction                |
|-------|----------|--------|----------------------|--------------------------------------------------------------------|
| ID    |          |        |                      |                                                                    |
| Rese  | et 0x000 | 00000  | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID    |          |        |                      | A A A A A A A A A A A A A A A A A A A                              |
| Bit r | umber    |        | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

## 7.30.7.36 TXD.LIST

Address offset: 0x550 EasyDMA list type

| Bit n | umber   |       |           | 31 30 29 28 27 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|-----------|----------------|------------------------------------------------------------------------|
| ID    |         |       |           |                | A A                                                                    |
| Rese  | t 0x000 | 00000 |           | 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |       |           |                |                                                                        |
| Α     | RW      | LIST  |           |                | List type                                                              |
|       |         |       | Disabled  | 0              | Disable EasyDMA list                                                   |
|       |         |       | ArrayList | 1              | Use array list                                                         |

## 7.30.7.37 CONFIG

Address offset: 0x554 Configuration register

| Bit n | umber            |       |            | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|-------|------------|-------------------------|-----------------------------------------------------------------|
| ID    |                  |       |            |                         | СВА                                                             |
| Rese  | Reset 0x00000000 |       |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                  |       |            |                         |                                                                 |
| Α     | RW               | ORDER |            |                         | Bit order                                                       |
|       |                  |       | MsbFirst   | 0                       | Most significant bit shifted out first                          |
|       |                  |       | LsbFirst   | 1                       | Least significant bit shifted out first                         |
| В     | RW               | СРНА  |            |                         | Serial clock (SCK) phase                                        |
|       |                  |       | Leading    | 0                       | Sample on leading edge of clock, shift serial data on trailing  |
|       |                  |       |            |                         | edge                                                            |
|       |                  |       | Trailing   | 1                       | Sample on trailing edge of clock, shift serial data on leading  |
|       |                  |       |            |                         | edge                                                            |
| С     | RW               | CPOL  |            |                         | Serial clock (SCK) polarity                                     |
|       |                  |       | ActiveHigh | 0                       | Active high                                                     |
|       |                  |       | ActiveLow  | 1                       | Active low                                                      |



#### 7.30.7.38 IFTIMING.RXDELAY

Address offset: 0x560

Sample delay for input serial data on MISO



#### 7.30.7.39 IFTIMING.CSNDUR

Address offset: 0x564

Minimum duration between edge of CSN and edge of SCK. When SHORTS.END\_START is used, this is also the minimum duration CSN must stay high between transactions.



#### 7.30.7.40 CSNPOL

Address offset: 0x568
Polarity of CSN output



#### 7.30.7.41 PSELDCX

Address offset: 0x56C



#### Pin select for DCX signal



#### 7.30.7.42 DCXCNT

Address offset: 0x570

DCX configuration

| Bit n | umber    |        | 31 30 29 28 27 26 | 5 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|-------------------|-----------------------------------------------------------------------|
| ID    |          |        |                   | АААА                                                                  |
| Rese  | et 0x000 | 00000  | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |          |        |                   |                                                                       |
| Α     | RW       | DCXCNT | 0x00xF            | This register specifies the number of command bytes                   |
|       |          |        |                   | preceding the data bytes. The PSEL.DCX line will be low               |
|       |          |        |                   | during transmission of command bytes and high during                  |
|       |          |        |                   | transmission of data bytes. Value 0xF indicates that all              |
|       |          |        |                   | bytes are command bytes.                                              |

#### 7.30.7.43 ORC

Address offset: 0x5C0

Byte transmitted after TXD.MAXCNT bytes have been transmitted in the case when RXD.MAXCNT is greater than TXD.MAXCNT



# 7.30.8 Electrical specification

## 7.30.8.1 Timing specifications

| Symbol                  | Description                                  | Min. | Тур. | Max.             | Units |
|-------------------------|----------------------------------------------|------|------|------------------|-------|
| f <sub>SPIM</sub>       | Bit rates for SPIM <sup>20</sup>             |      |      | 16 <sup>21</sup> | Mbps  |
| t <sub>SPIM,START</sub> | Time from START task to transmission started |      | 1    |                  | μs    |

High bit rates may require GPIOs to be set as High Drive, see GPIO chapter for more details.



<sup>&</sup>lt;sup>21</sup> Application core SPIM4 supports 32 Mbps write speed when running at 128 MHz.

| Symbol                    | Description                                   | Min.                   | Тур. | Max.                  | Units |
|---------------------------|-----------------------------------------------|------------------------|------|-----------------------|-------|
| t <sub>SPIM,CSCK</sub>    | SCK period                                    | 125                    |      |                       | ns    |
| t <sub>SPIM,RSCK,LD</sub> | SCK rise time, standard drive <sup>22</sup>   |                        |      | t <sub>RF,25pF</sub>  |       |
| t <sub>SPIM,RSCK,HD</sub> | SCK rise time, high drive <sup>22</sup>       |                        |      | t <sub>HRF,25pF</sub> |       |
| t <sub>SPIM,FSCK,LD</sub> | SCK fall time, standard drive <sup>22</sup>   |                        |      | t <sub>RF,25pF</sub>  |       |
| t <sub>SPIM,FSCK,HD</sub> | SCK fall time, high drive <sup>22</sup>       |                        |      | t <sub>HRF,25pF</sub> |       |
| t <sub>SPIM,WHSCK</sub>   | SCK high time <sup>22</sup>                   | (t <sub>CSCK</sub> /2) |      |                       |       |
|                           |                                               | - t <sub>RSCK</sub> -  |      |                       |       |
|                           |                                               | 1.5 ns                 |      |                       |       |
| t <sub>SPIM,WLSCK</sub>   | SCK low time <sup>22</sup>                    | (t <sub>CSCK</sub> /2) |      |                       |       |
|                           |                                               | - t <sub>FSCK</sub> -  |      |                       |       |
|                           |                                               | 1.5 ns                 |      |                       |       |
| t <sub>SPIM,SUMI</sub>    | MISO to CLK edge setup time                   | 19                     |      |                       | ns    |
| t <sub>SPIM,HMI</sub>     | CLK edge to MISO hold time                    | 10                     |      |                       | ns    |
| t <sub>SPIM,VMO</sub>     | CLK edge to MOSI valid, SCK frequency ≤ 8 MHz |                        |      | 59                    | ns    |
| t <sub>SPIM,VMO,HS</sub>  | CLK edge to MOSI valid, SCK frequency > 8 MHz |                        |      |                       | ns    |
| t <sub>SPIM,HMO</sub>     | MOSI hold time after CLK edge                 | 10                     |      |                       | ns    |



Figure 200: SPIM timing diagram

# 7.31 SPIS — Serial peripheral interface slave with EasyDMA

SPI slave (SPIS) is implemented with EasyDMA support for ultra-low power serial communication from an external SPI master. EasyDMA in conjunction with hardware-based semaphore mechanisms removes all real-time requirements associated with controlling the SPI slave from a low priority CPU execution context.

NORDIC\*

<sup>&</sup>lt;sup>22</sup> At 25pF load, including GPIO pin capacitance, see GPIO spec.



Figure 201: SPI slave

SPIS supports SPI modes 0 through 3. The CONFIG register allows setting CPOL and CPHA appropriately.

| Mode      | Clock polarity  | Clock phase       |
|-----------|-----------------|-------------------|
|           | CPOL            | СРНА              |
| SPI_MODE0 | 0 (Active High) | 0 (Trailing Edge) |
| SPI_MODE1 | 0 (Active High) | 1 (Leading Edge)  |
| SPI_MODE2 | 1 (Active Low)  | 0 (Trailing Edge) |
| SPI_MODE3 | 1 (Active Low)  | 1 (Leading Edge)  |

Table 148: SPI modes

## 7.31.1 Shared resources

The SPI slave shares registers and other resources with other peripherals that have the same ID as the SPI slave. Therefore, you must disable all peripherals that have the same ID as the SPI slave before the SPI slave can be configured and used.

Disabling a peripheral that has the same ID as the SPI slave will not reset any of the registers that are shared with the SPI slave. It is important to configure all relevant SPI slave registers explicitly to secure that it operates correctly.

The Instantiation table in Peripherals on page 150 shows which peripherals have the same ID as the SPI slave.

## 7.31.2 EasyDMA

SPIS implements EasyDMA for accessing RAM without CPU involvement.

SPIS implements the EasyDMA channels found in the following table.



| Channel | Туре   | Register Cluster |
|---------|--------|------------------|
| TXD     | READER | TXD              |
| RXD     | WRITER | RXD              |

Table 149: SPIS EasyDMA Channels

For detailed information regarding the use of EasyDMA, see EasyDMA on page 154.

If RXD.MAXCNT is larger than TXD.MAXCNT, the remaining transmitted bytes will contain the value defined in the ORC register.

The END event indicates that EasyDMA has finished accessing the buffer in RAM.

## 7.31.3 SPI slave operation

SPI slave uses two memory pointers, RXD.PTR and TXD.PTR, that point to the RXD buffer (receive buffer) and TXD buffer (transmit buffer) respectively. Since these buffers are located in RAM, which can be accessed by both the SPI slave and the CPU, a hardware based semaphore mechanism is implemented to enable safe sharing.

Before the CPU can safely update the RXD.PTR and TXD.PTR pointers it must first acquire the SPI semaphore. The CPU can acquire the semaphore by triggering the ACQUIRE task and then receiving the ACQUIRED event. When the CPU has updated the RXD.PTR and TXD.PTR pointers the CPU must release the semaphore before the SPI slave will be able to acquire it.

The CPU releases the semaphore by triggering the RELEASE task, this is illustrated in SPI transaction when shortcut between END and ACQUIRE is enabled on page 574. Triggering the RELEASE task when the semaphore is not granted to the CPU will have no effect. See Semaphore operation on page 574 for more information

If the CPU is not able to reconfigure the TXD.PTR and RXD.PTR between granted transactions, the same TX data will be clocked out and the RX buffers will be overwritten. To prevent this from happening, the END\_ACQUIRE shortcut can be used. With this shortcut enabled, the semaphore will be handed over to the CPU automatically after the granted transaction has completed, giving the CPU the ability to update the TXPTR and RXPTR between every granted transaction.

The ENDRX event is generated when the RX buffer has been filled.

The RXD.MAXCNT register specifies the maximum number of bytes the SPI slave can receive in one granted transaction. If the SPI slave receives more than RXD.MAXCNT number of bytes, an OVERFLOW will be indicated in the STATUS register and the incoming bytes will be discarded.

The TXD.MAXCNT parameter specifies the maximum number of bytes the SPI slave can transmit in one granted transaction. If the SPI slave is forced to transmit more than TXD.MAXCNT number of bytes, an OVERREAD will be indicated in the STATUS register and the ORC character will be clocked out.

The RXD.AMOUNT and TXD.AMOUNT registers are updated when a granted transaction is completed. The TXD.AMOUNT register indicates how many bytes were read from the TX buffer in the last transaction, that is, ORC (over-read) characters are not included in this number. Similarly, the RXD.AMOUNT register indicates how many bytes were written into the RX buffer in the last transaction.





Figure 202: SPI transaction when shortcut between END and ACQUIRE is enabled

# 7.31.4 Semaphore operation

The semaphore is a mechanism implemented inside the SPI slave that prevents simultaneous access to the data buffers by the SPI slave and CPU.

The semaphore is by default assigned to the CPU after the SPI slave is enabled. No ACQUIRED event will be generated for this initial semaphore handover. An ACQUIRED event will be generated immediately if the ACQUIRE task is triggered while the semaphore is assigned to the CPU. The figure SPI semaphore FSM on page 575 illustrates the transitions between states in the semaphore based on the relevant tasks and events.





Figure 203: SPI semaphore FSM

**Note:** The semaphore mechanism does not, at any time, prevent the CPU from performing read or write access to the RXD.PTR register, the TXD.PTR registers, or the RAM that these pointers are pointing to. The semaphore is only telling when these can be updated by the CPU so that safe sharing is achieved.

The SPI slave will try to acquire the semaphore when STARTED event is detected, the even also indicates that CSN is currently low. If the SPI slave does not manage to acquire the semaphore at this point (i.e., it is under CPU's control), the transaction will be ignored. This means that all incoming data on MOSI will be discarded, and the DEF (default) character will be clocked out on the MISO line throughout the whole transaction. This will also be the case even if the semaphore is released by the CPU during the transaction. In case of a race condition where the CPU and the SPI slave try to acquire the semaphore at the same time, as illustrated in lifeline item 2 in figure SPI transaction when shortcut between END and ACQUIRE is enabled on page 574, the semaphore will be granted to the CPU.

If the SPI slave acquires the semaphore, the transaction will be granted. The incoming data on MOSI will be stored in the RXD buffer and the data in the TXD buffer will be clocked out on MISO.

When a granted transaction is completed and CSN goes high, the SPI slave will automatically release the semaphore and generate the END event.

As long as the semaphore is available, the SPI slave can be granted multiple transactions one after the other.

If the CPU tries to acquire the semaphore while it is assigned to the SPI slave, an immediate handover will not be granted. However, the semaphore will be handed over to the CPU as soon as the SPI slave has released the semaphore after the granted transaction is completed. If the END\_ACQUIRE shortcut is enabled and the CPU has triggered the ACQUIRE task during a granted transaction, only one ACQUIRE request will be served following the END event.

# 7.31.5 Pin configuration

The CSN, SCK, MOSI, and MISO signals associated with the SPI slave are mapped to physical pins according to the configuration specified in the PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers respectively. If the CONNECT field of any of these registers is set to Disconnected, the associated SPI slave signal will not be connected to any physical pins.

The PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO registers and their configurations are only used as long as the SPI slave is enabled, and retained only as long as the device is in System ON mode, see POWER — Power control on page 46 chapter for more information about power modes. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field

NORDIC

and PIN\_CNF[n] register. PSEL.CSN, PSEL.SCK, PSEL.MOSI, and PSEL.MISO must only be configured when the SPI slave is disabled.

To secure correct behavior in the SPI slave, the pins used by the SPI slave must be configured in the GPIO peripheral as described in GPIO configuration before enabling peripheral on page 576 before enabling the SPI slave. This is to secure that the pins used by the SPI slave are driven correctly if the SPI slave itself is temporarily disabled, or if the device temporarily enters System OFF. This configuration must be retained in the GPIO for the selected I/Os as long as the SPI slave is to be recognized by an external SPI master.

The MISO line is set in high impedance as long as the SPI slave is not selected with CSN.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| SPI signal | SPI pin                   | Direction | Output value Comment                                        |
|------------|---------------------------|-----------|-------------------------------------------------------------|
| CSN        | As specified in PSEL.CSN  | Input     | Not applicable                                              |
| SCK        | As specified in PSEL.SCK  | Input     | Not applicable                                              |
| MOSI       | As specified in PSEL.MOSI | Input     | Not applicable                                              |
| MISO       | As specified in PSEL.MISO | Input     | Not applicable Emulates that the SPI slave is not selected. |

Table 150: GPIO configuration before enabling peripheral

## 7.31.6 Registers

| Base address Domain       | Peripheral | Instance   | Secure mapping | DMA security | Description | Configuration |
|---------------------------|------------|------------|----------------|--------------|-------------|---------------|
| 0x50008000<br>APPLICATION | NI CDIC    | SPISO : S  | US             | SA           | SPI slave 0 |               |
| 0x40008000                | N JFIJ     | SPISO : NS | 03             | 3A           | Sri siave o |               |
| 0x50009000 APPLICATION    | NI SDIS    | SPIS1:S    | US             | SA           | SPI slave 1 |               |
| 0x40009000                | N JFIJ     | SPIS1 : NS | 03             | 3A           | Sri siave 1 |               |
| 0x5000B000<br>APPLICATION | NI SDIS    | SPIS2 : S  | US             | SA           | SPI slave 2 |               |
| 0x4000B000                | N 31 13    | SPIS2 : NS | 03             | <i>3</i> A   | SIT SIGVE 2 |               |
| 0x5000C000 APPLICATION    | NI SDIS    | SPIS3 : S  | US             | SA           | SPI slave 3 |               |
| 0x4000C000                | V 31 13    | SPIS3 : NS |                | 57.          | 31131446 3  |               |
| 0x41013000 NETWORK        | SPIS       | SPIS0      | NS             | NA           | SPI slave 0 |               |

Table 151: Instances

| Register          | Offset | Security | Description                                                 |
|-------------------|--------|----------|-------------------------------------------------------------|
| TASKS_ACQUIRE     | 0x024  |          | Acquire SPI semaphore                                       |
| TASKS_RELEASE     | 0x028  |          | Release SPI semaphore, enabling the SPI slave to acquire it |
| SUBSCRIBE_ACQUIRE | 0x0A4  |          | Subscribe configuration for task ACQUIRE                    |
| SUBSCRIBE_RELEASE | 0x0A8  |          | Subscribe configuration for task RELEASE                    |
| EVENTS_END        | 0x104  |          | Granted transaction completed                               |
| EVENTS_ENDRX      | 0x110  |          | End of RXD buffer reached                                   |
| EVENTS_ACQUIRED   | 0x128  |          | Semaphore acquired                                          |
| PUBLISH_END       | 0x184  |          | Publish configuration for event END                         |
| PUBLISH_ENDRX     | 0x190  |          | Publish configuration for event ENDRX                       |
| PUBLISH_ACQUIRED  | 0x1A8  |          | Publish configuration for event ACQUIRED                    |
| SHORTS            | 0x200  |          | Shortcuts between local events and tasks                    |
| INTENSET          | 0x304  |          | Enable interrupt                                            |
| INTENCLR          | 0x308  |          | Disable interrupt                                           |
| SEMSTAT           | 0x400  |          | Semaphore status register                                   |
| STATUS            | 0x440  |          | Status from last transaction                                |
| ENABLE            | 0x500  |          | Enable SPI slave                                            |



| Register   | Offset Security |                                                                             |            |
|------------|-----------------|-----------------------------------------------------------------------------|------------|
| PSEL.SCK   | 0x508           | Pin select for SCK                                                          |            |
| PSEL.MISO  | 0x50C           | Pin select for MISO signal                                                  |            |
| PSEL.MOSI  | 0x510           | Pin select for MOSI signal                                                  |            |
| PSEL.CSN   | 0x514           | Pin select for CSN signal                                                   |            |
| PSELSCK    | 0x508           | Pin select for SCK                                                          | Deprecated |
| PSELMISO   | 0x50C           | Pin select for MISO                                                         | Deprecated |
| PSELMOSI   | 0x510           | Pin select for MOSI                                                         | Deprecated |
| PSELCSN    | 0x514           | Pin select for CSN                                                          | Deprecated |
| RXD.PTR    | 0x534           | RXD data pointer                                                            |            |
| RXD.MAXCNT | 0x538           | Maximum number of bytes in receive buffer                                   |            |
| RXD.AMOUNT | 0x53C           | Number of bytes received in last granted transaction                        |            |
| RXD.LIST   | 0x540           | EasyDMA list type                                                           |            |
| RXDPTR     | 0x534           | RXD data pointer                                                            | Deprecated |
| MAXRX      | 0x538           | Maximum number of bytes in receive buffer                                   | Deprecated |
| AMOUNTRX   | 0x53C           | Number of bytes received in last granted transaction                        | Deprecated |
| TXD.PTR    | 0x544           | TXD data pointer                                                            |            |
| TXD.MAXCNT | 0x548           | Maximum number of bytes in transmit buffer                                  |            |
| TXD.AMOUNT | 0x54C           | Number of bytes transmitted in last granted transaction                     |            |
| TXD.LIST   | 0x550           | EasyDMA list type                                                           |            |
| TXDPTR     | 0x544           | TXD data pointer                                                            | Deprecated |
| MAXTX      | 0x548           | Maximum number of bytes in transmit buffer Deprec                           |            |
| AMOUNTTX   | 0x54C           | Number of bytes transmitted in last granted transaction                     | Deprecated |
| CONFIG     | 0x554           | Configuration register                                                      |            |
| DEF        | 0x55C           | Default character. Character clocked out in case of an ignored transaction. |            |
| ORC        | 0x5C0           | Over-read character                                                         |            |

Table 152: Register overview

# 7.31.6.1 TASKS\_ACQUIRE

Address offset: 0x024
Acquire SPI semaphore



# 7.31.6.2 TASKS\_RELEASE

Address offset: 0x028

Release SPI semaphore, enabling the SPI slave to acquire it







#### 7.31.6.3 SUBSCRIBE\_ACQUIRE

Address offset: 0x0A4

Subscribe configuration for task ACQUIRE



## 7.31.6.4 SUBSCRIBE\_RELEASE

Address offset: 0x0A8

Subscribe configuration for task RELEASE



#### 7.31.6.5 EVENTS END

Address offset: 0x104

Granted transaction completed



## **7.31.6.6 EVENTS ENDRX**

Address offset: 0x110

End of RXD buffer reached



| Bit n | umber   |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                        | А                                                               |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                        |                                                                 |
| Α     | RW      | EVENTS_ENDRX |              |                        | End of RXD buffer reached                                       |
|       |         |              | NotGenerated | 0                      | Event not generated                                             |
|       |         |              | Generated    | 1                      | Event generated                                                 |

# 7.31.6.7 EVENTS\_ACQUIRED

Address offset: 0x128 Semaphore acquired

| Bit r | umber    |                 |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                 |              |                         | А                                                               |
| Rese  | et 0x000 | 00000           |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                 |              |                         | Description                                                     |
| Α     | RW       | EVENTS_ACQUIRED |              |                         | Semaphore acquired                                              |
|       |          |                 | NotGenerated | 0                       | Event not generated                                             |
|       |          |                 | Generated    | 1                       | Event generated                                                 |

# 7.31.6.8 PUBLISH\_END

Address offset: 0x184

Publish configuration for event END

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event END will publish to.                  |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |

# 7.31.6.9 PUBLISH\_ENDRX

Address offset: 0x190

Publish configuration for event ENDRX

| Bit n            | umber |                 |                                   | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8  | 7   | 6 ! | 5 4 | 3   | 2 | 1 0 |
|------------------|-------|-----------------|-----------------------------------|-------------------------|------------------------------------------------|-----|-----|-----|-----|---|-----|
| ID               |       |                 |                                   | В                       |                                                | Α   | Α / | Д Д | Α   | Α | A A |
| Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0                       | 0 (                                            | 0 0 | 0   | 0   | 0 0 |   |     |
| ID               |       |                 |                                   |                         |                                                |     |     |     |     |   |     |
| Α                | RW    | CHIDX           |                                   | [2550]                  | DPPI channel that event ENDRX will publish to. |     |     |     |     |   |     |
| В                | RW    | EN              |                                   |                         |                                                |     |     |     |     |   |     |
|                  |       |                 | Disabled                          | 0                       | Disable publishing                             |     |     |     |     |   |     |
|                  |       |                 | Enabled                           | 1                       | Enable publishing                              |     |     |     |     |   |     |

# 7.31.6.10 PUBLISH\_ACQUIRED

Address offset: 0x1A8



#### Publish configuration for event ACQUIRED



#### 7.31.6.11 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit number |             |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|------------|-------------|----------|-------------------------|-------------------------------------------------------------|-----|
| ID         |             |          |                         | А                                                           |     |
| Reset 0x00 | 000000      |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID R/W     |             |          |                         |                                                             |     |
| A RW       | END_ACQUIRE |          |                         | Shortcut between event END and task ACQUIRE                 |     |
|            |             | Disabled | 0                       | Disable shortcut                                            |     |
|            |             | Enabled  | 1                       | Enable shortcut                                             |     |

#### 7.31.6.12 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber    |          |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |          |          |                        | C B A                                                           |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |          |          |                        | Description                                                     |
| Α     | RW       | END      |          |                        | Write '1' to enable interrupt for event END                     |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |
| В     | RW       | ENDRX    |          |                        | Write '1' to enable interrupt for event ENDRX                   |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW       | ACQUIRED |          |                        | Write '1' to enable interrupt for event ACQUIRED                |
|       |          |          | Set      | 1                      | Enable                                                          |
|       |          |          | Disabled | 0                      | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                      | Read: Enabled                                                   |

#### 7.31.6.13 INTENCLR

Address offset: 0x308

Disable interrupt





| Bit r | umber    |          |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |          |          |                         | C B A                                                           |
| Rese  | et 0x000 | 00000    |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |          |          |                         | Description                                                     |
| Α     | RW       | END      |          |                         | Write '1' to disable interrupt for event END                    |
|       |          |          | Clear    | 1                       | Disable                                                         |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | ENDRX    |          |                         | Write '1' to disable interrupt for event ENDRX                  |
|       |          |          | Clear    | 1                       | Disable                                                         |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | ACQUIRED |          |                         | Write '1' to disable interrupt for event ACQUIRED               |
|       |          |          | Clear    | 1                       | Disable                                                         |
|       |          |          | Disabled | 0                       | Read: Disabled                                                  |
|       |          |          | Enabled  | 1                       | Read: Enabled                                                   |

# 7.31.6.14 SEMSTAT

Address offset: 0x400 Semaphore status register

| Bit r | umber    |         |            | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |            |                         | A A                                                             |
| Rese  | et 0x000 | 00001   |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |            |                         | Description                                                     |
| Α     | R        | SEMSTAT |            |                         | Semaphore status                                                |
|       |          |         | Free       | 0                       | Semaphore is free                                               |
|       |          |         | CPU        | 1                       | Semaphore is assigned to CPU                                    |
|       |          |         | SPIS       | 2                       | Semaphore is assigned to SPI slave                              |
|       |          |         | CPUPending | 3                       | Semaphore is assigned to SPI but a handover to the CPU is       |
|       |          |         |            |                         | pending                                                         |

# 7.31.6.15 STATUS

Address offset: 0x440

Status from last transaction

Note: 1

| Bit n | umber   |          |            | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------|------------|-------------------------|---------------------------------------------------------------|
| ID    |         |          |            |                         | B A                                                           |
| Rese  | t 0x000 | 00000    |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |          |            |                         |                                                               |
| Α     | RW      | OVERREAD |            |                         | TX buffer over-read detected, and prevented                   |
|       |         |          | NotPresent | 0                       | Read: error not present                                       |
|       |         |          | Present    | 1                       | Read: error present                                           |
|       |         |          | Clear      | 1                       | Write: clear error on writing '1'                             |
| В     | RW      | OVERFLOW |            |                         | RX buffer overflow detected, and prevented                    |
|       |         |          | NotPresent | 0                       | Read: error not present                                       |
|       |         |          | Present    | 1                       | Read: error present                                           |
|       |         |          | Clear      | 1                       | Write: clear error on writing '1'                             |





#### 7.31.6.16 ENABLE

Address offset: 0x500

**Enable SPI slave** 



#### 7.31.6.17 PSEL.SCK

Address offset: 0x508
Pin select for SCK



#### 7.31.6.18 PSEL.MISO

Address offset: 0x50C

Pin select for MISO signal



#### 7.31.6.19 PSEL.MOSI

Address offset: 0x510

Pin select for MOSI signal



| Bit n           | umber |                 |                                         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------|-------|-----------------|-----------------------------------------|------------------------|-----------------------------------------------------------------|
| ID              |       |                 |                                         | С                      | ВАААА                                                           |
| Reset 0xFFFFFFF |       | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                        |                                                                 |
| ID              |       |                 |                                         |                        | Description                                                     |
| Α               | RW    | PIN             |                                         | [031]                  | Pin number                                                      |
| В               | RW    | PORT            |                                         | [01]                   | Port number                                                     |
| С               | RW    | CONNECT         |                                         |                        | Connection                                                      |
|                 |       |                 | Disconnected                            | 1                      | Disconnect                                                      |
|                 |       |                 | Connected                               | 0                      | Connect                                                         |

#### 7.31.6.20 PSEL.CSN

Address offset: 0x514

Pin select for CSN signal

| Bit n | umber           |         |                 | 31 30 29 28 27 26 25 24                 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|-----------------|---------|-----------------|-----------------------------------------|-----------------------------------------------------------------|
| ID    |                 |         |                 | С                                       | ВАААА                                                           |
| Rese  | Reset 0xFFFFFFF |         | 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                                                 |
| ID    |                 |         |                 |                                         |                                                                 |
| Α     | RW              | PIN     |                 | [031]                                   | Pin number                                                      |
| В     | RW              | PORT    |                 | [01]                                    | Port number                                                     |
| С     | RW              | CONNECT |                 |                                         | Connection                                                      |
|       |                 |         | Disconnected    | 1                                       | Disconnect                                                      |
|       |                 |         | Connected       | 0                                       | Connect                                                         |

# 7.31.6.21 PSELSCK (Deprecated)

Address offset: 0x508

Pin select for SCK

|           |         | Disconnected | 0xFFF | FFFFF | :      |       |    | Disco | nne | ct    |      |      |       |       |       |      |      |     |   |   |     |            |   |     |
|-----------|---------|--------------|-------|-------|--------|-------|----|-------|-----|-------|------|------|-------|-------|-------|------|------|-----|---|---|-----|------------|---|-----|
| A RW      | PSELSCK |              | [031  | ]     |        |       |    | Pin n | umb | oer c | onfi | gura | tion  | for S | SPI S | CK s | igna | I   |   |   |     |            |   |     |
| ID R/W    |         |              |       |       |        |       |    | Desc  |     |       |      |      |       |       |       |      |      |     |   |   |     |            |   |     |
| Reset 0xF | FFFFFF  |              | 1 1   | 1 1   | 1      | 1 1   | 1  | 1 1   | 1   | 1 :   | 1 1  | 1    | 1 1   | 1     | 1 1   | . 1  | 1    | 1 1 | 1 | 1 | 1 1 | l <b>1</b> | 1 | 1 1 |
| ID        |         |              | A A   | А А   | Α      | АА    | Α  | А А   | Α   | A     | A A  | Α    | А А   | Α     | A A   | A    | Α.   | А А | Α | Α | A A | A A        | Α | А А |
| Bit numbe | r       |              | 31 30 | 29 28 | 3 27 2 | 26 25 | 24 | 23 22 | 21  | 20 1  | 9 18 | 17 : | 16 15 | 14    | 13 1  | 2 11 | 10   | 9 8 | 7 | 6 | 5 4 | 1 3        | 2 | 1 0 |

# 7.31.6.22 PSELMISO (Deprecated)

Address offset: 0x50C Pin select for MISO



# 7.31.6.23 PSELMOSI (Deprecated)

Address offset: 0x510



#### Pin select for MOSI



## 7.31.6.24 PSELCSN (Deprecated)

Address offset: 0x514 Pin select for CSN

| Bit n | umber   |         |              | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|----------------------|------------------------------------------------------------------|
| ID    |         |         |              | A A A A A A          | A A A A A A A A A A A A A A A A A A A                            |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                          |
| ID    |         |         |              |                      |                                                                  |
| Α     | RW      | PSELCSN |              | [031]                | Pin number configuration for SPI CSN signal                      |
|       |         |         | Disconnected | 0xFFFFFFF            | Disconnect                                                       |

#### 7.31.6.25 RXD.PTR

Address offset: 0x534 RXD data pointer

| Α     | RV    | N    | PTR   |     |      |      |            |      |      |    | RX | D d | ata  | poi  | nter |      |    |      |      |    |      |      |   |   |   |   |     |     |   |   |
|-------|-------|------|-------|-----|------|------|------------|------|------|----|----|-----|------|------|------|------|----|------|------|----|------|------|---|---|---|---|-----|-----|---|---|
| ID    |       |      |       |     |      |      |            |      |      |    |    |     |      |      |      |      |    |      |      |    |      |      |   |   |   |   |     |     |   |   |
| Res   | et 0x | 0000 | 00000 | 0   | 0    | 0 (  | 0          | 0    | 0    | 0  | 0  | 0   | 0 (  | 0 (  | 0    | 0    | 0  | 0 (  | 0    | 0  | 0    | 0 0  | 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID    |       |      |       | A   | Α .  | A A  | <b>Α</b> Α | A    | Α    | Α  | Α  | Α   | Α ,  | A A  | A    | Α    | Α  | A A  | A A  | Α  | Α.   | ΑД   | A | Α | Α | Α | A A | A   | Α | Α |
| Bit r | numb  | oer  |       | 313 | 30 2 | 29 2 | 8 27       | 7 26 | 5 25 | 24 | 23 | 22  | 21 2 | 20 1 | 9 18 | 3 17 | 16 | 15 1 | 4 13 | 12 | 11 1 | 10 9 | 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 |

See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.31.6.26 RXD.MAXCNT

Address offset: 0x538

Maximum number of bytes in receive buffer

| Α     | RW       | MAXCNT | [10   | FFFF] |         |        | М     | axim   | num r | numb  | er of | byte | es in | rece | ive  | buff | er  |   |   |   |     |     |   |   |
|-------|----------|--------|-------|-------|---------|--------|-------|--------|-------|-------|-------|------|-------|------|------|------|-----|---|---|---|-----|-----|---|---|
| ID    |          |        |       |       |         |        |       |        |       |       |       |      |       |      |      |      |     |   |   |   |     |     |   |   |
| Rese  | et 0x000 | 00000  | 0 0   | 0 0   | 0 0     | 0 0    | 0 0   | 0      | 0 0   | 0 0   | 0     | 0 0  | 0     | 0 (  | 0    | 0    | 0 0 | 0 | 0 | 0 | 0 ( | 0   | 0 | 0 |
| ID    |          |        |       |       |         |        |       |        |       |       |       | Δ    | A     | Α ,  | A A  | Α    | А А | Α | Α | Α | A A | A A | Α | Α |
| Bit r | number   |        | 31 30 | 29 28 | 8 27 20 | 6 25 2 | 24 23 | 3 22 2 | 21 20 | 19 18 | 8 17  | 16 1 | 5 14  | 13 1 | 2 11 | . 10 | 9 8 | 7 | 6 | 5 | 4 3 | 3 2 | 1 | 0 |

## 7.31.6.27 RXD.AMOUNT

Address offset: 0x53C

Number of bytes received in last granted transaction





#### 7.31.6.28 RXD.LIST

Address offset: 0x540
EasyDMA list type



## 7.31.6.29 RXDPTR (Deprecated)

Address offset: 0x534 RXD data pointer



See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.31.6.30 MAXRX (Deprecated)

Address offset: 0x538

Maximum number of bytes in receive buffer



## 7.31.6.31 AMOUNTRX (Deprecated)

Address offset: 0x53C

Number of bytes received in last granted transaction

NORDIC\*



#### 7.31.6.32 TXD.PTR

Address offset: 0x544

TXD data pointer



See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.31.6.33 TXD.MAXCNT

Address offset: 0x548

Maximum number of bytes in transmit buffer



#### 7.31.6.34 TXD.AMOUNT

Address offset: 0x54C

Number of bytes transmitted in last granted transaction

| Α     | R        | AMOUNT | [10xFFFF]                 | Number of bytes transmitted in last granted transaction       |
|-------|----------|--------|---------------------------|---------------------------------------------------------------|
| ID    |          |        |                           | Description                                                   |
| Rese  | et 0x000 | 00000  | 0 0 0 0 0 0 0 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |          |        |                           | A A A A A A A A A A A A A A A A                               |
| Bit r | number   |        | 31 30 29 28 27 26 25 24 2 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 7.31.6.35 TXD.LIST

Address offset: 0x550

EasyDMA list type





## 7.31.6.36 TXDPTR (Deprecated)

Address offset: 0x544

TXD data pointer

| A     | RW       | TXDPTR |    |       |      |    |      |      | Т   | XD  | dat | ta p | oin | ter |    |      |     |      |    |     |      |   |   |   |   |     |   |   | _ |
|-------|----------|--------|----|-------|------|----|------|------|-----|-----|-----|------|-----|-----|----|------|-----|------|----|-----|------|---|---|---|---|-----|---|---|---|
| ID    |          |        |    |       |      |    |      |      |     |     |     |      |     |     |    |      |     |      |    |     |      |   |   |   |   |     |   |   |   |
| Res   | et 0x000 | 00000  | 0  | 0 0   | 0    | 0  | 0    | 0 (  | 0 ( | 0   | 0   | 0    | 0   | 0   | 0  | 0    | 0 ( | 0    | 0  | 0   | 0 0  | 0 | 0 | 0 | 0 | 0 ( | 0 | 0 | 0 |
| ID    |          |        | Α  | А А   | A    | Α  | Α .  | A ,  | Δ , | Δ Δ | Α Α | AA   | Α   | Α   | Α  | A    | 4 4 | A    | Α  | Α   | A A  | A | Α | Α | Α | A A | A | Α | Α |
| Bit r | number   |        | 31 | 30 29 | 9 28 | 27 | 26 2 | 25 2 | 4 2 | 3 2 | 2 2 | 1 20 | 19  | 18  | 17 | 16 1 | 5 1 | 4 13 | 12 | 11: | 10 9 | 8 | 7 | 6 | 5 | 4 3 | 2 | 1 | 0 |

See the Memory chapter for details about which memories are available for EasyDMA.

## 7.31.6.37 MAXTX (Deprecated)

Address offset: 0x548

Maximum number of bytes in transmit buffer



## 7.31.6.38 AMOUNTTX (Deprecated)

Address offset: 0x54C

Number of bytes transmitted in last granted transaction



#### 7.31.6.39 CONFIG

Address offset: 0x554 Configuration register



| Rit n | umber    |       |            | 21 20 20 29 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|------------|------------------------|-----------------------------------------------------------------|
|       | iuiiibei |       |            |                        |                                                                 |
| ID    |          |       |            |                        | СВА                                                             |
| Rese  | et 0x000 | 00000 |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |       |            |                        |                                                                 |
| Α     | RW       | ORDER |            |                        | Bit order                                                       |
|       |          |       | MsbFirst   | 0                      | Most significant bit shifted out first                          |
|       |          |       | LsbFirst   | 1                      | Least significant bit shifted out first                         |
| В     | RW       | СРНА  |            |                        | Serial clock (SCK) phase                                        |
|       |          |       | Leading    | 0                      | Sample on leading edge of clock, shift serial data on trailing  |
|       |          |       |            |                        | edge                                                            |
|       |          |       | Trailing   | 1                      | Sample on trailing edge of clock, shift serial data on leading  |
|       |          |       |            |                        | edge                                                            |
| С     | RW       | CPOL  |            |                        | Serial clock (SCK) polarity                                     |
|       |          |       | ActiveHigh | 0                      | Active high                                                     |
|       |          |       | ActiveLow  | 1                      | Active low                                                      |

#### 7.31.6.40 DEF

Address offset: 0x55C

Default character. Character clocked out in case of an ignored transaction.

| Bit r | number   |       | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|----------|-------|------------------|---------------------------------------------------------------------|
| ID    |          |       |                  | A A A A A A A A A A A A A A A A A A A                               |
| Res   | et 0x000 | 00000 | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |          |       |                  |                                                                     |
| Α     | RW       | DEF   |                  | Default character. Character clocked out in case of an              |
|       |          |       |                  | ignored transaction.                                                |

#### 7.31.6.41 ORC

Address offset: 0x5C0

Over-read character

| Bit r | umber    |        | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|----------------------|------------------------------------------------------------------|
| ID    |          |        |                      | A A A A A A A                                                    |
| Res   | et 0x000 | 000000 | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |          |        |                      |                                                                  |
| Α     | RW       | ORC    |                      | Over-read character. Character clocked out after an over-        |
|       |          |        |                      | read of the transmit buffer.                                     |

# 7.31.7 Electrical specification

# 7.31.7.1 SPIS slave interface electrical specifications

| Symbol                  | Description                                             | Min. | Тур. | Max.            | Units |
|-------------------------|---------------------------------------------------------|------|------|-----------------|-------|
| f <sub>SPIS</sub>       | Bit rates for SPIS <sup>23</sup>                        |      |      | 8 <sup>24</sup> | Mbps  |
| t <sub>SPIS,START</sub> | Time from RELEASE task to receive/transmit (CSN active) |      |      |                 | μs    |

High bit rates may require GPIOs to be set as High Drive, see GPIO chapter for more details.



The actual maximum data rate depends on the master's CLK to MISO and MOSI setup and hold timings.

# 7.31.7.2 Serial Peripheral Interface Slave (SPIS) timing specifications

| Symbol                    | Description                        | Min.               | Тур. | Max. | Units |
|---------------------------|------------------------------------|--------------------|------|------|-------|
| t <sub>SPIS,CSCKIN</sub>  | SCK input period                   | 125                |      |      | ns    |
| t <sub>SPIS,RFSCKIN</sub> | SCK input rise/fall time           |                    |      | 30   | ns    |
| t <sub>SPIS,WHSCKIN</sub> | SCK input high time                | 30                 |      |      | ns    |
| t <sub>SPIS,WLSCKIN</sub> | SCK input low time                 | 30                 |      |      | ns    |
| t <sub>SPIS,SUCSN</sub>   | CSN to CLK setup time              | 1000 <sup>25</sup> |      |      | ns    |
| t <sub>SPIS,HCSN</sub>    | CLK to CSN hold time               | 1000               |      |      | ns    |
| t <sub>SPIS,ASA</sub>     | CSN to MISO driven                 |                    |      | 68   | ns    |
| t <sub>SPIS,ASO</sub>     | CSN to MISO valid <sup>26</sup>    | 1000               |      |      | ns    |
| t <sub>SPIS,DISSO</sub>   | CSN to MISO disabled <sup>26</sup> |                    |      | 68   | ns    |
| t <sub>SPIS,CWH</sub>     | CSN inactive time                  | 300                |      |      | ns    |
| t <sub>SPIS,VSO</sub>     | CLK edge to MISO valid             |                    |      | 31   | ns    |
| t <sub>SPIS,HSO</sub>     | MISO hold time after CLK edge      | 13                 |      |      | ns    |
| t <sub>SPIS,SUSI</sub>    | MOSI to CLK edge setup time        | 19                 |      |      | ns    |
| t <sub>SPIS,HSI</sub>     | CLK edge to MOSI hold time         | 10                 |      |      | ns    |





Figure 204: SPIS timing diagram

Excluding any start-up delay for the high frequency clock in low power mode.
 At 25pF load, including GPIO capacitance, see GPIO spec.



Figure 205: Common SPIM and SPIS timing diagram

# 7.32 SPU — System protection unit

SPU is the central point in the system to control access to memories, peripherals and other resources.

The main features of SPU are the following:

- Arm TrustZone support, allowing definition of secure, non-secure and non-secure callable memory regions
- Extended Arm TrustZone, protecting memory regions and peripherals from non-CPU devices like EasyDMA transfer
- Pin access protection, preventing non-secure code and peripherals from accessing secure pin resources
- DPPI access protection, realized by preventing non-secure code and peripherals to publish from or subscribe to secured DPPI channels
- External domain access protection, controlling access rights from other MCUs

# 7.32.1 General concepts

SPU provides a register interface to control the various internal logic blocks that monitor access to memory-mapped slave devices (RAM, flash, peripherals, etc) and other resources (device pins, DPPI channels, etc).

For memory-mapped devices like RAM, flash, and peripherals, the internal logic checks the address and attributes (e.g. read, write, execute, secure) of the incoming transfer to block it if necessary. A secure resource can be accessed by a given master based on the following factors:

- *CPU-type master* By the security state of the CPU and the security state reported by SPU, for the address in the bus transfer.
- Non-CPU master By the security attribute of the master that initiates the transfer, defined by a SPU register.

The Simplified view of SPU protection on page 591 shows a simplified view of the SPU registers controlling several internal modules.





Figure 206: Simplified view of SPU protection

The protection logic implements a read-as-zero/write-ignore (RAZ/WI) policy where the following are true:

- A blocked read operation will always return a zero value on the bus, preventing information leak.
- A write operation to a forbidden region or peripheral will be ignored.

An error is reported through dedicated error signals. For security state violations from an M33 master this will be a SecureFault exception, for other violations this will be an SPU event. The SPU event can be configured to generate an interrupt towards the CPU.

Other resources like pins and DPPI channels are protected by comparing the security attributes of the protected resource with the security attribute of the peripheral that wants to access it. SPU is the only place where those security attributes can be configured.

## 7.32.1.1 Special considerations for Arm TrustZone for Cortex-M enabled system

SPU also controls custom logic for an Arm TrustZone for Cortex-M enabled CPU.

Custom logic is shown as the implementation defined attribution unit (IDAU) in figure Simplified view of SPU protection on page 591. Full support is provided for the following:

- Arm TrustZone for Cortex-M related instructions, like test target (TT) for reporting the security attributes of a region
- Non-secure callable (NSC) regions, to implement secure entry points from non-secure code

SPU provides the necessary registers to configure the security attributes for memory regions and peripherals. However, as a requirement to use SPU, the secure attribution unit (SAU) needs to be disabled and all memory set as non-secure in the Arm core. This will allow SPU to control the IDAU and set the security attribution of all addresses as originally intended.

#### 7.32.2 Flash access control

The flash memory space is divided into 64 regions of 16 KiB, each with configurable permissions settings.

For each region, the following types of permissions can be configured:

#### Read

Allows data read access to the region. The code fetch from this region is not controlled by the read permission but by the execute permission described below.

NORDIC

#### Write

Allows write or page erase access to the region.

#### **Execute**

Allows code fetch from this region, even if data read is disabled.

#### Secure

Allows only bus accesses with the security attribute set to access the region.

Permissions can be set independently. For example, it is possible to configure a flash region to be accessible only through secure transfer, being read-only (no write allowed) and non-executable (no code fetch allowed). For each region, permissions can be set and then locked by using the FLASHREGION[n].PERM.LOCK bit, to prevent subsequent modifications.

The debugger can step through execute-protected memory regions.

The following figure shows the N=64 flash regions, each of size 16 KiB.

# **UICR** Always secure **FICR SPU** registers Region #N-1 Region #n Region size **Entire** Access control flash Region #1 Region #0 Access error Data bus Address and control signals (write) Data bus Master identification (read) Error reporting Bus error Events System bus

Flash address space

Figure 207: Flash memory regions

## 7.32.2.1 Non-secure callable (NSC) region definition in flash

SPU provides support for the definition of non-secure callable (NSC) sub-regions to allow non-secure to secure function calls.

A non-secure callable sub-region can only exist within an existing secure region and its definition is done using the following registers:



- FLASHNSC[n].REGION, used to select the secure region that will contain the NSC sub-region
- FLASHNSC[n].SIZE, used to define the size of the NSC sub-region within the secure region

The NSC sub-region will be defined starting with the highest address in that region and descending. The following figure illustrates the NSC sub-regions and the registers used for their definition.



Figure 208: Non-secure callable region definition in the flash memory space

The NSC sub-region will only be defined when the following are true:

- FLASHNSC[i].SIZE value is non zero
- FLASHNSC[i].REGION defines a secure region

If FLASHNSC[i].REGION and FLASHNSCj].REGION have the same value, there is only one sub-region defined as NSC, with the size given by the maximum of FLASHNSC[i].SIZE and FLASHNSC[j].SIZE.

If FLASHNSC[i].REGION defines a non-secure region, then there is no non-secure callable region defined and the selected region stays non-secure.

#### 7.32.2.2 Flash access error reporting

SPU and the logic controlled by it will respond with a certain behavior once an access violation is detected.

The following actions will happen once the logic controlled by SPU detects an access violation on one of the flash ports:

- · The faulty transfer will be blocked.
- In case of a read transfer, the bus will be driven to zero.
- If supported by the master, feedback will be sent to the master through specific bus error signals. At the same time, SPU will receive an event that can optionally trigger a CPU interrupt.
- A SecureFault exception will be triggered if a security violation is detected for access from the CPU.
- A BusFault exception will be triggered when a read/write/execute protection violation is detected from the CPU.
- The FLASHACCERR event will be triggered if any access violations are detected for all master types except for the CPU security violation.

NORDIC\*

The following table summarizes the SPU behavior based on the type of initiator and access violation.

| Master type    | Security violation        | Read/Write/Execute protection violation |
|----------------|---------------------------|-----------------------------------------|
| Arm Cortex-M33 | SecureFault exception     | BusFault exception, FLASHACCERR event   |
| EasyDMA        | RAZ/WI, FLASHACCERR event | RAZ/WI, FLASHACCERR event               |
| Other masters  | RAZ/WI, FLASHACCERR event | RAZ/WI, FLASHACCERR event               |

Table 153: Error reporting for flash access errors

For the Arm Cortex-M33 master, the SecureFault exception will take precedence over the BusFault exception if a security violation occurs simultaneously with another type of violation.

#### 7.32.2.3 UICR and FICR protections

The user information configuration registers (UICR) and factory information configuration registers (FICR) are always considered as secure. FICR registers are read-only. UICR registers can be read and written by secure code only.

Writing new values to user information configuration registers must follow the procedure described in NVMC — Non-volatile memory controller on page 334. Code execution from FICR and UICR address spaces will always be reported as an access violation except during a debug session.

#### 7.32.3 RAM access control

The RAM memory space is divided into 64 regions of 8 KiB, each with configurable permissions settings. For each region, the following types of permissions can be configured:

#### Read

Allows data read access to the region. Code fetch from this region is not controlled by the read permission but by the execute permission described below.

#### Write

Allows write access to the region.

#### **Execute**

Allows code fetch from this region.

#### Secure

Allows only bus accesses with the security attribute set to access the region.

Permissions can be set independently. For example, it is possible to configure a RAM region to be accessible only through secure transfer, being read-only (no write allowed) and non-executable (no code fetch allowed). For each region, permissions can be set and then locked to prevent subsequent modifications by using the RAMREGION[n].PERM.LOCK bit.

The following figure shows the RAM memory space divided into N=64 regions, each of 8 KiB.





Figure 209: RAM memory regions

#### 7.32.3.1 Non-secure callable (NSC) region definition in RAM

SPU provides support for the definition of non-secure callable (NSC) sub-regions to allow non-secure to secure function calls.

A non-secure callable sub-region can only exist within an existing secure region. It is defined by the following registers:

- RAMNSC[n].REGION, used to select the secure region that will contain the NSC sub-region
- RAMNSC[n].SIZE, used to define the size of the NSC sub-region within the secure region

The NSC sub-region will be defined starting with the highest address in that region and descending. The following figure shows the NSC sub-regions and the registers used for their definition.





Figure 210: Non-secure callable region definition in the RAM memory space

The NSC sub-region will only be defined when the following are true:

- RAMNSC[i].SIZE value is non zero
- RAMNSC[i].REGION defines a secure region

If RAMNSC[i].REGION and RAMNSC[j].REGION have the same value, there is only one sub-region defined as NSC, with the size given by the maximum of RAMNSC[i].SIZE and RAMNSC[j].SIZE.

If RAMNSC[i].REGION defines a non-secure region, then there is no non-secure callable region defined and the selected region stays non-secure.

#### 7.32.3.2 RAM access error reporting

SPU and the logic it controls will respond with a certain behavior once an access violation is detected.

The following actions will happen once the logic controlled by the SPU detects an access violation on one of the RAM ports:

- · The faulty transfer will be blocked.
- In case of a read transfer, the bus will be driven to zero.
- If supported by the master, feedback will be sent to the master through specific bus error signals.
- A SecureFault exception will be triggered if security violation is detected for access from Arm Cortex-M33
- A BusFault exception will be triggered when read/write/execute protection violation is detected for Arm Cortex-M33. The SPU will also generate an event that can optionally trigger an interrupt towards the CPU.
- The RAMACCERR event will be triggered if any access violations are detected for all master types but for Arm Cortex-M33 security violation

The following table summarizes the SPU behavior based on the type of initiator and access violation.



| Master type    | Security violation      | Read/Write/Execute protection violation |
|----------------|-------------------------|-----------------------------------------|
| Arm Cortex-M33 | SecureFault exception   | BusFault exception, RAMACCERR event     |
| EasyDMA        | RAZ/WI, RAMACCERR event | RAZ/WI, RAMACCERR event                 |
| Other masters  | RAZ/WI, RAMACCERR event | RAZ/WI, RAMACCERR event                 |

Table 154: Error reporting for RAM access errors

For the Arm Cortex-M33 master, the SecureFault exception will take precedence over the BusFault exception if a security violation occurs simultaneously with another type of violation.

## 7.32.4 Peripheral access control

Access controls are defined by the characteristics of the peripheral.

Peripherals can have their security attribute set as one of the following:

#### Always secure

For a peripheral related to system control.

#### Always non-secure

For some general-purpose peripherals.

#### Configurable

For general-purpose peripherals that may be configured for secure only access.

The full list of peripherals and their corresponding security attributes can be found in Memory on page 19. For each peripheral with ID n, PERIPHID[n]. PERM will show whether the security attribute for this peripheral is configurable or not.

If not hardcoded, the security attribute can configured using the PERIPHID[id].PERM.

At reset, all user-selectable and split security peripherals are set to be secure with secure DMA where present.

Secure code can access both secure peripherals and non-secure peripherals.

## 7.32.4.1 Peripherals with split security

Peripherals with split security are defined to handle use-cases when both secure and non-secure code needs to control the same resource.

When peripherals with split security have their security attribute set to non-secure, access to specific registers and bitfields within some registers is dependent on the security attribute of the bus transfer. For example, some registers will not be accessible for a non-secure transfer.

When peripherals with split security have their security attribute set to secure, then only secure transfers can access their registers.

See Peripherals on page 150 for an overview of split security peripherals. Respective peripheral chapters explain the specific security behavior of each peripheral.

## 7.32.4.2 Peripheral address mapping

Peripherals that have non-secure security mapping have their address starting with 0x4XXXXXXXX. Peripherals that have secure security mapping have their address starting with 0x5XXXXXXXX.

Peripherals with a user-selectable security mapping are available at an address starting with the following:

- 0x4XXXXXXX, if the peripheral security attribute is set to non-secure
- 0x5XXXXXXX, if the peripheral security attribute is set to secure



#### Note:

Access to a secure peripheral using the 0x4XXXXXXX address range will result in bus error, regardless if the CPU is executing secure or non-secure code.

Similarly, a CPU running secure code attempting to access a non-secure peripheral using the 0x5XXXXXXX address range will result in bus error.

Peripherals with a split security mapping are available at an address starting with the following:

- 0x4XXXXXXX for non-secure access and 0x5XXXXXXX for secure access, if the peripheral security attribute is set to non-secure
  - Secure registers in the 0x4XXXXXXX range are not visible for secure or non-secure code, and an attempt to access such a register will result in write-ignore, read-as-zero behavior
  - Secure code can access both non-secure and secure registers in the 0x5XXXXXXX range
- 0x5XXXXXXX, if the peripheral security attribute is set to secure

Any attempt to access the 0x50000000 to 0x5FFFFFFF address range from non-secure code will be ignored and generate a SecureFault exception.

The following table contains the address mapping for the three peripheral types in each configuration.

| Security-features and configuration                  | Mapped at 0x4XXXXXXXX         | Mapped at 0x5XXXXXXXX? |
|------------------------------------------------------|-------------------------------|------------------------|
| Secure peripheral                                    | No                            | Yes                    |
| Non-secure peripheral                                | Yes                           | No                     |
| Split-security peripheral, with attribute=secure     | No                            | Yes                    |
| Split-security peripheral, with attribute=non-secure | Yes, restricted functionality | Yes                    |

Table 155: Peripheral's address mapping in relation to its security-features and configuration

#### 7.32.4.3 Special considerations for peripherals with DMA master

Peripherals containing a DMA master can be configured so the security attribute of the DMA transfers is different from the security attribute of the peripheral itself. This allows a secure peripheral to do non-secure data transfers to or from the system memories.

The following conditions must be met:

- The DMA field of PERIPHID[n].PERM.SECURITYMAPPING should read as "SeparateAttribute"
- The peripheral itself should be secure (PERIPHID[n].PERM.SECATTR == 1)

Then it is possible to select the security attribute of the DMA transfers using the field DMASEC (PERIPHID[n].PERM.DMASEC == Secure and PERIPHID[n].PERM.DMASEC == NonSecure) in PERIPHID[n].PERM.

#### 7.32.4.4 Peripheral access error reporting

Peripherals send error reports once access violation is detected.

The following actions will happen if the logic controlled by the SPU detects an access violation on one of the peripherals:

- The faulty transfer will be blocked.
- In case of a read transfer, the bus will be driven to zero.
- If supported by the master, feedback is sent to the master through specific bus error signals. If the master is a processor supporting Arm TrustZone for Cortex-M, a SecureFault exception will be generated for security related errors.
- The PERIPHACCERR event will be triggered.



#### 7.32.5 Pin access control

Access to device pins can be controlled by SPU. A pin can be declared as secure so that only secure peripherals or secure code can access it. Pins declared as non-secure can be accessed by both secure and non-secure peripherals or code.

The security attribute of each pin can be individually configured in SPU's GPIOPORT[n].PERM register. When the secure attribute is set for a pin, only peripherals that have the secure attribute set will be able to read the value of the pin or change it.

Peripherals can select the pins they need access to through their PSEL registers. If a peripheral has its attribute set to non-secure, but one of its PSEL registers selects a pin with the attribute set to secure, the SPU controlled logic will ensure that the pin selection is not propagated. In addition, the pin value will always be read as zero, to prevent a non-secure peripheral from obtaining a value from a secure pin. Access to other pins with attribute set as non-secure will not be blocked.

Pins can be assigned to other domains than the application domain by changing the MCUSEL value in the GPIO PIN\_CNF[n] register. Domains that do not have a pin assigned to them cannot control a pin or read its status. Any pin configuration set in a domain that doesn't have ownership of that pin will not take effect until the MCUSEL is updated to assign that pin to the domain. Within each domain, pin access is controlled by that domain's local security configuration and peripheral PSEL registers. This is illustrated in the following figure:

The SPU setting will still count when the APP domain accesses its local GPIO peripheral, as local registers are still writable even though MCUSEL is set to a different domain. Any changes in the APP GPIO peripheral done to a GPIO controlled by another domain will not affect the GPIO pad until MCUSEL is changed to APP.



Figure 211: Pin access for domains other than the application domain

#### 7.32.6 DPPI access control

Access to DPPI channels can be restricted. A channel can be declared as secure so that only secure peripherals can access it.

The security attribute of a DPPI channel is configured in DPPI[n].PERM (n=0..0) on page 609. When the secure attribute is set for a channel, only peripherals that have the secure attribute set will be able to publish events to this channel or subscribe to this channel to receive tasks.

The DPPI controller peripheral (DPPIC) is a split security peripheral, i.e., its security behavior depends on the security attributes of both the DPPIC and the accessing party. See Special considerations regarding the DPPIC configuration registers on page 600 for more information about the DPPIC security behavior.

If a non-secure peripheral wants to publish an event on a secure DPPI channel, the channel will ignore the event. If a non-secure peripheral subscribes to a secure DPPI channel, it will not receive any events from

this channel. The following figure illustrates the principle of operation of the security logic for a subscribed channel:



Figure 212: Subscribed channel security concept

No error reporting mechanism is associated with the DPPI access control logic.

## 7.32.6.1 Special considerations regarding the DPPIC configuration registers

DPPI channels can be enabled, disabled and grouped through the DPPI controller (DPPIC). The DPPIC is a split-security peripheral, and handles both secure and non-secure accesses.

A non-secure peripheral access will only be able to configure and control DPPI channels defined as non-secure in SPU's DPPI[n].PERM register(s). A secure peripheral access can control all DPPI channels, independently of the configuration in the DPPI[n].PERM register(s).

The DPPIC allows the creation of group of channels to be able to enable or disable all channels within a group simultaneously. The security attribute of a group of channels (secure or non-secure) is defined as follows:

- If all channels (enabled or not) in the group are non-secure, then the group is considered non-secure
- If at least one of the channels (enabled or not) in the group is secure, then the group is considered secure

A non-secure access to a DPPIC register, or a bitfield controlling a channel marked as secure in DPPI[n].PERM register(s), will be ignored:

- · Write accesses will have no effect
- Read will always return a zero value

No exceptions are thrown when a non-secure access targets a register or bitfield controlling a secure channel. For example, if the bit i is set in the DPPI[n].PERM register (declaring the DPPI channel i as secure), then:

 Non-secure write accesses to registers CHEN, CHENSET and CHENCLR will not be able to write to bit i of those registers



- Non-secure write accesses to registers TASK\_CHG[j].EN and TASK\_CHG[j].DIS will be ignored if the
  channel group j contains at least one channel defined as secure (it can be the channel i itself or any
  channel declared as secured)
- Non-secure read accesses to registers CHEN, CHENSET and CHENCLR will always read zero for the bit at position i

For the channel configuration registers (DPPIC.CHG[n]), access from non-secure code is only possible if the included channels are all non-secure, whether the channels are enabled or not. If a DPPIC.CHG[g] register included one or more secure channels, then the group g is considered as secure and only a secure transfer can read or write DPPIC.CHG[g]. A non-secure write will be ignored and a non-secure read will return zero.

The DPPIC can subscribe to secure or non-secure channels through SUBSCRIBE\_CHG[n] registers in order to trigger task for enabling or disabling groups of channels. But an event from a non-secure channel will be ignored if the group subscribing to this channel is secure. An event from a secure channel can trigger both secure and non-secure tasks.

#### 7.32.7 External domain access control

Other domains with their own CPUs can access peripherals, flash and RAM memories. The SPU allows controlling accesses from those bus masters.

The external domains can access application MCU memories and peripherals. External domains are assigned security attributes as described in register EXTDOMAIN[n].PERM.

| Domain      | Capability register                                       | Permission register                                 |
|-------------|-----------------------------------------------------------|-----------------------------------------------------|
| Network MCU | EXTDOMAIN[n].PERM (n=00) on page 608, SECUREMAPPING field | EXTDOMAIN[n].PERM (n=00) on page 608, SECATTR field |

Table 156: Register mapping for external domains

The figure below illustrates how the security control units are used to assign security attributes to transfers initiated by the external domains:





Figure 213: Access control from external domains

# 7.32.8 Arm TrustZone for Cortex-M ID allocation

Flash and RAM regions, as well as non-secure and secure peripherals, are assigned unique Arm TrustZone IDs.

The Arm TrustZone ID should not be mistaken for the peripheral ID used to identify peripherals.

The following table lists the Arm TrustZone ID allocation.



| Regions                | Arm TrustZone Cortex-M ID |
|------------------------|---------------------------|
| Flash regions 063      | 063                       |
| RAM regions 063        | 64127                     |
| UICR                   | 252                       |
| FICR                   | 252                       |
| CACHEDATA              | 252                       |
| CACHEINFO              | 252                       |
| Non-secure peripherals | 253                       |
| Secure peripherals     | 254                       |

Table 157: Arm TrustZone ID allocation

# 7.32.9 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description            | Configuration |
|------------------------|------------|----------|----------------|--------------|------------------------|---------------|
| 0x50003000 APPLICATION | N SPU      | SPU      | S              | NA           | System protection unit |               |

Table 158: Instances

| Register             | Offset | Security | Description                                                                  |          |
|----------------------|--------|----------|------------------------------------------------------------------------------|----------|
| EVENTS_RAMACCERR     | 0x100  |          | A security violation has been detected for the RAM memory space              |          |
| EVENTS_FLASHACCERR   | 0x104  |          | A security violation has been detected for the flash memory space            |          |
| EVENTS_PERIPHACCERR  | 0x108  |          | A security violation has been detected on one or several peripherals         |          |
| PUBLISH_RAMACCERR    | 0x180  |          | Publish configuration for event RAMACCERR                                    |          |
| PUBLISH_FLASHACCERR  | 0x184  |          | Publish configuration for event FLASHACCERR                                  |          |
| PUBLISH_PERIPHACCERR | 0x188  |          | Publish configuration for event PERIPHACCERR                                 |          |
| INTEN                | 0x300  |          | Enable or disable interrupt                                                  |          |
| INTENSET             | 0x304  |          | Enable interrupt                                                             |          |
| INTENCLR             | 0x308  |          | Disable interrupt                                                            |          |
| CAP                  | 0x400  |          | Show implemented features for the current device                             |          |
| CPULOCK              | 0x404  |          | Configure bits to lock down CPU features at runtime                          |          |
| EXTDOMAIN[n].PERM    | 0x440  |          | Access for bus access generated from the external domain n                   |          |
|                      |        |          | List capabilities of the external domain n                                   |          |
| DPPI[n].PERM         | 0x480  |          | Select between secure and non-secure attribute for the DPPI channels         |          |
| DPPI[n].LOCK         | 0x484  |          | Prevent further modification of the corresponding PERM register              |          |
| GPIOPORT[n].PERM     | 0x4C0  |          | Select between secure and non-secure attribute for pins 0 to 31 of port n    | Retained |
| GPIOPORT[n].LOCK     | 0x4C4  |          | Prevent further modification of the corresponding PERM register              |          |
| FLASHNSC[n].REGION   | 0x500  |          | Define which flash region can contain the non-secure callable (NSC) region n |          |
| FLASHNSC[n].SIZE     | 0x504  |          | Define the size of the non-secure callable (NSC) region n                    |          |
| RAMNSC[n].REGION     | 0x540  |          | Define which RAM region can contain the non-secure callable (NSC) region n   |          |
| RAMNSC[n].SIZE       | 0x544  |          | Define the size of the non-secure callable (NSC) region n                    |          |
| FLASHREGION[n].PERM  | 0x600  |          | Access permissions for flash region n                                        |          |
| RAMREGION[n].PERM    | 0x700  |          | Access permissions for RAM region n                                          |          |
| PERIPHID[n].PERM     | 0x800  |          | List capabilities and access permissions for the peripheral with ID n        |          |

Table 159: Register overview



#### 7.32.9.1 EVENTS\_RAMACCERR

Address offset: 0x100

A security violation has been detected for the RAM memory space



#### 7.32.9.2 EVENTS FLASHACCERR

Address offset: 0x104

A security violation has been detected for the flash memory space



#### 7.32.9.3 EVENTS PERIPHACCERR

Address offset: 0x108

A security violation has been detected on one or several peripherals



#### 7.32.9.4 PUBLISH RAMACCERR

Address offset: 0x180

Publish configuration for event RAMACCERR





## 7.32.9.5 PUBLISH FLASHACCERR

Address offset: 0x184

Publish configuration for event FLASHACCERR



## 7.32.9.6 PUBLISH PERIPHACCERR

Address offset: 0x188

Publish configuration for event PERIPHACCERR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                      | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                        | Description                                                     |
| Α     | RW      | CHIDX |          | [2550]                 | DPPI channel that event PERIPHACCERR will publish to.           |
| В     | RW      | EN    |          |                        |                                                                 |
|       |         |       | Disabled | 0                      | Disable publishing                                              |
|       |         |       | Enabled  | 1                      | Enable publishing                                               |

#### 7.32.9.7 INTEN

Address offset: 0x300

Enable or disable interrupt







| Bit number        |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------|----------|------------------------|-----------------------------------------------------------------|
| ID                |          |                        | СВА                                                             |
| Reset 0x00000000  |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field      |          |                        | Description                                                     |
|                   | Disabled | 0                      | Disable                                                         |
|                   | Enabled  | 1                      | Enable                                                          |
| C RW PERIPHACCERR |          |                        | Enable or disable interrupt for event PERIPHACCERR              |
|                   | Disabled | 0                      | Disable                                                         |
|                   | Enabled  | 1                      | Enable                                                          |

## 7.32.9.8 INTENSET

Address offset: 0x304

Enable interrupt

| Dit n | umber    |              |          | 21 20 20 20 27 26 25 2               | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|----------|--------------------------------------|-----------------------------------------------------------------|
|       | ullibei  |              |          | — 31 30 2 <del>3</del> 28 27 20 23 2 |                                                                 |
| ID    |          |              |          |                                      | СВА                                                             |
| Rese  | et 0x000 | 00000        |          | 0 0 0 0 0 0 0                        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |          |                                      | Description                                                     |
| Α     | RW       | RAMACCERR    |          |                                      | Write '1' to enable interrupt for event RAMACCERR               |
|       |          |              | Set      | 1                                    | Enable                                                          |
|       |          |              | Disabled | 0                                    | Read: Disabled                                                  |
|       |          |              | Enabled  | 1                                    | Read: Enabled                                                   |
| В     | RW       | FLASHACCERR  |          |                                      | Write '1' to enable interrupt for event FLASHACCERR             |
|       |          |              | Set      | 1                                    | Enable                                                          |
|       |          |              | Disabled | 0                                    | Read: Disabled                                                  |
|       |          |              | Enabled  | 1                                    | Read: Enabled                                                   |
| С     | RW       | PERIPHACCERR |          |                                      | Write '1' to enable interrupt for event PERIPHACCERR            |
|       |          |              | Set      | 1                                    | Enable                                                          |
|       |          |              | Disabled | 0                                    | Read: Disabled                                                  |
|       |          |              | Enabled  | 1                                    | Read: Enabled                                                   |

# 7.32.9.9 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |              |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |              |          |                        | СВА                                                             |
| Rese  | et 0x000 | 00000        |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |              |          |                        | Description                                                     |
| Α     | RW       | RAMACCERR    |          |                        | Write '1' to disable interrupt for event RAMACCERR              |
|       |          |              | Clear    | 1                      | Disable                                                         |
|       |          |              | Disabled | 0                      | Read: Disabled                                                  |
|       |          |              | Enabled  | 1                      | Read: Enabled                                                   |
| В     | RW       | FLASHACCERR  |          |                        | Write '1' to disable interrupt for event FLASHACCERR            |
|       |          |              | Clear    | 1                      | Disable                                                         |
|       |          |              | Disabled | 0                      | Read: Disabled                                                  |
|       |          |              | Enabled  | 1                      | Read: Enabled                                                   |
| С     | RW       | PERIPHACCERR |          |                        | Write '1' to disable interrupt for event PERIPHACCERR           |





#### 7.32.9.10 CAP

Address offset: 0x400

Show implemented features for the current device



#### 7.32.9.11 CPULOCK

Address offset: 0x404

Configure bits to lock down CPU features at runtime

Write '1' to any position to set the corresponding lock bit, which will remain set until the next reset

Any '0' writes to this register will be ignored

| Bit n | umber   |              |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |              |          |                         | E D C B A                                                       |
| Rese  | t 0x000 | 00000        |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |          |                         |                                                                 |
| Α     | RW      | LOCKSVTAIRCR |          |                         | Write '1' to prevent updating the secure interrupt              |
|       |         |              |          |                         | configuration until the next reset                              |
|       |         |              |          |                         | When set to '1', this lock bit prevents changes to:             |
|       |         |              |          |                         | The Secure vector table base address                            |
|       |         |              |          |                         | Handling of Secure interrupt priority                           |
|       |         |              |          |                         | BusFault, HardFault, and NMI security target                    |
|       |         |              | Locked   | 1                       | Disables writes to the VTOR_S, AIRCR.PRIS, and                  |
|       |         |              |          |                         | AIRCR.BFHFNMINS registers                                       |
|       |         |              | Unlocked | 0                       | These registers can be updated                                  |
| В     | RW      | LOCKNSVTOR   |          |                         | Write '1' to prevent updating the non-secure vector table       |
|       |         |              |          |                         | base address until the next reset                               |
|       |         |              |          |                         | When set to '1', this lock bit prevents changes to the          |
|       |         |              |          |                         | Non-secure interrupt vector table base address register         |
|       |         |              |          |                         | VTOR_NS                                                         |
|       |         |              | Locked   | 1                       | The address of the non-secure vector table is locked            |
|       |         |              | Unlocked | 0                       | The address of the non-secure vector table can be updated       |



| Bit n | umber    |           |           | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|-----------|-------------------------|---------------------------------------------------------------|
| ID    |          |           |           |                         | E D C B A                                                     |
| Rese  | et 0x000 | 00000     |           | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
|       |          |           |           |                         |                                                               |
| С     | RW       | LOCKSMPU  |           |                         | Write '1' to prevent updating the secure MPU regions until    |
|       |          |           |           |                         | the next reset                                                |
|       |          |           |           |                         | When set to '1', this lock bit prevents changes to            |
|       |          |           |           |                         | programmed Secure MPU memory regions and all writes           |
|       |          |           |           |                         | to the registers are ignored                                  |
|       |          |           | Locked    | 1                       | Disables writes to the MPU_CTRL, MPU_RNR, MPU_RBAR,           |
|       |          |           |           |                         | MPU_RLAR, MPU_RBAR_An and MPU_RLAR_An from                    |
|       |          |           |           |                         | software or from a debug agent connected to the               |
|       |          |           |           |                         | processor in Secure state                                     |
|       |          |           | Unlocked  | 0                       | These registers can be updated                                |
| D     | RW       | LOCKNSMPU |           |                         | Write '1' to prevent updating the Non-secure MPU regions      |
|       |          |           |           |                         | until the next reset                                          |
|       |          |           |           |                         | When set to '1', this lock bit prevents changes to            |
|       |          |           |           |                         | programmed Non-secure MPU memory regions already              |
|       |          |           |           |                         | programmed. All writes to the registers are ignored.          |
|       |          |           | Locked    | 1                       | Disables writes to the MPU_CTRL_NS, MPU_RNR_NS,               |
|       |          |           |           |                         | MPU_RBAR_NS, MPU_RLAR_NS, MPU_RBAR_A_NSn and                  |
|       |          |           |           |                         | MPU_RLAR_A_NSn from software or from a debug agent            |
|       |          |           |           | _                       | connected to the processor                                    |
| _     | D14/     | LOCKCALL  | Unlocked  | 0                       | These registers can be updated                                |
| E     | RW       | LOCKSAU   |           |                         | Write '1' to prevent updating the secure SAU regions until    |
|       |          |           |           |                         | the next reset                                                |
|       |          |           |           |                         | When set to '1', this lock bit prevents changes to Secure     |
|       |          |           |           |                         | SAU memory regions already programmed. All writes to          |
|       |          |           |           |                         | the registers are ignored.                                    |
|       |          |           | Locked    | 1                       | Disables writes to the SAU_CTRL, SAU_RNR, SAU_RBAR            |
|       |          |           |           |                         | and SAU_RLAR registers from software or from a debug          |
|       |          |           | Unlocked  | 0                       | agent connected to the processor                              |
|       |          |           | UIIIUCKEU | U                       | These registers can be updated                                |

# 7.32.9.12 EXTDOMAIN[n].PERM (n=0..0)

Address offset:  $0x440 + (n \times 0x4)$ 

Access for bus access generated from the external domain  $\boldsymbol{n}$ 

List capabilities of the external domain n



| Bit number       |    |               |                | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----|---------------|----------------|------------------------|------------------------------------------------------------------|
| ID               |    |               |                |                        | C B A A                                                          |
| Reset 0x00000002 |    |               |                | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|                  |    |               |                |                        |                                                                  |
| Α                | R  | SECUREMAPPING |                |                        | Define configuration capabilities for TrustZone Cortex-M         |
|                  |    |               |                |                        | secure attribute                                                 |
|                  |    |               |                |                        | This does not affect DPPI in the external domain                 |
|                  |    |               | NonSecure      | 0                      | The bus access from this external domain always have the         |
|                  |    |               |                |                        | non-secure attribute set                                         |
|                  |    |               | Secure         | 1                      | The bus access from this external domain always have the         |
|                  |    |               |                |                        | secure attribute set                                             |
|                  |    |               | UserSelectable | 2                      | Non-secure or secure attribute for bus access from this          |
|                  |    |               |                |                        | domain is defined by the EXTDOMAIN[n].PERM register              |
| В                | RW | SECATTR       |                |                        | Peripheral security mapping                                      |
|                  |    |               |                |                        | This bit has effect only if                                      |
|                  |    |               |                |                        | EXTDOMAIN[n].PERM.SECUREMAPPING reads as                         |
|                  |    |               |                |                        | UserSelectable                                                   |
|                  |    |               | NonSecure      | 0                      | Bus accesses from this domain have the non-secure                |
|                  |    |               |                |                        | attribute set                                                    |
|                  |    |               | Secure         | 1                      | Bus accesses from this domain have secure attribute set          |
| С                | RW | LOCK          |                |                        |                                                                  |
|                  |    |               | Unlocked       | 0                      | This register can be updated                                     |
|                  |    |               | Locked         | 1                      | The content of this register can't be changed until the next     |
|                  |    |               |                |                        | reset                                                            |

# 7.32.9.13 DPPI[n].PERM (n=0..0)

Address offset:  $0x480 + (n \times 0x8)$ 

Select between secure and non-secure attribute for the DPPI channels



# 7.32.9.14 DPPI[n].LOCK (n=0..0)

Address offset:  $0x484 + (n \times 0x8)$ 

Prevent further modification of the corresponding PERM register







## 7.32.9.15 GPIOPORT[n].PERM (n=0..1) (Retained)

Address offset:  $0x4C0 + (n \times 0x8)$ 

This register is a retained register

Select between secure and non-secure attribute for pins 0 to 31 of port n



## 7.32.9.16 GPIOPORT[n].LOCK (n=0..1)

Address offset: 0x4C4 + (n × 0x8)

Prevent further modification of the corresponding PERM register



## 7.32.9.17 FLASHNSC[n].REGION (n=0..1)

Address offset:  $0x500 + (n \times 0x8)$ 

Define which flash region can contain the non-secure callable (NSC) region n



## 7.32.9.18 FLASHNSC[n].SIZE (n=0..1)

Address offset:  $0x504 + (n \times 0x8)$ 

Define the size of the non-secure callable (NSC) region n



| Bit r | number           |      |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|------|----------|-------------------------|---------------------------------------------------------------|
| ID    |                  |      |          |                         | B A A A A                                                     |
| Rese  | Reset 0x00000000 |      |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
|       |                  |      |          |                         |                                                               |
| Α     | RW               | SIZE |          |                         | Size of the non-secure callable (NSC) region n                |
|       |                  |      | Disabled | 0                       | The region n is not defined as a non-secure callable region.  |
|       |                  |      |          |                         | Normal security attributes (secure or non-secure) are         |
|       |                  |      |          |                         | enforced.                                                     |
|       |                  |      | 32       | 1                       | The region n is defined as non-secure callable with size 32   |
|       |                  |      |          |                         | bytes                                                         |
|       |                  |      | 64       | 2                       | The region n is defined as non-secure callable with size 64   |
|       |                  |      |          |                         | bytes                                                         |
|       |                  |      | 128      | 3                       | The region n is defined as non-secure callable with size 128  |
|       |                  |      |          |                         | bytes                                                         |
|       |                  |      | 256      | 4                       | The region n is defined as non-secure callable with size 256  |
|       |                  |      |          |                         | bytes                                                         |
|       |                  |      | 512      | 5                       | The region n is defined as non-secure callable with size 512  |
|       |                  |      |          |                         | bytes                                                         |
|       |                  |      | 1024     | 6                       | The region n is defined as non-secure callable with size      |
|       |                  |      |          |                         | 1024 bytes                                                    |
|       |                  |      | 2048     | 7                       | The region n is defined as non-secure callable with size      |
|       |                  |      |          |                         | 2048 bytes                                                    |
|       |                  |      | 4096     | 8                       | The region n is defined as non-secure callable with size      |
|       |                  |      |          |                         | 4096 bytes                                                    |
| В     | RW               | LOCK |          |                         |                                                               |
|       |                  |      | Unlocked | 0                       | This register can be updated                                  |
|       |                  |      | Locked   | 1                       | The content of this register can't be changed until the next  |
|       |                  |      |          |                         | reset                                                         |
|       |                  |      |          |                         |                                                               |

# 7.32.9.19 RAMNSC[n].REGION (n=0..1)

Address offset:  $0x540 + (n \times 0x8)$ 

Define which RAM region can contain the non-secure callable (NSC) region n



# 7.32.9.20 RAMNSC[n].SIZE (n=0..1)

Address offset:  $0x544 + (n \times 0x8)$ 

Define the size of the non-secure callable (NSC) region n



| Bit r            | number |      |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|--------|------|----------|----------------------|------------------------------------------------------------------|
| ID               |        |      |          |                      | В АААА                                                           |
| Reset 0x00000000 |        |      |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|                  |        |      |          |                      |                                                                  |
| Α                | RW     | SIZE |          |                      | Size of the non-secure callable (NSC) region n                   |
|                  |        |      | Disabled | 0                    | The region n is not defined as a non-secure callable region.     |
|                  |        |      |          |                      | Normal security attributes (secure or non-secure) are            |
|                  |        |      |          |                      | enforced.                                                        |
|                  |        |      | 32       | 1                    | The region n is defined as non-secure callable with size 32      |
|                  |        |      |          |                      | bytes                                                            |
|                  |        |      | 64       | 2                    | The region n is defined as non-secure callable with size 64      |
|                  |        |      |          |                      | bytes                                                            |
|                  |        |      | 128      | 3                    | The region n is defined as non-secure callable with size 128     |
|                  |        |      |          |                      | bytes                                                            |
|                  |        |      | 256      | 4                    | The region n is defined as non-secure callable with size 256     |
|                  |        |      |          |                      | bytes                                                            |
|                  |        |      | 512      | 5                    | The region n is defined as non-secure callable with size 512     |
|                  |        |      |          |                      | bytes                                                            |
|                  |        |      | 1024     | 6                    | The region n is defined as non-secure callable with size         |
|                  |        |      |          |                      | 1024 bytes                                                       |
|                  |        |      | 2048     | 7                    | The region n is defined as non-secure callable with size         |
|                  |        |      |          |                      | 2048 bytes                                                       |
|                  |        |      | 4096     | 8                    | The region n is defined as non-secure callable with size         |
|                  |        |      |          |                      | 4096 bytes                                                       |
| В                | RW     | LOCK |          |                      |                                                                  |
|                  |        |      | Unlocked | 0                    | This register can be updated                                     |
|                  |        |      | Locked   | 1                    | The content of this register can't be changed until the next     |
|                  |        |      |          |                      | reset                                                            |
|                  |        |      |          |                      |                                                                  |

# 7.32.9.21 FLASHREGION[n].PERM (n=0..63)

Address offset:  $0x600 + (n \times 0x4)$ 

Access permissions for flash region n

| Bit r | Bit number       |         |            | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|---------|------------|-------------------------|-----------------------------------------------------------------|
| ID    |                  |         |            |                         | E D C B A                                                       |
| Rese  | Reset 0x00000017 |         |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1                   |
| ID    |                  |         |            |                         | Description                                                     |
| Α     | RW               | EXECUTE |            |                         | Configure instruction fetch permissions from flash region n     |
|       |                  |         | Enable     | 1                       | Allow instruction fetches from flash region n                   |
|       |                  |         | Disable    | 0                       | Block instruction fetches from flash region n                   |
| В     | RW               | WRITE   |            |                         | Configure write permission for flash region n                   |
|       |                  |         | Enable     | 1                       | Allow write operation to region n                               |
|       |                  |         | Disable    | 0                       | Block write operation to region n                               |
| С     | RW               | READ    |            |                         | Configure read permissions for flash region n                   |
|       |                  |         | Enable     | 1                       | Allow read operation from flash region n                        |
|       |                  |         | Disable    | 0                       | Block read operation from flash region n                        |
| D     | RW               | SECATTR |            |                         | Security attribute for flash region n                           |
|       |                  |         | Non_Secure | 0                       | Flash region n security attribute is non-secure                 |
|       |                  |         | Secure     | 1                       | Flash region n security attribute is secure                     |
| Е     | RW               | LOCK    |            |                         |                                                                 |
|       |                  |         | Unlocked   | 0                       | This register can be updated                                    |



| ID R/W Field Value ID  Locked |                         | Description The content of this register can't be changed until the next |
|-------------------------------|-------------------------|--------------------------------------------------------------------------|
| ID R/W Field Value ID         |                         | Description                                                              |
|                               |                         |                                                                          |
| Reset 0x00000017              | 0 0 0 0 0 0 0           | $0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \$                                |
| ID                            |                         | E D C B A                                                                |
| Bit number                    | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0            |

# 7.32.9.22 RAMREGION[n].PERM (n=0..63)

Address offset:  $0x700 + (n \times 0x4)$ Access permissions for RAM region n

| Bit r | number   |         |            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|------------|------------------------|-----------------------------------------------------------------|
| ID    |          |         |            |                        | E D C B A                                                       |
| Res   | et 0x000 | 000017  |            | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |         |            |                        |                                                                 |
| Α     | RW       | EXECUTE |            |                        | Configure instruction fetch permissions from RAM region n       |
|       |          |         | Enable     | 1                      | Allow instruction fetches from RAM region n                     |
|       |          |         | Disable    | 0                      | Block instruction fetches from RAM region n                     |
| В     | RW       | WRITE   |            |                        | Configure write permission for RAM region n                     |
|       |          |         | Enable     | 1                      | Allow write operation to RAM region n                           |
|       |          |         | Disable    | 0                      | Block write operation to RAM region n                           |
| С     | RW       | READ    |            |                        | Configure read permissions for RAM region n                     |
|       |          |         | Enable     | 1                      | Allow read operation from RAM region n                          |
|       |          |         | Disable    | 0                      | Block read operation from RAM region n                          |
| D     | RW       | SECATTR |            |                        | Security attribute for RAM region n                             |
|       |          |         | Non_Secure | 0                      | RAM region n security attribute is non-secure                   |
|       |          |         | Secure     | 1                      | RAM region n security attribute is secure                       |
| Ε     | RW       | LOCK    |            |                        |                                                                 |
|       |          |         | Unlocked   | 0                      | This register can be updated                                    |
|       |          |         | Locked     | 1                      | The content of this register can't be changed until the next    |
|       |          |         |            |                        | reset                                                           |

# 7.32.9.23 PERIPHID[n].PERM (n=0..255)

Address offset:  $0x800 + (n \times 0x4)$ 

List capabilities and access permissions for the peripheral with ID n

**Note:** Reset values are unique per peripheral instantation. Please refer to the peripheral instantiation table. Entries not listed in the instantiation table are undefined.

| Bit n | umber   |               |                | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------|----------------|------------------------|------------------------------------------------------------------|
| ID    |         |               |                | F                      | E DCBBAA                                                         |
| Rese  | t 0x000 | 00012         |                | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |         |               |                |                        |                                                                  |
| Α     | R       | SECUREMAPPING |                |                        | Define configuration capabilities for Arm TrustZone Cortex-      |
|       |         |               |                |                        | M secure attribute                                               |
|       |         |               | NonSecure      | 0                      | This peripheral is always accessible as a non-secure             |
|       |         |               |                |                        | peripheral                                                       |
|       |         |               | Secure         | 1                      | This peripheral is always accessible as a secure peripheral      |
|       |         |               | UserSelectable | 2                      | Non-secure or secure attribute for this peripheral is            |
|       |         |               |                |                        | defined by the PERIPHID[n].PERM register                         |



| Bit n            | umber |         |                         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                           |
|------------------|-------|---------|-------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| ID               |       |         |                         | F                       | E DCBBAA                                                                                                                                                  |
| Reset 0x00000012 |       |         |                         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                   |
|                  |       |         |                         |                         |                                                                                                                                                           |
|                  |       |         | Split                   | 3                       | This peripheral implements the split security mechanism.  Non-secure or secure attribute for this peripheral is defined by the PERIPHID[n].PERM register. |
| В                | R     | DMA     |                         |                         | Indicates if the peripheral has DMA capabilities and if DMA transfer can be assigned to a different security attribute than the peripheral itself         |
|                  |       |         | NoDMA                   | 0                       | Peripheral has no DMA capability                                                                                                                          |
|                  |       |         | NoSeparateAttribute     | 1                       | Peripheral has DMA and DMA transfers always have the same security attribute as assigned to the peripheral                                                |
|                  |       |         | SeparateAttribute       | 2                       | Peripheral has DMA and DMA transfers can have a different security attribute than the one assigned to the peripheral                                      |
| С                | RW    | SECATTR |                         |                         | Peripheral security mapping                                                                                                                               |
|                  |       |         |                         |                         | This bit has effect only if  PERIPHID[n].PERM.SECUREMAPPING reads as  UserSelectable or Split                                                             |
|                  |       |         | Secure                  | 1                       | Peripheral is mapped in secure peripheral address space                                                                                                   |
|                  |       |         | NonSecure               | 0                       | If SECUREMAPPING == UserSelectable: Peripheral is mapped in non-secure peripheral address space.                                                          |
|                  |       |         |                         |                         | If SECUREMAPPING == Split: Peripheral is mapped in non-                                                                                                   |
|                  |       |         |                         |                         | secure and secure peripheral address space.                                                                                                               |
| D                | RW    | DMASEC  |                         |                         | Security attribution for the DMA transfer                                                                                                                 |
|                  |       |         |                         |                         | This bit has effect only if PERIPHID[n].PERM.SECATTR is set to secure                                                                                     |
|                  |       |         | Secure                  | 1                       | DMA transfers initiated by this peripheral have the secure attribute set                                                                                  |
|                  |       |         | NonSecure               | 0                       | DMA transfers initiated by this peripheral have the non-<br>secure attribute set                                                                          |
| E                | RW    | LOCK    |                         |                         |                                                                                                                                                           |
|                  |       |         | Unlocked                | 0                       | This register can be updated                                                                                                                              |
|                  |       |         | Locked                  | 1                       | The content of this register can't be changed until the next reset                                                                                        |
| F                | R     | PRESENT |                         |                         | Indicate if a peripheral is present with ID n                                                                                                             |
|                  |       |         | NotPresent<br>IsPresent | 0                       | Peripheral is not present  Peripheral is present                                                                                                          |
|                  |       |         |                         |                         |                                                                                                                                                           |

# 7.33 SWI — Software interrupts

A set of interrupts have been reserved for use as software interrupts.



# 7.33.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description          | Configuration |
|---------------------|------------|----------|----------------|--------------|----------------------|---------------|
| 0x4101A000 NETWORK  | SWI        | SWI0     | NS             | NA           | Software interrupt 0 |               |
| 0x4101B000 NETWORK  | SWI        | SWI1     | NS             | NA           | Software interrupt 1 |               |
| 0x4101C000 NETWORK  | SWI        | SWI2     | NS             | NA           | Software interrupt 2 |               |
| 0x4101D000 NETWORK  | SWI        | SWI3     | NS             | NA           | Software interrupt 3 |               |

Table 160: Instances

# 7.34 TEMP — Temperature sensor

The temperature sensor measures die temperature over the temperature range of the device. Linearity compensation can be implemented if required by the application.

The main features of TEMP are the following:

- Temperature range is greater than or equal to operating temperature of the device
- Resolution is 0.25 °C

TEMP is started by triggering the START task.

When the temperature measurement is completed, a DATARDY event will be generated and the result of the measurement can be read from the TEMP register.

To achieve the measurement accuracy stated in the electrical specification, the crystal oscillator must be selected as the HFCLK source, see CLOCK — Clock control on page 73 for more information.

When the temperature measurement is completed, TEMP analog electronics power down to save power.

TEMP only supports one-shot operation, meaning that every TEMP measurement has to be explicitly started using the START task.

# 7.34.1 Registers

| Base address Domain | Peripheral | Instance | Secure mapping | DMA security | Description        | Configuration |
|---------------------|------------|----------|----------------|--------------|--------------------|---------------|
| 0x41010000 NETWORK  | TEMP       | TEMP     | NS             | NA           | Temperature sensor |               |

Table 161: Instances

| Register        | Offset | Security | Description                                  |
|-----------------|--------|----------|----------------------------------------------|
| TASKS_START     | 0x000  |          | Start temperature measurement                |
| TASKS_STOP      | 0x004  |          | Stop temperature measurement                 |
| SUBSCRIBE_START | 0x080  |          | Subscribe configuration for task START       |
| SUBSCRIBE_STOP  | 0x084  |          | Subscribe configuration for task STOP        |
| EVENTS_DATARDY  | 0x100  |          | Temperature measurement complete, data ready |
| PUBLISH_DATARDY | 0x180  |          | Publish configuration for event DATARDY      |
| INTENSET        | 0x304  |          | Enable interrupt                             |
| INTENCLR        | 0x308  |          | Disable interrupt                            |
| TEMP            | 0x508  |          | Temperature in °C (0.25° steps)              |
| A0              | 0x520  |          | Slope of first piecewise linear function     |
| A1              | 0x524  |          | Slope of second piecewise linear function    |
| A2              | 0x528  |          | Slope of third piecewise linear function     |
| A3              | 0x52C  |          | Slope of fourth piecewise linear function    |
| A4              | 0x530  |          | Slope of fifth piecewise linear function     |



| Register | Offset | Security | Description                                     |
|----------|--------|----------|-------------------------------------------------|
| A5       | 0x534  |          | Slope of sixth piecewise linear function        |
| В0       | 0x540  |          | y-intercept of first piecewise linear function  |
| B1       | 0x544  |          | y-intercept of second piecewise linear function |
| B2       | 0x548  |          | y-intercept of third piecewise linear function  |
| B3       | 0x54C  |          | y-intercept of fourth piecewise linear function |
| B4       | 0x550  |          | y-intercept of fifth piecewise linear function  |
| B5       | 0x554  |          | y-intercept of sixth piecewise linear function  |
| ТО       | 0x560  |          | Endpoint of first piecewise linear function     |
| T1       | 0x564  |          | Endpoint of second piecewise linear function    |
| T2       | 0x568  |          | Endpoint of third piecewise linear function     |
| Т3       | 0x56C  |          | Endpoint of fourth piecewise linear function    |
| T4       | 0x570  |          | Endpoint of fifth piecewise linear function     |

Table 162: Register overview

# 7.34.1.1 TASKS\_START

Address offset: 0x000

Start temperature measurement



# 7.34.1.2 TASKS\_STOP

Address offset: 0x004

Stop temperature measurement



# 7.34.1.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START





#### 7.34.1.4 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP



#### 7.34.1.5 EVENTS DATARDY

Address offset: 0x100

Temperature measurement complete, data ready



#### 7.34.1.6 PUBLISH DATARDY

Address offset: 0x180

Publish configuration for event DATARDY





#### 7.34.1.7 INTENSET

Address offset: 0x304

Enable interrupt



#### 7.34.1.8 INTENCLR

Address offset: 0x308

Disable interrupt



#### 7.34.1.9 TEMP

Address offset: 0x508

Temperature in °C (0.25° steps)



#### 7.34.1.10 A0

Address offset: 0x520

Slope of first piecewise linear function





7.34.1.11 A1

Address offset: 0x524

Slope of second piecewise linear function



7.34.1.12 A2

Address offset: 0x528

Slope of third piecewise linear function



7.34.1.13 A3

Address offset: 0x52C

Slope of fourth piecewise linear function



7.34.1.14 A4

Address offset: 0x530

Slope of fifth piecewise linear function





#### 7.34.1.15 A5

Address offset: 0x534

Slope of sixth piecewise linear function



#### 7.34.1.16 BO

Address offset: 0x540

y-intercept of first piecewise linear function



#### 7.34.1.17 B1

Address offset: 0x544

y-intercept of second piecewise linear function



#### 7.34.1.18 B2

Address offset: 0x548

y-intercept of third piecewise linear function



#### 7.34.1.19 B3

Address offset: 0x54C

y-intercept of fourth piecewise linear function

NORDIC



#### 7.34.1.20 B4

Address offset: 0x550

y-intercept of fifth piecewise linear function



#### 7.34.1.21 B5

Address offset: 0x554

y-intercept of sixth piecewise linear function



#### 7.34.1.22 TO

Address offset: 0x560

Endpoint of first piecewise linear function



#### 7.34.1.23 T1

Address offset: 0x564

Endpoint of second piecewise linear function





#### 7.34.1.24 T2

Address offset: 0x568

Endpoint of third piecewise linear function



#### 7.34.1.25 T3

Address offset: 0x56C

Endpoint of fourth piecewise linear function



#### 7.34.1.26 T4

Address offset: 0x570

Endpoint of fifth piecewise linear function



# 7.34.2 Electrical specification

# 7.34.2.1 Temperature Sensor Electrical Specification

| Description                                               | Min.                                                                                                                                                                                                                                                                                                      | Тур.                                                                                                                                                                                                                                                                                                                    | Max.                                                                                                                                                                                                                                                                                                                            | Units                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time required for temperature measurement                 |                                                                                                                                                                                                                                                                                                           | 36                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                 | μs                                                                                                                                                                                                                                                                                                                                                                                 |
| Temperature sensor range                                  | -20                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                         | 70                                                                                                                                                                                                                                                                                                                              | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Temperature sensor accuracy                               | -5                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                         | 5                                                                                                                                                                                                                                                                                                                               | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Temperature sensor range, extended temperature range      | -40                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                         | 105                                                                                                                                                                                                                                                                                                                             | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Temperature sensor accuracy, extended temperature range   | -7                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                         | 7                                                                                                                                                                                                                                                                                                                               | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Temperature sensor resolution                             |                                                                                                                                                                                                                                                                                                           | 0.25                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                 | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Sample to sample stability at constant device temperature |                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                         | ±0.25                                                                                                                                                                                                                                                                                                                           | °C                                                                                                                                                                                                                                                                                                                                                                                 |
| Sample offset at 25°C                                     | -2.5                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                         | 2.5                                                                                                                                                                                                                                                                                                                             | °C                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                           | Time required for temperature measurement  Temperature sensor range  Temperature sensor accuracy  Temperature sensor range, extended temperature range  Temperature sensor accuracy, extended temperature range  Temperature sensor resolution  Sample to sample stability at constant device temperature | Time required for temperature measurement  Temperature sensor range -20  Temperature sensor accuracy -5  Temperature sensor range, extended temperature range -40  Temperature sensor accuracy, extended temperature range -7  Temperature sensor resolution  Sample to sample stability at constant device temperature | Time required for temperature measurement 36  Temperature sensor range -20  Temperature sensor accuracy -5  Temperature sensor range, extended temperature range -40  Temperature sensor accuracy, extended temperature range -7  Temperature sensor resolution 0.25  Sample to sample stability at constant device temperature | Time required for temperature measurement 36  Temperature sensor range -20 70  Temperature sensor accuracy -5 5  Temperature sensor range, extended temperature range -40 105  Temperature sensor accuracy, extended temperature range -7 7  Temperature sensor resolution 0.25  Sample to sample stability at constant device temperature 36  Temperature sensor resolution 50.25 |





# 7.35 TIMER — Timer/counter

This peripheral is a general purpose timer allowing time intervals to be defined by user input. It can operate in two modes: Timer mode and Counter mode.



Figure 214: Block schematic for timer/counter

TIMER runs on the high-frequency clock source (HFCLK) and includes a four-bit (1/2X) prescaler that can divide the timer input clock from the HFCLK controller. Clock source selection between PCLK16M and PCLK1M is automatic according to the TIMER base frequency set by the prescaler. The TIMER base frequency is always given as 16 MHz divided by the prescaler value.

The PPI system allows a TIMER event to trigger a task on another system peripheral on the device. The PPI system also enables the TIMER task/event feature to generate periodic output and PWM signals to any GPIO. The number of GPIO inputs or outputs used at the same time is limited by the number of GPIOTE channels.

TIMER can operate in two modes: Timer mode and Counter mode. In both modes, TIMER is started by triggering the START task, and stopped by triggering the STOP task. After TIMER stops, it can resume timing/counting by triggering the START task again. When timing/counting resumes, TIMER continues from the value it was on prior to stopping.

In Timer mode, TIMER's internal Counter register is incremented by one for every tick of the timer frequency  $f_{\text{TIMER}}$ , as illustrated in Block schematic for timer/counter on page 623. The timer frequency is derived from PCLK16M as shown in the following example, using the values specified in the PRESCALER register.

```
f_{\text{TIMER}} = 16 \text{ MHz} / (2^{\text{PRESCALER}})
```

When f<sub>TIMFR</sub> ≤ 1 MHz, TIMER uses PCLK1M instead of PCLK16M for reduced power consumption.

In Counter mode, the TIMER's internal Counter register is incremented by one each time the COUNT task is triggered, meaning the timer frequency and the prescaler are not utilized in Counter mode. Similarly, the COUNT task has no effect in Timer mode.

TIMER's maximum value is configured by changing the bit-width of the timer in register BITMODE on page 631.



PRESCALER on page 631 and BITMODE on page 631 must only be updated when TIMER is stopped. If these registers are updated while TIMER is started, unpredictable behavior may occur.

When TIMER is incremented beyond its maximum value, the Counter register will overflow and TIMER will automatically start over from zero.

The Counter register can be cleared by triggering the CLEAR task. This will explicitly set the internal value to zero.

TIMER implements multiple capture/compare registers.

Independent of prescaler settings, the accuracy of TIMER is equivalent to one tick of the timer frequency  $f_{\text{TIMER}}$  as illustrated in Block schematic for timer/counter on page 623.

# 7.35.1 Capture

TIMER implements one capture task for every available capture/compare register.

Every time the CAPTURE[n] task is triggered, the counter value is copied to the CC[n] register.

### 7.35.2 Compare

TIMER implements one COMPARE event for every available capture/compare register.

When the counter value becomes equal to the value specified in a capture compare register CC[n], the corresponding compare event COMPARE[n] is generated.

BITMODE on page 631 specifies how many Counter and capture/compare register bits are used when the comparison is performed. Other bits are ignored.

The COMPARE event can be configured to operate in one-shot mode by configuring the corresponding ONESHOTEN[n] register. After writing CC[n], a COMPARE[n] event is generated the first time the Counter matches CC[n].

# 7.35.3 Task delays

After TIMER is started, the CLEAR, COUNT, and STOP tasks are guaranteed to take effect within one clock cycle of the PCLK16M.

# 7.35.4 Task priority

If the START task and the STOP task are triggered at the same time, meaning within the same period of PCLK16M, the STOP task is prioritized.

If one or more of the CAPTURE tasks and the CLEAR task are triggered at the same time, that is, within the same period of PCLK16M, the CAPTURE tasks are prioritized. This means that the CC registers will capture the counter value before the CLEAR tasks are triggered.



# 7.35.5 Registers

| Base address Domai | 'n            | Peripheral | Instance    | Secure mapping | DMA security | Description | Configuration        |
|--------------------|---------------|------------|-------------|----------------|--------------|-------------|----------------------|
| 0x5000F000         | 'ATION        | TIMED      | TIMER0 : S  | US             | NA           | Timer 0     | 6 capture compare    |
| 0x4000F000         | ICATION TIMER |            | TIMER0 : NS | 03             | NA .         | Timer o     | channels implemented |
| 0x50010000         | 'ATION        | TIMER      | TIMER1:S    | US             | NA           | Timer 1     | 6 capture compare    |
| 0x40010000         | AHON          | IIIVIEK    | TIMER1: NS  | 03             | IVA          | Timer 1     | channels implemented |
| 0x50011000         | 'ATION        | TIMER      | TIMER2 : S  | US             | NA           | Timer 2     | 6 capture compare    |
| 0x40011000         | AHON          | IIIVIEK    | TIMER2 : NS | 03             | IVA          | Tilliel 2   | channels implemented |
| 0x4100C000 NETW    | ORK           | TIMER      | TIMER0      | NS             | NA           | Timer 0     |                      |
| 0x41018000 NETW    | ORK           | TIMER      | TIMER1      | NS             | NA           | Timer 1     |                      |
| 0x41019000 NETW    | ORK           | TIMER      | TIMER2      | NS             | NA           | Timer 2     |                      |

Table 163: Instances

| Register             | Offset | Security | Description                                             |          |
|----------------------|--------|----------|---------------------------------------------------------|----------|
| TASKS_START          | 0x000  |          | Start Timer                                             |          |
| TASKS_STOP           | 0x004  |          | Stop Timer                                              |          |
| TASKS_COUNT          | 0x008  |          | Increment Timer (Counter mode only)                     |          |
| TASKS_CLEAR          | 0x00C  |          | Clear time                                              |          |
| TASKS_SHUTDOWN       | 0x010  |          | Shut down timer                                         | Deprecat |
| TASKS_CAPTURE[n]     | 0x040  |          | Capture Timer value to CC[n] register                   |          |
| SUBSCRIBE_START      | 0x080  |          | Subscribe configuration for task START                  |          |
| SUBSCRIBE_STOP       | 0x084  |          | Subscribe configuration for task STOP                   |          |
| SUBSCRIBE_COUNT      | 0x088  |          | Subscribe configuration for task COUNT                  |          |
| SUBSCRIBE_CLEAR      | 0x08C  |          | Subscribe configuration for task CLEAR                  |          |
| SUBSCRIBE_SHUTDOWN   | 0x090  |          | Subscribe configuration for task SHUTDOWN               | Deprecat |
| SUBSCRIBE_CAPTURE[n] | 0x0C0  |          | Subscribe configuration for task CAPTURE[n]             |          |
| EVENTS_COMPARE[n]    | 0x140  |          | Compare event on CC[n] match                            |          |
| PUBLISH_COMPARE[n]   | 0x1C0  |          | Publish configuration for event COMPARE[n]              |          |
| SHORTS               | 0x200  |          | Shortcuts between local events and tasks                |          |
| INTEN                | 0x300  |          | Enable or disable interrupt                             |          |
| INTENSET             | 0x304  |          | Enable interrupt                                        |          |
| INTENCLR             | 0x308  |          | Disable interrupt                                       |          |
| MODE                 | 0x504  |          | Timer mode selection                                    |          |
| BITMODE              | 0x508  |          | Configure the number of bits used by the TIMER          |          |
| PRESCALER            | 0x510  |          | Timer prescaler register                                |          |
| CC[n]                | 0x540  |          | Capture/Compare register n                              |          |
| ONESHOTEN[n]         | 0x580  |          | Enable one-shot operation for Capture/Compare channel n |          |

Table 164: Register overview

# 7.35.5.1 TASKS\_START

Address offset: 0x000

Start Timer





## 7.35.5.2 TASKS STOP

Address offset: 0x004

Stop Timer



# 7.35.5.3 TASKS\_COUNT

Address offset: 0x008

Increment Timer (Counter mode only)



#### 7.35.5.4 TASKS CLEAR

Address offset: 0x00C

Clear time



#### 7.35.5.5 TASKS\_SHUTDOWN (Deprecated)

Address offset: 0x010

Shut down timer





# 7.35.5.6 TASKS\_CAPTURE[n] (n=0..7)

Address offset:  $0x040 + (n \times 0x4)$ Capture Timer value to CC[n] register

| Bit n | umber   |               |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------|---------|------------------------|-----------------------------------------------------------------|
| ID    |         |               |         |                        | А                                                               |
| Rese  | t 0x000 | 00000         |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |               |         |                        | Description                                                     |
| Α     | W       | TASKS_CAPTURE |         |                        | Capture Timer value to CC[n] register                           |
|       |         |               | Trigger | 1                      | Trigger task                                                    |

# 7.35.5.7 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



#### 7.35.5.8 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         | Description                                                   |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to                 |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable subscription                                          |
|       |         |       | Enabled  | 1                       | Enable subscription                                           |

## 7.35.5.9 SUBSCRIBE\_COUNT

Address offset: 0x088

Subscribe configuration for task COUNT



#### 7.35.5.10 SUBSCRIBE CLEAR

Address offset: 0x08C

Subscribe configuration for task CLEAR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task CLEAR will subscribe to                  |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

# 7.35.5.11 SUBSCRIBE\_SHUTDOWN (Deprecated)

Address offset: 0x090

Subscribe configuration for task SHUTDOWN

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task SHUTDOWN will subscribe to               |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

# 7.35.5.12 SUBSCRIBE\_CAPTURE[n] (n=0..7)

Address offset:  $0x0C0 + (n \times 0x4)$ 

Subscribe configuration for task CAPTURE[n]







# 7.35.5.13 EVENTS\_COMPARE[n] (n=0..7)

Address offset:  $0x140 + (n \times 0x4)$ Compare event on CC[n] match



### 7.35.5.14 PUBLISH\_COMPARE[n] (n=0..7)

Address offset:  $0x1C0 + (n \times 0x4)$ 

Publish configuration for event COMPARE[n]



#### 7.35.5.15 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit no | umber   |                  |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------|---------|------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID     |         |                  |          |                         | PONMLKJI HGFEDCBA                                               |
| Rese   | t 0x000 | 00000            |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID     |         |                  |          |                         | Description                                                     |
| A-H    | RW      | COMPARE[i]_CLEAR |          |                         | Shortcut between event COMPARE[i] and task CLEAR                |
|        |         | (i=07)           |          |                         |                                                                 |
|        |         |                  | Disabled | 0                       | Disable shortcut                                                |
|        |         |                  | Enabled  | 1                       | Enable shortcut                                                 |
| I-P    | RW      | COMPARE[i]_STOP  |          |                         | Shortcut between event COMPARE[i] and task STOP                 |
|        |         | (i=07)           |          |                         |                                                                 |
|        |         |                  | Disabled | 0                       | Disable shortcut                                                |
|        |         |                  | Enabled  | 1                       | Enable shortcut                                                 |

#### 7.35.5.16 INTEN

Address offset: 0x300

Enable or disable interrupt



| Bit number               | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------------------------|------------------------|------------------------------------------------------------------|
| ID                       |                        | H G F E D C B A                                                  |
| Reset 0x00000000         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field Value ID    |                        | Description                                                      |
| A-H RW COMPARE[i] (i=07) |                        | Enable or disable interrupt for event COMPARE[i]                 |
| Disabled                 | 0                      | Disable                                                          |
| Enabled                  | 1                      | Enable                                                           |

# 7.35.5.17 INTENSET

Address offset: 0x304

Enable interrupt

| Bit numbe | r                 |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------|-------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID        |                   |          | H G F E D C B A         |                                                                 |
| Reset 0x0 | 0000000           |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W    |                   |          |                         |                                                                 |
| A-H RW    | COMPARE[i] (i=07) |          |                         | Write '1' to enable interrupt for event COMPARE[i]              |
|           |                   | Set      | 1                       | Enable                                                          |
|           |                   | Disabled | 0                       | Read: Disabled                                                  |
|           |                   | Enabled  | 1                       | Read: Enabled                                                   |

# 7.35.5.18 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit number               | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------------------------|------------------------|------------------------------------------------------------------|
| ID                       |                        | H G F E D C B A                                                  |
| Reset 0x00000000 0 0 0 0 |                        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field Value ID    |                        | Description                                                      |
| A-H RW COMPARE[i] (i=07) |                        | Write '1' to disable interrupt for event COMPARE[i]              |
| Clear                    | 1                      | Disable                                                          |
| Disabled                 | 0                      | Read: Disabled                                                   |
|                          |                        |                                                                  |

#### 7.35.5.19 MODE

Address offset: 0x504

Timer mode selection

| Bit n | umber   |       |                 | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|-----------------|------------------------|------------------------------------------------------------------|
| ID    |         |       |                 |                        | A A                                                              |
| Rese  | t 0x000 | 00000 |                 | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |         |       |                 |                        | Description                                                      |
| Α     | RW      | MODE  |                 |                        | Timer mode                                                       |
|       |         |       | Timer           | 0                      | Select Timer mode                                                |
|       |         |       | Counter         | 1                      | Select Counter mode Deprecated                                   |
|       |         |       | LowPowerCounter | 2                      | Select Low Power Counter mode                                    |



#### 7.35.5.20 BITMODE

Address offset: 0x508

Configure the number of bits used by the TIMER



#### 7.35.5.21 PRESCALER

Address offset: 0x510
Timer prescaler register



#### 7.35.5.22 CC[n] (n=0..7)

Address offset: 0x540 + (n × 0x4) Capture/Compare register n



Only the number of bits indicated by BITMODE will be used by the TIMER.

#### 7.35.5.23 ONESHOTEN[n] (n=0..7)

Address offset:  $0x580 + (n \times 0x4)$ 

Enable one-shot operation for Capture/Compare channel n





# 7.35.6 Electrical specification

# 7.36 TWIM — $I^2$ C compatible two-wire interface master with EasyDMA

TWI master with EasyDMA (TWIM) is a two-wire half-duplex master which can communicate with multiple slave devices connected to the same bus.

Listed here are the main features for TWIM:

- I<sup>2</sup>C compatible
- Supported baud rates: 100, 250, 400 and 1000 kbps
- Support for clock stretching (non I<sup>2</sup>C compliant)
- EasyDMA

The two-wire interface can communicate with a bi-directional wired-AND bus with two lines (SCL, SDA). The protocol makes it possible to interconnect up to 127 individually addressable devices. TWIM is not compatible with CBUS.

The GPIOs used for each two-wire interface line can be chosen from any GPIO on the device and are independently configurable. This enables great flexibility in device pinout and efficient use of board space and signal routing.





Figure 215: TWI master with EasyDMA

A typical TWI setup consists of one master and one or more slaves, as illustrated in the following figure. TWIM is only able to operate as a single master on the TWI bus. Multi-master bus configuration is not supported.



Figure 216: A typical TWI setup comprising one master and three slaves

TWIM supports clock stretching performed by the slaves. The SCK pulse following a stretched clock cycle may be shorter than specified by the  $I^2$ C specification.

TWIM is started by triggering the STARTTX or STARTRX tasks, and stopped by triggering the STOP task. After a STOP task, TWIM generates a STOPPED event when it has stopped.

After TWIM has been started, the STARTTX or STARTRX tasks should not be triggered again until TWIM has issued a LASTRX, LASTTX, or STOPPED event.

TWIM can be suspended using the SUSPEND task, such as when using the TWI master in a low priority interrupt context. When TWIM enters suspend state, it will automatically issue a SUSPENDED event while performing a continuous clock stretching until it is instructed to resume operation via a RESUME task. TWIM cannot be stopped while it is suspended, thus the STOP task has to be issued after the TWI master has been resumed.

**Note:** Any ongoing byte transfer will be allowed to complete before the suspend is enforced. A SUSPEND task has no effect unless TWIM is actively involved in a transfer.

If a NACK is clocked in from the slave, TWIM generates an ERROR event.

NORDIC\*
SEMICONDUCTOR

#### 7.36.1 Shared resources

TWIM shares registers and other resources with other peripherals that have the same ID as the TWI master. Therefore, you must disable all peripherals that have the same ID as TWIM before it can be configured and used.

Disabling a peripheral that has the same ID as TWIM will not reset any of the registers that are shared with TWIM. It is therefore important to configure all relevant registers explicitly to secure that TWIM operates correctly.

The Instantiation table in Peripherals on page 150 shows which peripherals have the same ID as the TWI.

# 7.36.2 EasyDMA

TWIM implements EasyDMA for accessing RAM without CPU involvement.

TWIM implements the EasyDMA channels found in the following table.

| Channel | Туре   | Register Cluster |
|---------|--------|------------------|
| TXD     | READER | TXD              |
| RXD     | WRITER | RXD              |

Table 165: TWIM EasyDMA Channels

For detailed information regarding the use of EasyDMA, see EasyDMA on page 154.

The RXD.PTR, TXD.PTR, RXD.MAXCNT, and TXD.MAXCNT registers are double-buffered. They can be updated and prepared for the next RX or TX transmission immediately after having received the RXSTARTED or TXSTARTED event.

The STOPPED event indicates that EasyDMA has finished accessing the buffer in RAM.

# 7.36.3 Master write sequence

A TWIM write sequence is started by triggering the STARTTX task. After the STARTTX task has been triggered, TWIM generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 0 (WRITE=0, READ=1).

The address must match the address of the slave device that the master wants to write to. The READ/ WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) generated by the slave.

After receiving the ACK bit, TWIM clocks out the data bytes found in the transmit buffer located in RAM at the address specified in the TXD.PTR register. Each byte clocked out from TWIM will be followed by an ACK/NACK bit clocked in from the slave.

A typical TWIM write sequence is shown in the following figure, including clock stretching performed by TWIM following a SUSPEND task.

A SUSPENDED event indicates that the SUSPEND task has taken effect. This event can be used to synchronize the software.

TWIM will generate a LASTTX event when it starts to transmit the last byte.





Figure 217: TWIM writing data to a slave

TWIM is stopped by triggering the STOP task. This task should be triggered during the transmission of the last byte to secure that TWIM will stop as fast as possible after sending the last byte. The shortcut between LASTTX and STOP can alternatively be used to accomplish this.

**Note:** TWIM does not stop by itself when the entire RAM buffer has been sent, or when an error occurs. The STOP task must be issued, through the use of a local or PPI shortcut, or in software as part of the error handler.

# 7.36.4 Master read sequence

A TWIM read sequence is started by triggering the STARTRX task. After the STARTRX task has been triggered, TWIM generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 1 (WRITE = 0, READ = 1). The address must match the address of the slave device that the master wants to read from. The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK = 1) generated by the slave.

After sending the ACK bit, the TWI slave sends data to the master using the clock generated by TWIM.

Data received will be stored in RAM at the address specified in the RXD.PTR register. The TWI master will generate an ACK after all but the last byte have been received from the slave. TWIM generates a NACK after the last byte received to indicate that the read sequence shall stop.

A typical TWIM read sequence is illustrated in the following figure, including clock stretching performed by TWIM following a SUSPEND task.

A SUSPENDED event indicates that the SUSPEND task has taken effect. This event can be used to synchronize the software.

TWIM generates a LASTRX event when it is ready to receive the last byte. If RXD.MAXCNT > 1, the LASTRX event is generated after sending the ACK of the previously received byte. If RXD.MAXCNT = 1, the LASTRX event is generated after receiving the ACK following the address and READ bit.

TWIM is stopped by triggering the STOP task. This task must be triggered before the NACK bit is supposed to be transmitted. The STOP task can be triggered at any time during the reception of the last byte. It is recommended to use the shortcut between LASTRX and STOP to accomplish this.

TWIM does not stop by itself when the RAM buffer is full, or when an error occurs. The STOP task must be issued, through the use of a local or PPI shortcut, or in software as part of the error handler.

TWIM cannot be stopped while suspended, so the STOP task must be issued after TWIM has been resumed.

NORDIC\*



Figure 218: TWIM reading data from a slave

# 7.36.5 Master repeated start sequence

A typical repeated start sequence is when TWIM writes two bytes to the slave followed by reading four bytes from the slave. This example uses shortcuts to perform the simplest type of repeated start sequence, i.e. one write followed by one read. The same approach can be used to perform a repeated start sequence where the sequence is read followed by write.

The following figure shows an example of a repeated start sequence where TWIM writes two bytes followed by reading four bytes from the slave.



Figure 219: Master repeated start sequence

If a more complex repeated start sequence is needed, and the TWI firmware drive is serviced in a low priority interrupt, it may be necessary to use the SUSPEND task and SUSPENDED event to guarantee that the correct tasks are generated at the correct time. A double repeated start sequence using the SUSPEND task to secure safe operation in low priority interrupts is shown in the following figure.





Figure 220: Double repeated start sequence

# 7.36.6 Low power

To ensure lowest possible power consumption when the peripheral is not needed stop and disable TWIM.

When the STOP task is sent, the software shall wait until the STOPPED event is received as a response before disabling the peripheral through the ENABLE register. If the peripheral is already stopped, the STOP task is not required.

# 7.36.7 Master mode pin configuration

The SCL and SDA signals are mapped to physical pins using the PSEL.SCL and PSEL.SDA registers.

The PSEL.SCL and PSEL.SDA registers and their configurations are only used as long as the TWI master is enabled, and retained only as long as the device is in System ON mode. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register. PSEL.SCL and PSEL.SDA must only be configured when the TWI master is disabled.

To secure correct signal levels on the pins used by TWIM while in System OFF mode, and when TWIM is disabled, these pins must be configured in the GPIO peripheral as described in the following table.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| TWI master signal | TWI master pin                         | Direction | Output value   | Drive strength     |
|-------------------|----------------------------------------|-----------|----------------|--------------------|
| SCL               | As specified in PSEL.SCL <sup>27</sup> | Input     | Not applicable | S0D1 <sup>27</sup> |
| SDA               | As specified in PSEL.SDA <sup>27</sup> | Input     | Not applicable | S0D1 <sup>27</sup> |

Table 166: GPIO configuration before enabling peripheral

4406\_640 v1.3 637 NORDIC

Special pin and drive strength considerations applies when using the 1000 kbps baud rate. For pin recommendations, see Pin assignments on page 790.

# 7.36.8 Registers

| Base address Domain      | Peripheral       | Instance   | Secure mapping | DMA security | Description               | Configuration |
|--------------------------|------------------|------------|----------------|--------------|---------------------------|---------------|
| 0x50008000<br>APPLICATIO | ANIANT IAC       | TWIM0 : S  | US             | SA           | Two-wire interface master |               |
| 0x40008000               | JIN I VVIIVI     | TWIM0 : NS | 03             | SA           | 0                         |               |
| 0x50009000               | ANIANT IAC       | TWIM1:S    | US             | SA           | Two-wire interface master |               |
| 0x40009000               | APPLICATION TWIM |            | 03             | ЭА           | 1                         |               |
| 0x5000B000<br>APPLICATIO | MIWT INC         | TWIM2 : S  | US             | SA           | Two-wire interface master |               |
| 0x4000B000               | JIN I WIIWI      | TWIM2 : NS | 03             | 5,1          | 2                         |               |
| 0x5000C000               | MIWT INC         | TWIM3 : S  | US             | SA           | Two-wire interface master |               |
| 0x4000C000               | 714 1 VV 11V1    | TWIM3 : NS | 03             | JA           | 3                         |               |
| 0x41013000 NETWORK       | TWIM             | TWIM0      | NS             | NA           | Two-wire interface master |               |
|                          |                  |            |                |              | 0                         |               |

Table 167: Instances

| Register          | Offset | Security | Description                                                                 |
|-------------------|--------|----------|-----------------------------------------------------------------------------|
| TASKS_STARTRX     | 0x000  |          | Start TWI receive sequence                                                  |
| TASKS_STARTTX     | 0x008  |          | Start TWI transmit sequence                                                 |
| TASKS_STOP        | 0x014  |          | Stop TWI transaction. Must be issued while the TWI master is not suspended. |
| TASKS_SUSPEND     | 0x01C  |          | Suspend TWI transaction                                                     |
| TASKS_RESUME      | 0x020  |          | Resume TWI transaction                                                      |
| SUBSCRIBE_STARTRX | 0x080  |          | Subscribe configuration for task STARTRX                                    |
| SUBSCRIBE_STARTTX | 0x088  |          | Subscribe configuration for task STARTTX                                    |
| SUBSCRIBE_STOP    | 0x094  |          | Subscribe configuration for task STOP                                       |
| SUBSCRIBE_SUSPEND | 0x09C  |          | Subscribe configuration for task SUSPEND                                    |
| SUBSCRIBE_RESUME  | 0x0A0  |          | Subscribe configuration for task RESUME                                     |
| EVENTS_STOPPED    | 0x104  |          | TWI stopped                                                                 |
| EVENTS_ERROR      | 0x124  |          | TWI error                                                                   |
| EVENTS_SUSPENDED  | 0x148  |          | SUSPEND task has been issued, TWI traffic is now suspended.                 |
| EVENTS_RXSTARTED  | 0x14C  |          | Receive sequence started                                                    |
| EVENTS_TXSTARTED  | 0x150  |          | Transmit sequence started                                                   |
| EVENTS_LASTRX     | 0x15C  |          | Byte boundary, starting to receive the last byte                            |
| EVENTS_LASTTX     | 0x160  |          | Byte boundary, starting to transmit the last byte                           |
| PUBLISH_STOPPED   | 0x184  |          | Publish configuration for event STOPPED                                     |
| PUBLISH_ERROR     | 0x1A4  |          | Publish configuration for event ERROR                                       |
| PUBLISH_SUSPENDED | 0x1C8  |          | Publish configuration for event SUSPENDED                                   |
| PUBLISH_RXSTARTED | 0x1CC  |          | Publish configuration for event RXSTARTED                                   |
| PUBLISH_TXSTARTED | 0x1D0  |          | Publish configuration for event TXSTARTED                                   |
| PUBLISH_LASTRX    | 0x1DC  |          | Publish configuration for event LASTRX                                      |
| PUBLISH_LASTTX    | 0x1E0  |          | Publish configuration for event LASTTX                                      |
| SHORTS            | 0x200  |          | Shortcuts between local events and tasks                                    |
| INTEN             | 0x300  |          | Enable or disable interrupt                                                 |
| INTENSET          | 0x304  |          | Enable interrupt                                                            |
| INTENCLR          | 0x308  |          | Disable interrupt                                                           |
| ERRORSRC          | 0x4C4  |          | Error source                                                                |
| ENABLE            | 0x500  |          | Enable TWIM                                                                 |
| PSEL.SCL          | 0x508  |          | Pin select for SCL signal                                                   |
| PSEL.SDA          | 0x50C  |          | Pin select for SDA signal                                                   |
| FREQUENCY         | 0x524  |          | TWI frequency. Accuracy depends on the HFCLK source selected.               |
| RXD.PTR           | 0x534  |          | Data pointer                                                                |
| RXD.MAXCNT        | 0x538  |          | Maximum number of bytes in receive buffer                                   |
| RXD.AMOUNT        | 0x53C  |          | Number of bytes transferred in the last transaction                         |
|                   |        |          |                                                                             |



| Register   | Offset | Security | Description                                         |
|------------|--------|----------|-----------------------------------------------------|
| RXD.LIST   | 0x540  |          | EasyDMA list type                                   |
| TXD.PTR    | 0x544  |          | Data pointer                                        |
| TXD.MAXCNT | 0x548  |          | Maximum number of bytes in transmit buffer          |
| TXD.AMOUNT | 0x54C  |          | Number of bytes transferred in the last transaction |
| TXD.LIST   | 0x550  |          | EasyDMA list type                                   |
| ADDRESS    | 0x588  |          | Address used in the TWI transfer                    |

Table 168: Register overview

# 7.36.8.1 TASKS\_STARTRX

Address offset: 0x000

Start TWI receive sequence

| Bit n | umber    |               |         | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|---------|---------------------|--------------------------------------------------------------------|
| ID    |          |               |         |                     | A                                                                  |
| Rese  | et 0x000 | 00000         |         | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID    |          |               |         |                     | Description                                                        |
| Α     | W        | TASKS_STARTRX |         |                     | Start TWI receive sequence                                         |
|       |          |               | Trigger | 1                   | Trigger task                                                       |

# 7.36.8.2 TASKS\_STARTTX

Address offset: 0x008

Start TWI transmit sequence

| Bit n | umber   |               |         | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------|---------|------------------------|-----------------------------------------------------------------|
| ID    |         |               |         |                        | А                                                               |
| Rese  | t 0x000 | 00000         |         | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |               |         |                        | Description                                                     |
| Α     | W       | TASKS_STARTTX |         |                        | Start TWI transmit sequence                                     |
|       |         |               | Trigger | 1                      | Trigger task                                                    |

# 7.36.8.3 TASKS\_STOP

Address offset: 0x014

Stop TWI transaction. Must be issued while the TWI master is not suspended.

| Bit n | umber   |            |         | 31 30 29 28 27 2 | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------|------------------|------------------------------------------------------------------------|
| ID    |         |            |         |                  | А                                                                      |
| Rese  | t 0x000 | 00000      |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                |
| ID    |         |            |         |                  | Description                                                            |
| Α     | W       | TASKS_STOP |         |                  | Stop TWI transaction. Must be issued while the TWI master              |
|       |         |            |         |                  | is not suspended.                                                      |
|       |         |            | Trigger | 1                | Trigger task                                                           |

# 7.36.8.4 TASKS\_SUSPEND

Address offset: 0x01C Suspend TWI transaction





# 7.36.8.5 TASKS\_RESUME

Address offset: 0x020
Resume TWI transaction



# 7.36.8.6 SUBSCRIBE\_STARTRX

Address offset: 0x080

Subscribe configuration for task STARTRX

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STARTRX will subscribe to                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

#### 7.36.8.7 SUBSCRIBE\_STARTTX

Address offset: 0x088

Subscribe configuration for task STARTTX

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A A                                               |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     |
| ID    |          |       |          |                         |                                                             |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task STARTTX will subscribe to            |
| В     | RW       | EN    |          |                         |                                                             |
|       |          |       | Disabled | 0                       | Disable subscription                                        |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |

#### 7.36.8.8 SUBSCRIBE\_STOP

Address offset: 0x094

Subscribe configuration for task STOP





# 7.36.8.9 SUBSCRIBE\_SUSPEND

Address offset: 0x09C

Subscribe configuration for task SUSPEND



# 7.36.8.10 SUBSCRIBE\_RESUME

Address offset: 0x0A0

Subscribe configuration for task RESUME

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task RESUME will subscribe to                 |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

#### 7.36.8.11 EVENTS\_STOPPED

Address offset: 0x104

TWI stopped







# 7.36.8.12 EVENTS\_ERROR

Address offset: 0x124

TWI error



#### 7.36.8.13 EVENTS SUSPENDED

Address offset: 0x148

SUSPEND task has been issued, TWI traffic is now suspended.



#### 7.36.8.14 EVENTS\_RXSTARTED

Address offset: 0x14C

Receive sequence started



#### 7.36.8.15 EVENTS\_TXSTARTED

Address offset: 0x150

Transmit sequence started





# 7.36.8.16 EVENTS\_LASTRX

Address offset: 0x15C

Byte boundary, starting to receive the last byte

| Bit n | umber    |               |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |               |              |                         | А                                                               |
| Rese  | et 0x000 | 00000         |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |               |              |                         | Description                                                     |
| Α     | RW       | EVENTS_LASTRX |              |                         | Byte boundary, starting to receive the last byte                |
|       |          |               | NotGenerated | 0                       | Event not generated                                             |
|       |          |               | Generated    | 1                       | Event generated                                                 |

# 7.36.8.17 EVENTS\_LASTTX

Address offset: 0x160

Byte boundary, starting to transmit the last byte

| Bit n | umber   |               |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |               |              |                        | A                                                               |
| Rese  | t 0x000 | 00000         |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |               |              |                        |                                                                 |
| Α     | RW      | EVENTS_LASTTX |              |                        | Byte boundary, starting to transmit the last byte               |
|       |         |               | NotGenerated | 0                      | Event not generated                                             |
|       |         |               | Generated    | 1                      | Event generated                                                 |

#### 7.36.8.18 PUBLISH\_STOPPED

Address offset: 0x184

Publish configuration for event STOPPED

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A A                                                   |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |          |                         |                                                                 |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that event STOPPED will publish to.                |
| В     | RW       | EN    |          |                         |                                                                 |
|       |          |       | Disabled | 0                       | Disable publishing                                              |
|       |          |       | Enabled  | 1                       | Enable publishing                                               |

#### 7.36.8.19 PUBLISH\_ERROR

Address offset: 0x1A4

Publish configuration for event ERROR

NORDIC\*



#### 7.36.8.20 PUBLISH SUSPENDED

Address offset: 0x1C8

Publish configuration for event SUSPENDED



# 7.36.8.21 PUBLISH\_RXSTARTED

Address offset: 0x1CC

Publish configuration for event RXSTARTED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         |                                                               |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event RXSTARTED will publish to.            |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 1                       | Enable publishing                                             |

#### 7.36.8.22 PUBLISH\_TXSTARTED

Address offset: 0x1D0

Publish configuration for event TXSTARTED







# 7.36.8.23 PUBLISH\_LASTRX

Address offset: 0x1DC

Publish configuration for event LASTRX



# 7.36.8.24 PUBLISH\_LASTTX

Address offset: 0x1E0

Publish configuration for event LASTTX



#### 7.36.8.25 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit r | umber    |                |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|----------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                |          |                         | F D C B A                                                       |
| Rese  | et 0x000 | 00000          |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |                |          |                         |                                                                 |
| Α     | RW       | LASTTX_STARTRX |          |                         | Shortcut between event LASTTX and task STARTRX                  |
|       |          |                | Disabled | 0                       | Disable shortcut                                                |
|       |          |                | Enabled  | 1                       | Enable shortcut                                                 |
| В     | RW       | LASTTX_SUSPEND |          |                         | Shortcut between event LASTTX and task SUSPEND                  |
|       |          |                | Disabled | 0                       | Disable shortcut                                                |
|       |          |                | Enabled  | 1                       | Enable shortcut                                                 |
| С     | RW       | LASTTX_STOP    |          |                         | Shortcut between event LASTTX and task STOP                     |
|       |          |                | Disabled | 0                       | Disable shortcut                                                |
|       |          |                | Enabled  | 1                       | Enable shortcut                                                 |
| D     | RW       | LASTRX_STARTTX |          |                         | Shortcut between event LASTRX and task STARTTX                  |
|       |          |                | Disabled | 0                       | Disable shortcut                                                |
|       |          |                | Enabled  | 1                       | Enable shortcut                                                 |
| F     | RW       | LASTRX_STOP    |          |                         | Shortcut between event LASTRX and task STOP                     |
|       |          |                | Disabled | 0                       | Disable shortcut                                                |
|       |          |                | Enabled  | 1                       | Enable shortcut                                                 |
|       |          |                |          |                         |                                                                 |





# 7.36.8.26 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit r | umber    |           |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|------------------------|------------------------------------------------------------------|
| ID    |          |           |          |                        | J I H G F D A                                                    |
| Rese  | et 0x000 | 00000     |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |          |           |          |                        |                                                                  |
| Α     | RW       | STOPPED   |          |                        | Enable or disable interrupt for event STOPPED                    |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| D     | RW       | ERROR     |          |                        | Enable or disable interrupt for event ERROR                      |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| F     | RW       | SUSPENDED |          |                        | Enable or disable interrupt for event SUSPENDED                  |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| G     | RW       | RXSTARTED |          |                        | Enable or disable interrupt for event RXSTARTED                  |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| Н     | RW       | TXSTARTED |          |                        | Enable or disable interrupt for event TXSTARTED                  |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| I     | RW       | LASTRX    |          |                        | Enable or disable interrupt for event LASTRX                     |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
| J     | RW       | LASTTX    |          |                        | Enable or disable interrupt for event LASTTX                     |
|       |          |           | Disabled | 0                      | Disable                                                          |
|       |          |           | Enabled  | 1                      | Enable                                                           |
|       |          |           |          |                        |                                                                  |

# 7.36.8.27 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber   |           |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |           |          | J                      | I HGF D A                                                       |
| Rese  | t 0x000 | 00000     |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |           |          |                        |                                                                 |
| Α     | RW      | STOPPED   |          |                        | Write '1' to enable interrupt for event STOPPED                 |
|       |         |           | Set      | 1                      | Enable                                                          |
|       |         |           | Disabled | 0                      | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                      | Read: Enabled                                                   |
| D     | RW      | ERROR     |          |                        | Write '1' to enable interrupt for event ERROR                   |
|       |         |           | Set      | 1                      | Enable                                                          |
|       |         |           | Disabled | 0                      | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                      | Read: Enabled                                                   |
| F     | RW      | SUSPENDED |          |                        | Write '1' to enable interrupt for event SUSPENDED               |
|       |         |           | Set      | 1                      | Enable                                                          |
|       |         |           | Disabled | 0                      | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                      | Read: Enabled                                                   |
| G     | RW      | RXSTARTED |          |                        | Write '1' to enable interrupt for event RXSTARTED               |



| Bit r | umber    |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          | J                       | I HGF D A                                                       |
| Rese  | et 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |          |                         | Description                                                     |
|       |          |           | Set      | 1                       | Enable                                                          |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| Н     | RW       | TXSTARTED |          |                         | Write '1' to enable interrupt for event TXSTARTED               |
|       |          |           | Set      | 1                       | Enable                                                          |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| 1     | RW       | LASTRX    |          |                         | Write '1' to enable interrupt for event LASTRX                  |
|       |          |           | Set      | 1                       | Enable                                                          |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| J     | RW       | LASTTX    |          |                         | Write '1' to enable interrupt for event LASTTX                  |
|       |          |           | Set      | 1                       | Enable                                                          |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
|       |          |           |          |                         |                                                                 |

# 7.36.8.28 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit r | umber    |           |          | 313 | 30 29 | 9 28 | 27 2 | 26 25 | 5 24 | 1 23 | 3 22  | 21   | L 20 | 19   | 18 | 17    | 16  | 15  | 14 : | 13 1 | 12 1 | 111   | o 9  | 8   | 7   | 6 | 5 - | 4 3 | 3 2 | 1 | 0 |
|-------|----------|-----------|----------|-----|-------|------|------|-------|------|------|-------|------|------|------|----|-------|-----|-----|------|------|------|-------|------|-----|-----|---|-----|-----|-----|---|---|
| ID    |          |           |          |     |       |      |      |       | J    | -1   | ı     |      | Н    | G    | F  |       |     |     |      |      |      |       | D    |     |     |   |     |     |     | Α |   |
| Rese  | et 0x000 | 00000     |          | 0   | 0 0   | 0    | 0    | 0 0   | 0    | 0    | 0 0   | 0    | 0    | 0    | 0  | 0     | 0   | 0   | 0    | 0    | 0    | 0 0   | 0    | 0   | 0   | 0 | 0   | 0 ( | 0   | 0 | 0 |
|       |          |           |          |     |       |      |      |       |      |      |       |      |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| Α     | RW       | STOPPED   |          |     |       |      |      |       |      | W    | Vrite | · '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ver  | nt ST | ОР   | PEC | )   |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | oisab | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | t  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| D     | RW       | ERROR     |          |     |       |      |      |       |      | W    | Vrite | · '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ver  | nt EF | RRO  | R   |     |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | isab  | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | ł  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| F     | RW       | SUSPENDED |          |     |       |      |      |       |      | W    | Vrite | · '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ver  | nt Sl | JSP  | ENE | DED |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | oisab | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | t  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| G     | RW       | RXSTARTED |          |     |       |      |      |       |      | W    | Vrite | · '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ver  | nt R  | (ST/ | ١RT | ED  |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | oisab | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | t  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| Н     | RW       | TXSTARTED |          |     |       |      |      |       |      | W    | Vrite | e '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ver  | it T  | (ST/ | ART | ED  |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | Disab | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | t  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
| 1     | RW       | LASTRX    |          |     |       |      |      |       |      | W    | Vrite | e '1 | ' to | dis  | ab | le ir | ter | rup | t fo | r e  | ven  | nt L/ | STF  | RX  |     |   |     |     |     |   |   |
|       |          |           | Clear    | 1   |       |      |      |       |      | D    | Disab | le   |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Disabled | 0   |       |      |      |       |      | R    | lead: | : Di | isab | oled | t  |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           | Enabled  | 1   |       |      |      |       |      | R    | lead: | : Er | nab  | led  |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |
|       |          |           |          |     |       |      |      |       |      |      |       |      |      |      |    |       |     |     |      |      |      |       |      |     |     |   |     |     |     |   |   |

647



| Bit number            | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|----------------------|------------------------------------------------------------------|
| ID                    |                      | J I H G F D A                                                    |
| Reset 0x00000000      | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID R/W Field Value ID |                      | Description                                                      |
| J RW LASTTX           |                      | Write '1' to disable interrupt for event LASTTX                  |
| Clear                 | 1                    | Disable                                                          |
| Disabled              | 0                    | Read: Disabled                                                   |
| Enabled               | 1                    | Read: Enabled                                                    |

#### 7.36.8.29 ERRORSRC

Address offset: 0x4C4

Error source

| Bit r | umber    |         |             | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|-------------|------------------------|-----------------------------------------------------------------|
| ID    |          |         |             |                        | СВА                                                             |
| Rese  | et 0x000 | 00000   |             | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |             |                        |                                                                 |
| Α     | RW       | OVERRUN |             |                        | Overrun error                                                   |
|       |          |         |             |                        | A new byte was received before previous byte got                |
|       |          |         |             |                        | transferred into RXD buffer. (Previous data is lost)            |
|       |          |         | NotReceived | 0                      | Error did not occur                                             |
|       |          |         | Received    | 1                      | Error occurred                                                  |
| В     | RW       | ANACK   |             |                        | NACK received after sending the address (write '1' to clear)    |
|       |          |         | NotReceived | 0                      | Error did not occur                                             |
|       |          |         | Received    | 1                      | Error occurred                                                  |
| С     | RW       | DNACK   |             |                        | NACK received after sending a data byte (write '1' to clear)    |
|       |          |         | NotReceived | 0                      | Error did not occur                                             |
|       |          |         | Received    | 1                      | Error occurred                                                  |

#### 7.36.8.30 ENABLE

Address offset: 0x500

**Enable TWIM** 



#### 7.36.8.31 PSEL.SCL

Address offset: 0x508 Pin select for SCL signal





#### 7.36.8.32 PSEL.SDA

Address offset: 0x50C

Pin select for SDA signal



#### 7.36.8.33 FREQUENCY

Address offset: 0x524

TWI frequency. Accuracy depends on the HFCLK source selected.



#### 7.36.8.34 RXD.PTR

Address offset: 0x534

Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

#### 7.36.8.35 RXD.MAXCNT

Address offset: 0x538

Maximum number of bytes in receive buffer



#### 7.36.8.36 RXD.AMOUNT

Address offset: 0x53C

Number of bytes transferred in the last transaction



#### 7.36.8.37 RXD.LIST

Address offset: 0x540 EasyDMA list type

| Bit number            | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|------------------------|-----------------------------------------------------------------|
| ID                    |                        | ААА                                                             |
| Reset 0x00000000      | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field Value ID |                        | Description                                                     |
| A RW LIST             |                        | List type                                                       |
| Disabled              | 0                      | Disable EasyDMA list                                            |
| ArrayList             | 1                      | Use array list                                                  |

#### 7.36.8.38 TXD.PTR

Address offset: 0x544

Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

#### 7.36.8.39 TXD.MAXCNT

Address offset: 0x548

Maximum number of bytes in transmit buffer



#### 7.36.8.40 TXD.AMOUNT

Address offset: 0x54C

Number of bytes transferred in the last transaction



#### 7.36.8.41 TXD.LIST

Address offset: 0x550 EasyDMA list type



#### 7.36.8.42 ADDRESS

Address offset: 0x588

Address used in the TWI transfer



| Bit number       |          | 31 30 29 28 27 26 25 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|----------------------|--------------------------------------------------------------------|
| ID               |          |                      | A A A A A A                                                        |
| Reset 0x00000000 |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID R/W Field     | Value ID | Value                | Description                                                        |

A RW ADDRESS Address used in the TWI transfer

# 7.36.9 Electrical specification

# 7.36.9.1 TWIM interface electrical specifications

| Symbol                  | Description                                            | Min. | Тур. | Max. | Units |
|-------------------------|--------------------------------------------------------|------|------|------|-------|
| f <sub>TWIM,SCL</sub>   | Bit rates for TWIM <sup>28</sup>                       | 100  |      | 1000 | kbps  |
| t <sub>TWIM.START</sub> | Time from STARTRX/STARTTX task to transmission started |      | 1.5  |      | μs    |

# 7.36.9.2 Two Wire Interface Master (TWIM) timing specifications

| Symbol                            | Description                                              | Min. | Тур. | Max. | Units |
|-----------------------------------|----------------------------------------------------------|------|------|------|-------|
| t <sub>TWIM,SU_DAT</sub>          | Data setup time before positive edge on SCL – all modes  | 20   |      |      | ns    |
| t <sub>TWIM,HD_DAT</sub>          | Data hold time after negative edge on SCL – 100, 250 and | 500  |      | 625  | ns    |
|                                   | 400 kbps                                                 |      |      |      |       |
| t <sub>TWIM,HD_DAT</sub>          | Data hold time after negative edge on SCL – 1000 kbps    | 250  |      | 315  | ns    |
| $t_{TWIM,HD\_STA,100kbps}$        | TWIM master hold time for START and repeated START       | 9900 |      |      | ns    |
|                                   | condition, 100 kbps                                      |      |      |      |       |
| t <sub>TWIM,HD_STA,250kbps</sub>  | TWIM master hold time for START and repeated START       | 3900 |      |      | ns    |
|                                   | condition, 250 kbps                                      |      |      |      |       |
| $t_{TWIM,HD\_STA,400kbps}$        | TWIM master hold time for START and repeated START       | 2400 |      |      | ns    |
|                                   | condition, 400 kbps                                      |      |      |      |       |
| t <sub>TWIM,HD_STA,1000kbp</sub>  | TWIM master hold time for START and repeated START       | 900  |      |      | ns    |
|                                   | condition, 1000 kbps                                     |      |      |      |       |
| $t_{TWIM,SU\_STO,100kbps}$        | TWIM master setup time from SCL high to STOP condition,  | 5000 |      |      | ns    |
|                                   | 100 kbps                                                 |      |      |      |       |
| t <sub>TWIM,SU_STO,250kbps</sub>  | TWIM master setup time from SCL high to STOP condition,  | 2000 |      |      | ns    |
|                                   | 250 kbps                                                 |      |      |      |       |
| t <sub>TWIM,SU_STO,400kbps</sub>  | TWIM master setup time from SCL high to STOP condition,  | 1250 |      |      | ns    |
|                                   | 400 kbps                                                 |      |      |      |       |
| t <sub>TWIM,SU_STO,1000kbps</sub> | TWIM master setup time from SCL high to STOP condition,  | 500  |      |      | ns    |
|                                   | 1000 kbps                                                |      |      |      |       |
| t <sub>TWIM,BUF,100kbps</sub>     | TWIM master bus free time between STOP and START         | 5250 |      |      | ns    |
|                                   | conditions, 100 kbps                                     |      |      |      |       |
| t <sub>TWIM,BUF,250kbps</sub>     | TWIM master bus free time between STOP and START         | 2250 |      |      | ns    |
|                                   | conditions, 250 kbps                                     |      |      |      |       |
| t <sub>TWIM,BUF,400kbps</sub>     | TWIM master bus free time between STOP and START         | 1500 |      |      | ns    |
|                                   | conditions, 400 kbps                                     |      |      |      |       |
| t <sub>TWIM,BUF,1000kbps</sub>    | TWIM master bus free time between STOP and START         | 750  |      |      | ns    |
|                                   | conditions, 1000 kbps                                    |      |      |      |       |



High bit rates or stronger pull-ups may require GPIOs to be set as High Drive, see GPIO — General purpose input/output on page 224 for more details.



Figure 221: TWIM timing diagram, 1 byte transaction

## 7.36.10 Pullup resistor



Figure 222: Recommended TWIM pullup value vs. line capacitance

- The I<sup>2</sup>C specification allows a line capacitance of 400 pF at most.
- The value of internal pullup resistor (R<sub>PU</sub>) for nRF5340 can be found in GPIO General purpose input/output on page 224.

# 7.37 TWIS — $I^2C$ compatible two-wire interface slave with EasyDMA

TWI slave with EasyDMA (TWIS) is a two-wire half-duplex slave which can communicate with a master device connected to the same bus.

Listed here are the main features for TWIS:

- I<sup>2</sup>C compatible
- Supported baud rates: 100 and 400 kbps
- EasyDMA





Figure 223: TWI slave with EasyDMA

A typical TWI setup consists of one master and one or more slaves. For an example, see the following figure. TWIS is only able to operate with a single master on the TWI bus.



Figure 224: A typical TWI setup comprising one master and three slaves

The following figure shows the TWI slave state machine.





Figure 225: TWI slave state machine

The following table contains descriptions of the symbols used in the state machine.

| Symbol            | Туре         | Description                                                                                              |
|-------------------|--------------|----------------------------------------------------------------------------------------------------------|
| ENABLE            | Register     | The TWI slave has been enabled via the ENABLE register.                                                  |
| PREPARETX         | Task         | The TASKS_PREPARETX task has been triggered.                                                             |
| STOP              | Task         | The TASKS_STOP task has been triggered.                                                                  |
| PREPARERX         | Task         | The TASKS_PREPARERX task has been triggered.                                                             |
| STOPPED           | Event        | The EVENTS_STOPPED event was generated.                                                                  |
| RXSTARTED         | Event        | The EVENTS_RXSTARTED event was generated.                                                                |
| TXSTARTED         | Event        | The EVENTS_TXSTARTED event was generated.                                                                |
| TX prepared       | Internal     | Internal flag indicating that a TASKS_PREPARETX task has been triggered. This flag is not visible to the |
|                   |              | user.                                                                                                    |
| RX prepared       | Internal     | Internal flag indicating that a TASKS_PREPARERX task has been triggered. This flag is not visible to the |
|                   |              | user.                                                                                                    |
| Unprepare TX      | Internal     | Clears the internal 'TX prepared' flag until next TASKS_PREPARETX task.                                  |
| Unprepare RX      | Internal     | Clears the internal 'RX prepared' flag until next TASKS_PREPARERX task.                                  |
| Stop condition    | TWI protocol | A TWI stop condition was detected.                                                                       |
| Restart condition | TWI protocol | A TWI restart condition was detected.                                                                    |

Table 169: TWI slave state machine symbols

TWIS can perform clock stretching, with the premise that the master is able to support it.



It operates in a low power mode while waiting for a TWI master to initiate a transfer. As long as TWIS is not addressed, it will remain in this low power mode.

To secure correct behavior of the TWI slave, PSEL.SCL, PSEL.SDA, CONFIG, and the ADDRESS[n] registers must be configured prior to enabling the TWI slave through the ENABLE register. Similarly, changing these settings must be performed while the TWI slave is disabled. Failing to do so may result in unpredictable behavior.

#### 7.37.1 Shared resources

TWIS shares registers and other resources with other peripherals that have the same ID as TWIS.

Therefore, you must disable all peripherals that have the same ID as the TWI slave before TWIS can be configured and used. Disabling a peripheral that has the same ID as the TWI slave will not reset any of the registers that are shared with TWIS. It is therefore important to configure all relevant registers explicitly to secure that TWIS operates correctly.

The Instantiation table in Peripherals on page 150 shows which peripherals have the same ID as TWIS.

## 7.37.2 EasyDMA

TWIS implements EasyDMA for accessing RAM without CPU involvement.

The following table shows the Easy DMA channels that TWIS implements.

| Channel | Туре   | Register Cluster |
|---------|--------|------------------|
| TXD     | READER | TXD              |
| RXD     | WRITER | RXD              |

Table 170: TWIS EasyDMA Channels

For detailed information regarding the use of EasyDMA, see EasyDMA on page 154.

The STOPPED event indicates that EasyDMA has finished accessing the buffer in RAM.

# 7.37.3 TWIS responding to a read command

Before TWIS can respond to a read command, it must be configured correctly and enabled via the ENABLE register. When enabled, TWIS will be in its IDLE state.

A read command is started when the TWI master generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 1 (WRITE=0, READ=1). The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) response from the TWI slave.

TWIS is able to listen for up to two addresses at the same time. This is configured in the ADDRESS registers and the CONFIG register.

TWIS will only acknowledge (ACK) the read command if the address presented by the master matches one of the addresses the slave is configured to listen for. TWIS will generate a READ event when it acknowledges the read command.

TWIS is only able to detect a read command from the IDLE state.

TWIS will set an internal 'TX prepared' flag when the PREPARETX task is triggered.

When the read command is received, TWIS will enter the TX state if the internal 'TX prepared' flag is set.

If the internal 'TX prepared' flag is not set when the read command is received, TWIS will stretch the master's clock until the PREPARETX task is triggered and the internal 'TX prepared' flag is set.



TWIS will generate the TXSTARTED event and clear the 'TX prepared' flag ('unprepare TX') when it enters the TX state. In this state TWIS will send the data bytes found in the transmit buffer to the master using the master's clock.

TWIS will go back to the IDLE state if the TWI slave receives a restart command when it is in the TX state.

TWIS is stopped when it receives the stop condition from the TWI master. A STOPPED event will be generated when the transaction has stopped. TWIS will clear the 'TX prepared' flag ('unprepare TX') and go back to the IDLE state when it has stopped.

The transmit buffer is located in RAM at the address specified in the TXD.PTR register. TWIS will only be able to send TXD.MAXCNT bytes from the transmit buffer for each transaction. If the TWI master forces the slave to send more than TXD.MAXCNT bytes, the slave will send the byte specified in the ORC register to the master instead. If this happens, an ERROR event will be generated.

The EasyDMA configuration registers RXD.PTR, TXD.PTR, RXD.AMOUNT, and TXD.AMOUNT, are latched when the TXSTARTED event is generated.

TWIS can be forced to stop by triggering the STOP task. A STOPPED event will be generated when TWIS has stopped. TWIS will clear the 'TX prepared' flag and go back to the IDLE state when it has stopped, see also Terminating an ongoing TWI transaction on page 659.

Each byte sent from the slave will be followed by an ACK/NACK bit sent from the master. The TWI master will generate a NACK following the last byte that it wants to receive to tell the slave to release the bus so that the TWI master can generate the stop condition. The TXD.AMOUNT register can be queried after a transaction to see how many bytes were sent.

A typical TWIS read command response is illustrated in the following figure, including clock stretching following a SUSPEND task.



Figure 226: TWIS responding to a read command

# 7.37.4 TWIS responding to a write command

Before TWIS can respond to a write command, TWIS must be configured correctly and enabled via the ENABLE register. When enabled, TWIS will be in its IDLE state.

A write command is started when the TWI master generates a start condition on the TWI bus, followed by clocking out the address and the READ/WRITE bit set to 0 (WRITE=0, READ=1). The READ/WRITE bit is followed by an ACK/NACK bit (ACK=0 or NACK=1) response from the slave.

TWIS is able to listen for up to two addresses at the same time. This is configured in the ADDRESS registers and the CONFIG register.



TWIS will only acknowledge (ACK) the write command if the address presented by the master matches one of the addresses the slave is configured to listen for. TWIS will generate a WRITE event if it acknowledges the write command.

TWIS is only able to detect a write command from the IDLE state.

TWIS will set an internal 'RX prepared' flag when the PREPARERX task is triggered.

When the write command is received, TWIS will enter the RX state if the internal 'RX prepared' flag is set.

If the internal 'RX prepared' flag is not set when the write command is received, TWIS will stretch the master's clock until the PREPARERX task is triggered and the internal 'RX prepared' flag is set.

TWIS will generate the RXSTARTED event and clear the internal 'RX prepared' flag ('unprepare RX') when it enters the RX state. In this state, TWIS will be able to receive the bytes sent by the TWI master.

TWIS will go back to the IDLE state if TWIS receives a restart command when it is in the RX state.

TWIS is stopped when it receives the stop condition from the TWI master. A STOPPED event will be generated when the transaction has stopped. TWIS will clear the internal 'RX prepared' flag ('unprepare RX') and go back to the IDLE state when it has stopped.

The receive buffer is located in RAM at the address specified in the RXD.PTR register. TWIS will only be able to receive as many bytes as specified in the RXD.MAXCNT register. If the TWI master tries to send more bytes to the slave than it can receive, the extra bytes are discarded and NACKed by the slave. If this happens, an ERROR event will be generated.

The EasyDMA configuration registers, see RXD.PTR etc., are latched when the RXSTARTED event is generated.

TWIS can be forced to stop by triggering the STOP task. A STOPPED event will be generated when TWIS has stopped. TWIS will clear the internal 'RX prepared' flag and go back to the IDLE state when it has stopped, see also Terminating an ongoing TWI transaction on page 659.

TWIS will generate an ACK after every byte received from the master. The RXD.AMOUNT register can be queried after a transaction to see how many bytes were received.

A typical TWIS write command response is illustrated in the following figure, including clock stretching following a SUSPEND task.



Figure 227: TWIS responding to a write command

# 7.37.5 Master repeated start sequence

An example of a repeated start sequence is one in which the TWI master writes two bytes to TWIS followed by reading four bytes from the slave.

This is illustrated in the following figure.

In this example, the receiver does not know what the master wants to read in advance. This information is in the first two received bytes of the write in the repeated start sequence. To guarantee that the CPU is able to process the received data before TWIS starts to reply to the read command, the SUSPEND task is triggered via a shortcut from the READ event generated when the read command is received. When the CPU has processed the incoming data and prepared the correct data response, the CPU will resume the transaction by triggering the RESUME task.



Figure 228: Repeated start sequence

## 7.37.6 Terminating an ongoing TWI transaction

In some situations, e.g. if the external TWI master is not responding correctly, it may be required to terminate an ongoing transaction.

This can be achieved by triggering the STOP task. In this situation, a STOPPED event will be generated when the TWI has stopped independent of whether or not a STOP condition has been generated on the TWI bus. The TWI slave will release the bus when it has stopped and go back to its IDLE state.

# 7.37.7 Low power

To ensure lowest possible power consumption when the peripheral is not needed stop and disable TWIS.

The STOP task may not be always needed (the peripheral might already be stopped), but if the task is triggered, software shall wait until the STOPPED event is generated before disabling the peripheral through the ENABLE register.

# 7.37.8 Slave mode pin configuration

The SCL and SDA signals are mapped to physical pins using the PSEL.SCL and PSEL.SDA registers.

The PSEL.SCL and PSEL.SDA registers and their configurations are only used as long as TWIS is enabled, and retained only as long as the device is in System ON mode. When the peripheral is disabled, the pins will behave as regular GPIOs, and use the configuration in their respective OUT bit field and PIN\_CNF[n] register. PSEL.SCL and PSEL.SDA must only be configured when TWIS is disabled.

To secure correct signal levels on the pins used by TWIS while in System OFF mode, and when TWIS is disabled, these pins must be configured in the GPIO peripheral as described in the following table.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.



| TWI slave signal | TWI slave pin            | Direction | Output value   | Drive strength |
|------------------|--------------------------|-----------|----------------|----------------|
| SCL              | As specified in PSEL.SCL | Input     | Not applicable | SOD1           |
| SDA              | As specified in PSEL.SDA | Input     | Not applicable | SOD1           |

Table 171: GPIO configuration before enabling peripheral

# 7.37.9 Registers

| Base address Domain      | Peripheral       | Instance   | Secure mapping | DMA security | Description                 | Configuration |
|--------------------------|------------------|------------|----------------|--------------|-----------------------------|---------------|
| 0x50008000               | INI TIMUS        | TWIS0 : S  | US             | SA           | Two-wire interface slave 0  |               |
| 0x40008000               | APPLICATION TWIS |            | 03             | SA           | TWO-WIFE IIILEFFACE Slave O |               |
| 0x50009000               | INI TIMIS        | TWIS1:S    | US             | SA           | Two-wire interface slave 1  |               |
| 0x40009000               | APPLICATION TWIS |            | 03             | JA.          | TWO-WITE IIILETTACE STAVE I |               |
| 0x5000B000<br>APPLICATIO | IN TWIS          | TWIS2 : S  | US             | SA           | Two-wire interface slave 2  |               |
| 0x4000B000               | 14 1 1415        | TWIS2 : NS | 03             | JA.          | Two wire interface slave 2  |               |
| 0x5000C000 APPLICATIO    | N TWIS           | TWIS3 : S  | US             | SA           | Two-wire interface slave 3  |               |
| 0x4000C000               | 14 1 4415        | TWIS3 : NS | 03             | JA           | Two wire interface slave 5  |               |
| 0x41013000 NETWORK       | TWIS             | TWIS0      | NS             | NA           | Two-wire interface slave 0  |               |

Table 172: Instances

| Register            | Offset | Security | Description                                          |
|---------------------|--------|----------|------------------------------------------------------|
| TASKS_STOP          | 0x014  |          | Stop TWI transaction                                 |
| TASKS_SUSPEND       | 0x01C  |          | Suspend TWI transaction                              |
| TASKS_RESUME        | 0x020  |          | Resume TWI transaction                               |
| TASKS_PREPARERX     | 0x030  |          | Prepare the TWI slave to respond to a write command  |
| TASKS_PREPARETX     | 0x034  |          | Prepare the TWI slave to respond to a read command   |
| SUBSCRIBE_STOP      | 0x094  |          | Subscribe configuration for task STOP                |
| SUBSCRIBE_SUSPEND   | 0x09C  |          | Subscribe configuration for task SUSPEND             |
| SUBSCRIBE_RESUME    | 0x0A0  |          | Subscribe configuration for task RESUME              |
| SUBSCRIBE_PREPARERX | 0x0B0  |          | Subscribe configuration for task PREPARERX           |
| SUBSCRIBE_PREPARETX | 0x0B4  |          | Subscribe configuration for task PREPARETX           |
| EVENTS_STOPPED      | 0x104  |          | TWI stopped                                          |
| EVENTS_ERROR        | 0x124  |          | TWI error                                            |
| EVENTS_RXSTARTED    | 0x14C  |          | Receive sequence started                             |
| EVENTS_TXSTARTED    | 0x150  |          | Transmit sequence started                            |
| EVENTS_WRITE        | 0x164  |          | Write command received                               |
| EVENTS_READ         | 0x168  |          | Read command received                                |
| PUBLISH_STOPPED     | 0x184  |          | Publish configuration for event STOPPED              |
| PUBLISH_ERROR       | 0x1A4  |          | Publish configuration for event ERROR                |
| PUBLISH_RXSTARTED   | 0x1CC  |          | Publish configuration for event RXSTARTED            |
| PUBLISH_TXSTARTED   | 0x1D0  |          | Publish configuration for event TXSTARTED            |
| PUBLISH_WRITE       | 0x1E4  |          | Publish configuration for event WRITE                |
| PUBLISH_READ        | 0x1E8  |          | Publish configuration for event READ                 |
| SHORTS              | 0x200  |          | Shortcuts between local events and tasks             |
| INTEN               | 0x300  |          | Enable or disable interrupt                          |
| INTENSET            | 0x304  |          | Enable interrupt                                     |
| INTENCLR            | 0x308  |          | Disable interrupt                                    |
| ERRORSRC            | 0x4D0  |          | Error source                                         |
| MATCH               | 0x4D4  |          | Status register indicating which address had a match |
| ENABLE              | 0x500  |          | Enable TWIS                                          |
| PSEL.SCL            | 0x508  |          | Pin select for SCL signal                            |
| PSEL.SDA            | 0x50C  |          | Pin select for SDA signal                            |



| Register   | Offset | Security | Description                                                                             |
|------------|--------|----------|-----------------------------------------------------------------------------------------|
| RXD.PTR    | 0x534  |          | RXD Data pointer                                                                        |
| RXD.MAXCNT | 0x538  |          | Maximum number of bytes in RXD buffer                                                   |
| RXD.AMOUNT | 0x53C  |          | Number of bytes transferred in the last RXD transaction                                 |
| RXD.LIST   | 0x540  |          | EasyDMA list type                                                                       |
| TXD.PTR    | 0x544  |          | TXD Data pointer                                                                        |
| TXD.MAXCNT | 0x548  |          | Maximum number of bytes in TXD buffer                                                   |
| TXD.AMOUNT | 0x54C  |          | Number of bytes transferred in the last TXD transaction                                 |
| TXD.LIST   | 0x550  |          | EasyDMA list type                                                                       |
| ADDRESS[n] | 0x588  |          | TWI slave address n                                                                     |
| CONFIG     | 0x594  |          | Configuration register for the address match mechanism                                  |
| ORC        | 0x5C0  |          | Over-read character. Character sent out in case of an over-read of the transmit buffer. |

Table 173: Register overview

## 7.37.9.1 TASKS\_STOP

Address offset: 0x014 Stop TWI transaction

| Bit n | umber   |            |         | 31 30 29 28 27 2 | 6 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|---------|------------------|-----------------------------------------------------------------------|
| ID    |         |            |         |                  | A                                                                     |
| Rese  | t 0x000 | 00000      |         | 0 0 0 0 0 0      | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |
| ID    |         |            |         |                  |                                                                       |
| Α     | W       | TASKS_STOP |         |                  | Stop TWI transaction                                                  |
|       |         |            | Trigger | 1                | Trigger task                                                          |

## 7.37.9.2 TASKS\_SUSPEND

Address offset: 0x01C Suspend TWI transaction

|           |               | Trigger | 1                   | Trigger task                                                   |     |
|-----------|---------------|---------|---------------------|----------------------------------------------------------------|-----|
| A W       | TASKS_SUSPEND |         |                     | Suspend TWI transaction                                        |     |
| ID R/W    |               |         |                     |                                                                |     |
| Reset 0x0 | 0000000       |         | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                        | ) 0 |
| ID        |               |         |                     |                                                                | Α   |
| Bit numbe | r             |         | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | . 0 |

## 7.37.9.3 TASKS\_RESUME

Address offset: 0x020
Resume TWI transaction





## 7.37.9.4 TASKS\_PREPARERX

Address offset: 0x030

Prepare the TWI slave to respond to a write command



#### 7.37.9.5 TASKS PREPARETX

Address offset: 0x034

Prepare the TWI slave to respond to a read command

| Bit n | umber    |                 |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                 |         |                         | A                                                               |
| Rese  | et 0x000 | 00000           |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                 |         |                         |                                                                 |
| Α     | W        | TASKS_PREPARETX |         |                         | Prepare the TWI slave to respond to a read command              |
|       |          |                 | Trigger | 1                       | Trigger task                                                    |

## 7.37.9.6 SUBSCRIBE\_STOP

Address offset: 0x094

Subscribe configuration for task STOP

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         | Description                                                     |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to                   |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.37.9.7 SUBSCRIBE\_SUSPEND

Address offset: 0x09C

4406\_640 v1.3

Subscribe configuration for task SUSPEND

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|---|
| ID    |          |       |          | В                       | A A A A A A                                                 | Α |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 |
| ID    |          |       |          |                         |                                                             |   |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task SUSPEND will subscribe to            |   |
| В     | RW       | EN    |          |                         |                                                             |   |
|       |          |       | Disabled | 0                       | Disable subscription                                        |   |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |   |



## 7.37.9.8 SUBSCRIBE\_RESUME

Address offset: 0x0A0

Subscribe configuration for task RESUME



## 7.37.9.9 SUBSCRIBE\_PREPARERX

Address offset: 0x0B0

Subscribe configuration for task PREPARERX



#### 7.37.9.10 SUBSCRIBE PREPARETX

Address offset: 0x0B4

Subscribe configuration for task PREPARETX

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |       |          | В                       | A A A A A A A                                                   |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |       |          |                         |                                                                 |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task PREPARETX will subscribe to              |
| В     | RW       | EN    |          |                         |                                                                 |
|       |          |       | Disabled | 0                       | Disable subscription                                            |
|       |          |       |          |                         |                                                                 |

#### 7.37.9.11 EVENTS\_STOPPED

Address offset: 0x104

TWI stopped



| Bit n | umber            |                |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|----------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |                  |                |              |                        | А                                                               |
| Rese  | Reset 0x00000000 |                |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |                  |                |              |                        |                                                                 |
| Α     | RW               | EVENTS_STOPPED |              |                        | TWI stopped                                                     |
|       |                  |                | NotGenerated | 0                      | Event not generated                                             |
|       |                  |                | Generated    | 1                      | Event generated                                                 |

## 7.37.9.12 EVENTS\_ERROR

Address offset: 0x124

TWI error

| Bit n | umber   |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                        | А                                                               |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                        | Description                                                     |
| Α     | RW      | EVENTS_ERROR |              |                        | TWI error                                                       |
|       |         |              | NotGenerated | 0                      | Event not generated                                             |
|       |         |              | Generated    | 1                      | Event generated                                                 |

## 7.37.9.13 EVENTS\_RXSTARTED

Address offset: 0x14C Receive sequence started



## 7.37.9.14 EVENTS\_TXSTARTED

Address offset: 0x150

Transmit sequence started

| Bit n | umber            |                  |              | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|------------------|------------------|--------------|----------------------|------------------------------------------------------------------|
| ID    |                  |                  |              |                      | А                                                                |
| Rese  | Reset 0x00000000 |                  |              | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |                  |                  |              |                      | Description                                                      |
| Α     | RW               | EVENTS_TXSTARTED |              |                      | Transmit sequence started                                        |
|       |                  |                  | NotGenerated | 0                    | Event not generated                                              |
|       |                  |                  | Generated    | 1                    | Event generated                                                  |

## 7.37.9.15 EVENTS\_WRITE

Address offset: 0x164

Write command received



| Bit n | umber   |              |              | 31 30 29 28 27 26 2 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|---------------------|---------------------------------------------------------------------|
| ID    |         |              |              |                     | A                                                                   |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |              |              |                     |                                                                     |
| Α     | RW      | EVENTS_WRITE |              |                     | Write command received                                              |
|       |         |              | NotGenerated | 0                   | Event not generated                                                 |
|       |         |              | Generated    | 1                   | Event generated                                                     |

## 7.37.9.16 EVENTS\_READ

Address offset: 0x168
Read command received

| Bit number |             |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------|-------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID         |             |              |                         | А                                                               |
| Reset 0x00 | 000000      |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W     |             |              |                         | Description                                                     |
| A RW       | EVENTS_READ |              |                         | Read command received                                           |
|            |             | NotGenerated | 0                       | Event not generated                                             |
|            |             | Generated    | 1                       | Event generated                                                 |

## 7.37.9.17 PUBLISH\_STOPPED

Address offset: 0x184

Publish configuration for event STOPPED

| Bit n  | umber    |             |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0      |
|--------|----------|-------------|----------|-------------------------|----------------------------------------------------------------------|
| ID     |          |             |          | В                       | A A A A A A A A                                                      |
| Rese   | t 0x000  | 00000       |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                              |
| ID     |          |             |          |                         | Description                                                          |
|        |          |             |          |                         |                                                                      |
| Α      | RW       | CHIDX       |          | [2550]                  | DPPI channel that event STOPPED will publish to.                     |
| A<br>B | RW<br>RW | CHIDX<br>EN |          | [2550]                  | DPPI channel that event STOPPED will publish to.                     |
|        |          |             | Disabled | 0                       | DPPI channel that event STOPPED will publish to.  Disable publishing |

# 7.37.9.18 PUBLISH\_ERROR

Address offset: 0x1A4

Publish configuration for event ERROR

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------|-----|
| ID    |         |       |          | В                       | A A A A A A                                               | А А |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   | 0 0 |
| ID    |         |       |          |                         |                                                           |     |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event ERROR will publish to.            |     |
| В     | RW      | EN    |          |                         |                                                           |     |
|       |         |       | Disabled | 0                       | Disable publishing                                        |     |
|       |         |       | Enabled  | 1                       | Enable publishing                                         |     |

## 7.37.9.19 PUBLISH\_RXSTARTED

Address offset: 0x1CC



#### Publish configuration for event RXSTARTED



## 7.37.9.20 PUBLISH\_TXSTARTED

Address offset: 0x1D0

Publish configuration for event TXSTARTED



## 7.37.9.21 PUBLISH\_WRITE

Address offset: 0x1E4

Publish configuration for event WRITE



## 7.37.9.22 PUBLISH\_READ

Address offset: 0x1E8

Publish configuration for event READ





## 7.37.9.23 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber    |               |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |               |          |                        | В А                                                             |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |               |          |                        | Description                                                     |
| Α     | RW       | WRITE_SUSPEND |          |                        | Shortcut between event WRITE and task SUSPEND                   |
|       |          |               | Disabled | 0                      | Disable shortcut                                                |
|       |          |               | Enabled  | 1                      | Enable shortcut                                                 |
| В     | RW       | READ_SUSPEND  |          |                        | Shortcut between event READ and task SUSPEND                    |
|       |          |               | Disabled | 0                      | Disable shortcut                                                |
|       |          |               | Enabled  | 1                      | Enable shortcut                                                 |

#### 7.37.9.24 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit n | umber    |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          | H G                     | F E B A                                                         |
| Rese  | et 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |          |                         |                                                                 |
| Α     | RW       | STOPPED   |          |                         | Enable or disable interrupt for event STOPPED                   |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| В     | RW       | ERROR     |          |                         | Enable or disable interrupt for event ERROR                     |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| E     | RW       | RXSTARTED |          |                         | Enable or disable interrupt for event RXSTARTED                 |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| F     | RW       | TXSTARTED |          |                         | Enable or disable interrupt for event TXSTARTED                 |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| G     | RW       | WRITE     |          |                         | Enable or disable interrupt for event WRITE                     |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| Н     | RW       | READ      |          |                         | Enable or disable interrupt for event READ                      |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |



## 7.37.9.25 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber   |           |          | 31 30 29 28 | 27 26 2 | 25 24 | 23 22 2 | 21 20  | 19   | 18 17 | 16  | 15   | 14   | 13 1 | 2 1 | 1 10 | 9   | 8    | 7 ( | 5 5 | 4 | 3 | 2 1 | . 0 |
|-------|---------|-----------|----------|-------------|---------|-------|---------|--------|------|-------|-----|------|------|------|-----|------|-----|------|-----|-----|---|---|-----|-----|
| ID    |         |           |          |             | Н       | G     |         | F      | Ε    |       |     |      |      |      |     |      | В   |      |     |     |   |   | Δ   | 1   |
| Rese  | t 0x000 | 00000     |          | 0 0 0 0     | 0 0     | 0 0   | 0 0     | 0 0    | 0    | 0 0   | 0   | 0    | 0    | 0 0  | ) ( | 0    | 0   | 0    | 0 ( | 0 0 | 0 | 0 | 0 0 | 0 ( |
|       |         |           |          |             |         |       |         |        |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| Α     | RW      | STOPPED   |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | STC  | PP  | ED   |     |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | 2      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | oled |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| В     | RW      | ERROR     |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | ERF  | ROR |      |     |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | 2      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | oled |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| E     | RW      | RXSTARTED |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | RXS  | TAI | RTE  | )   |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | 2      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| F     | RW      | TXSTARTED |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | TXS  | TAF | RTEE | )   |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | :      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | oled |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| G     | RW      | WRITE     |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | WR   | ITE |      |     |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | 2      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
| Н     | RW      | READ      |          |             |         |       | Write ' | '1' to | ena  | ble i | nte | rrup | t fo | r ev | ent | RE/  | \D  |      |     |     |   |   |     |     |
|       |         |           | Set      | 1           |         |       | Enable  | :      |      |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Disabled | 0           |         |       | Read:   | Disab  | oled |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |
|       |         |           | Enabled  | 1           |         |       | Read:   | Enabl  | led  |       |     |      |      |      |     |      |     |      |     |     |   |   |     |     |

## 7.37.9.26 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit n | umber    |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          | H G                     | F E B A                                                         |
| Rese  | et 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |          |                         |                                                                 |
| Α     | RW       | STOPPED   |          |                         | Write '1' to disable interrupt for event STOPPED                |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | ERROR     |          |                         | Write '1' to disable interrupt for event ERROR                  |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| Ε     | RW       | RXSTARTED |          |                         | Write '1' to disable interrupt for event RXSTARTED              |
|       |          |           | Clear    | 1                       | Disable                                                         |



| Bit numb  | er       |           |          | 3130 | 0 29 2 | 8 27 | 26 2           | 25 2 | 4 23 | 3 22  | 21 2   | 0 19 | 18   | 17 1   | 6 1  | 5 14 | 13    | 12 1  | 1 10 | 9    | 8   | 7 | 6 | 5 4 | 3 | 2 | 1 ( |
|-----------|----------|-----------|----------|------|--------|------|----------------|------|------|-------|--------|------|------|--------|------|------|-------|-------|------|------|-----|---|---|-----|---|---|-----|
| ID        |          |           |          |      |        |      | Н              | G    |      |       | F      | E    |      |        |      |      |       |       |      | В    |     |   |   |     |   |   | Α   |
| Reset 0x0 | 0000     | 0000      |          | 0 0  | 0 0    | 0 0  | 0              | 0 0  | 0    | 0 0   | 0 0    | 0    | 0    | 0 0    | 0    | 0    | 0     | 0 0   | 0    | 0    | 0   | 0 | 0 | 0 0 | 0 | 0 | 0 ( |
|           |          |           |          |      |        |      |                |      |      |       |        |      |      |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Disabled | 0    |        |      |                |      | R    | ead:  | Disa   | ble  | d    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Enabled  | 1    |        |      |                |      | R    | ead:  | Enal   | bled | ł    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
| F RW      | V        | TXSTARTED |          |      |        |      |                |      | W    | Vrite | '1' to | o di | sabl | e inte | errı | ıpt  | for   | event | TX   | STA  | RTE | D |   |     |   |   |     |
|           |          |           | Clear    | 1    |        |      |                |      | D    | isabl | е      |      |      |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Disabled | 0    |        |      |                |      | R    | ead:  | Disa   | ble  | d    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Enabled  | 1    |        |      |                |      | R    | ead:  | Enal   | bled | i    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
| G RW      | ٧        | WRITE     |          |      |        |      |                |      | W    | Vrite | '1' to | o di | sabl | e inte | errı | ıpt  | for   | even  | W    | RITE |     |   |   |     |   |   |     |
|           |          |           | Clear    | 1    |        |      |                |      | D    | isabl | е      |      |      |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Disabled | 0    |        |      |                |      | R    | ead:  | Disa   | ble  | d    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Enabled  | 1    |        |      |                |      | R    | ead:  | Enal   | bled | i    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
| H RW      | ٧        | READ      |          |      |        |      |                |      | W    | Vrite | '1' to | o di | sabl | e inte | errı | ıpt  | for ( | event | RE   | AD   |     |   |   |     |   |   |     |
|           |          |           | Clear    | 1    |        |      |                |      | D    | isabl | e      |      |      |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           | Disabled | 0         |          |      |        |      | Read: Disabled |      |      |       |        |      |      |        |      |      |       |       |      |      |     |   |   |     |   |   |     |
|           |          |           | Enabled  | 1    |        |      |                |      | R    | ead:  | Enal   | bled | 1    |        |      |      |       |       |      |      |     |   |   |     |   |   |     |

#### 7.37.9.27 ERRORSRC

Address offset: 0x4D0

Error source



#### 7.37.9.28 MATCH

Address offset: 0x4D4

Status register indicating which address had a match



#### 7.37.9.29 ENABLE

Address offset: 0x500



#### **Enable TWIS**



## 7.37.9.30 PSEL.SCL

Address offset: 0x508

Pin select for SCL signal

| Bit r | umber    |         |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         | С            | ваааа                   |                                                                 |
| Rese  | et OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                         |
| ID    |          |         |              |                         |                                                                 |
| Α     | RW       | PIN     |              | [031]                   | Pin number                                                      |
| В     | RW       | PORT    |              | [01]                    | Port number                                                     |
| С     | RW       | CONNECT |              |                         | Connection                                                      |
|       |          |         | Disconnected | 1                       | Disconnect                                                      |
|       |          |         | Connected    | 0                       | Connect                                                         |

#### 7.37.9.31 PSEL.SDA

Address offset: 0x50C

Pin select for SDA signal

| Bit r | umber   |         |              | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|--------------|------------------------|------------------------------------------------------------------|
| ID    | ID      |         |              | С                      | ВАААА                                                            |
| Rese  | t OxFFF | FFFFF   |              | 1 1 1 1 1 1 1 :        | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                          |
| ID    |         |         |              |                        |                                                                  |
| Α     | RW      | PIN     |              | [031]                  | Pin number                                                       |
| В     | RW      | PORT    |              | [01]                   | Port number                                                      |
| С     | RW      | CONNECT |              |                        | Connection                                                       |
|       |         |         | Disconnected | 1                      | Disconnect                                                       |
|       |         |         | Connected    | 0                      | Connect                                                          |

#### 7.37.9.32 RXD.PTR

Address offset: 0x534 RXD Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

#### 7.37.9.33 RXD.MAXCNT

Address offset: 0x538

Maximum number of bytes in RXD buffer



#### 7.37.9.34 RXD.AMOUNT

Address offset: 0x53C

Number of bytes transferred in the last RXD transaction



#### 7.37.9.35 RXD.LIST

Address offset: 0x540

EasyDMA list type



#### 7.37.9.36 TXD.PTR

Address offset: 0x544

TXD Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

#### 7.37.9.37 TXD.MAXCNT

Address offset: 0x548

Maximum number of bytes in TXD buffer



#### 7.37.9.38 TXD.AMOUNT

Address offset: 0x54C

Number of bytes transferred in the last TXD transaction



#### 7.37.9.39 TXD.LIST

Address offset: 0x550

EasyDMA list type

| Bit r | number   |        |           | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|-----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |        |           |                         | АА                                                              |
| Rese  | et 0x000 | 000000 |           | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |        |           |                         | Description                                                     |
| Α     | RW       | LIST   |           |                         | List type                                                       |
|       |          |        | Disabled  | 0                       | Disable EasyDMA list                                            |
|       |          |        | ArrayList | 1                       | Use array list                                                  |

## 7.37.9.40 ADDRESS[n] (n=0..1)

Address offset:  $0x588 + (n \times 0x4)$ 

TWI slave address n





#### 7.37.9.41 CONFIG

Address offset: 0x594

Configuration register for the address match mechanism



#### 7.37.9.42 ORC

Address offset: 0x5C0

Over-read character. Character sent out in case of an over-read of the transmit buffer.



# 7.37.10 Electrical specification

# 7.37.10.1 TWIS slave timing specifications

| Symbol                           | Description                                               | Min. | Тур. | Max. | Units |
|----------------------------------|-----------------------------------------------------------|------|------|------|-------|
| f <sub>TWIS,SCL</sub>            | Bit rates for TWIS <sup>29</sup>                          | 100  |      | 400  | kbps  |
| t <sub>TWIS,START</sub>          | Time from PREPARERX/PREPARETX task to ready to receive/   |      | 1.5  |      | μs    |
|                                  | transmit                                                  |      |      |      |       |
| t <sub>TWIS,SU_DAT</sub>         | Data setup time before positive edge on SCL – all modes   | 20   |      |      | ns    |
| t <sub>TWIS,HD_DAT</sub>         | Data hold time after negative edge on SCL – all modes     | 350  |      | 600  | ns    |
| $t_{TWIS,HD\_STA,100kbps}$       | TWI slave hold time from for START condition (SDA low to  | 500  |      |      | ns    |
|                                  | SCL low), 100 kbps                                        |      |      |      |       |
| t <sub>TWIS,HD_STA,400kbps</sub> | TWI slave hold time from for START condition (SDA low to  | 500  |      |      | ns    |
|                                  | SCL low), 400 kbps                                        |      |      |      |       |
| t <sub>TWIS,SU_STO,100kbps</sub> | TWI slave setup time from SCL high to STOP condition, 100 | 500  |      |      | ns    |
|                                  | kbps                                                      |      |      |      |       |

High bit rates or stronger pull-ups may require GPIOs to be set as High Drive, see GPIO chapter for more details.



| Symbol                           | Description                                               | Min. | Тур. | Max. | Units |
|----------------------------------|-----------------------------------------------------------|------|------|------|-------|
| t <sub>TWIS,SU_STO,400kbps</sub> | TWI slave setup time from SCL high to STOP condition, 400 | 500  |      |      | ns    |
|                                  | kbps                                                      |      |      |      |       |
| t <sub>TWIS,BUF,100kbps</sub>    | TWI slave bus free time between STOP and START            | 500  |      |      | ns    |
|                                  | conditions, 100 kbps                                      |      |      |      |       |
| t <sub>TWIS,BUF,400kbps</sub>    | TWI slave bus free time between STOP and START            | 500  |      |      | ns    |
|                                  | conditions, 400 kbps                                      |      |      |      |       |



Figure 229: TWIS timing diagram, 1 byte transaction

# 7.38 UARTE — Universal asynchronous receiver/transmitter with EasyDMA

The Universal asynchronous receiver/transmitter with EasyDMA (UARTE) offers fast, full-duplex, asynchronous serial communication. Built-in flow control (CTS, RTS) is supported in hardware at a rate up to 1 Mbps and EasyDMA data transfer to and from RAM.

The main features of UARTE are the following:

- Full-duplex operation
- · Automatic hardware flow control
- · Optional even parity bit checking and generation
- EasyDMA
- Up to 1 Mbps baudrate
- Return to IDLE between transactions supported (when using HW flow control)
- One or two stop bit
- Least significant bit (LSB) first



Figure 230: UARTE configuration

The GPIOs used for each UART interface can be chosen from any GPIO on the device and are independently configurable. This enables device pinout flexibility and efficient use of board space and signal routing.

**Note:** The external crystal oscillator must be enabled to obtain sufficient clock accuracy for stable communication. See CLOCK — Clock control on page 73 for more information.



## 7.38.1 EasyDMA

UARTE implements EasyDMA for reading and writing to and from the RAM.

If the TXD.PTR and the RXD.PTR are not pointing to the Data RAM region, an EasyDMA transfer may result in a HardFault or RAM corruption. See Memory on page 19 for more information about the different memory regions.

The RXD.PTR, TXD.PTR, RXD.MAXCNT, and TXD.MAXCNT registers are double-buffered. They can be updated and prepared for the next reception or transmission immediately after having received the RXSTARTED or TXSTARTED event.

The ENDRX and ENDTX events indicate that the EasyDMA is finished accessing the RX or TX buffer in RAM.

#### 7.38.2 Transmission

The first step of a DMA transmission is storing bytes in the transmit buffer and configuring EasyDMA. This is achieved by writing the initial address pointer to TXD.PTR, and the number of bytes to transmit from the RAM buffer to TXD.MAXCNT. The UARTE transmission is started by triggering the STARTTX task.

After each byte has been sent over the TXD line, a TXDRDY event will be generated.

When all bytes have been transmitted, the transmission will automatically end and the ENDTX event will be generated.

A UARTE transmission sequence is stopped by triggering the STOPTX task. A TXSTOPPED event will be generated when the UARTE transmitter has stopped.

If the ENDTX event has not already been generated when the UARTE transmitter has come to a stop, UARTE will generate the ENDTX event explicitly even though all bytes specified in the TXD.MAXCNT register have not been transmitted.

If flow control is enabled through the HWFC field in the CONFIG register, a transmission will be automatically suspended when CTS is deactivated and resumed when CTS is activated again, as shown in the following figure. A byte that is in transmission when CTS is deactivated will be fully transmitted before the transmission is suspended.



Figure 231: UARTE transmission

The UARTE transmitter is in its lowest activity level consuming the least amount of energy when it is stopped. That is, before it is started via STARTTX or after it has been stopped via STOPTX and the



TXSTOPPED event has been generated. See POWER — Power control on page 46 for more information about power modes.

## 7.38.3 Reception

The UARTE receiver is started by triggering the STARTRX task. The UARTE receiver uses EasyDMA to store incoming data in an RX buffer in RAM.

The RX buffer is located at the address specified in the RXD.PTR register. The RXD.PTR register is double-buffered and it can be updated and prepared for the next STARTRX task immediately after the RXSTARTED event is generated. The size of the RX buffer is specified in the RXD.MAXCNT register. UARTE generates an ENDRX event when it has filled up the RX buffer, as seen in the following figure.

For each byte received over the RXD line, an RXDRDY event is generated. This event is likely to occur before the corresponding data has been transferred to Data RAM.

The RXD.AMOUNT register can be queried following an ENDRX event to see how many new bytes have been transferred to the RX buffer in RAM since the previous ENDRX event.



Figure 232: UARTE reception

The UARTE receiver is stopped by triggering the STOPRX task. An RXTO event is generated when the UARTE has stopped. UARTE makes sure that an impending ENDRX event is generated before the RXTO event is generated. This means that UARTE guarantees that no ENDRX event is generated after RXTO, unless UARTE is restarted or a FLUSHRX command is issued after the RXTO event is generated.

**Note:** If the ENDRX event has not been generated when the UARTE receiver stops, indicating that all pending content in the RX FIFO has been moved to the RX buffer, UARTE generates the ENDRX event explicitly even though the RX buffer is not full. In this scenario the ENDRX event is generated before the RXTO event is generated.

To determine the amount of bytes the RX buffer has received, the CPU can read the RXD.AMOUNT register following the ENDRX event or the RXTO event.

NORDIC\*

UARTE can receive up to four bytes after the STOPRX task has been triggered, if these are sent in succession immediately after the RTS signal is deactivated.

After the RXTO event is generated, the internal RX FIFO may still contain data. To move this data to RAM, the FLUSHRX task must be triggered. The RX buffer should be emptied, or the RXD.PTR register should be updated before the FLUSHRX task is triggered. This ensures the data in the RX buffer is not overwritten. To make sure that all data in the RX FIFO is moved to the RX buffer, the RXD.MAXCNT register must be set to RXD.MAXCNT > 4, as seen in the following figure. The UARTE will generate the ENDRX event after completing the FLUSHRX task even if the RX FIFO was empty or if the RX buffer does not fill up. After the ENDRX event, the RXD.AMOUNT register holds the actual amount of bytes transferred to the RX buffer.



Figure 233: UARTE reception with forced stop via STOPRX

If hardware flow control is enabled through the HWFC field in the CONFIG register, the RTS signal will be deactivated when the receiver is stopped via the STOPRX task or when the UARTE is only able to receive four more bytes in its internal RX FIFO.

With flow control disabled, the UARTE will function in the same way as when the flow control is enabled except that the RTS line will not be used. This means that no signal will be generated when the UARTE has reached the point where it is only able to receive four more bytes in its internal RX FIFO. Data received when the internal RX FIFO is filled up, will be lost.

The UARTE receiver will be in its lowest activity level, and consume the least amount of energy, when it is stopped, i.e. before it is started via STARTRX or after it has been stopped via STOPRX and the RXTO event has been generated. See POWER — Power control on page 46 for more information about power modes.

#### 7.38.4 Frror conditions

An ERROR event, in the form of a framing error, will be generated if a valid stop bit is not detected in a frame. Another ERROR event, in the form of a break condition, will be generated if the RXD line is held active low for longer than the length of a data frame. Effectively, a framing error is always generated before a break condition occurs.

An ERROR event will not stop reception. If the error was a parity error, the received byte is still transferred into Data RAM along with any following bytes. If a framing error occurs (wrong stop bit), that byte will not be stored into Data RAM but following incoming bytes will.

# 7.38.5 Using the UARTE without flow control

If flow control is not enabled, the interface will behave as if the CTS and RTS lines are kept active all the time.

# 7.38.6 Parity and stop bit configuration

Automatic even parity generation for both transmission and reception can be configured using the register CONFIG on page 696. If odd parity is desired, it can be configured using the register CONFIG on page 696. See the register description for details.

NORDIC

The amount of stop bits can also be configured through the register CONFIG on page 696.

## 7.38.7 Low power

To ensure lowest possible power consumption when the peripheral is not needed, stop and disable UARTE.

The STOPTX and STOPRX tasks may not be always needed (the peripheral might already be stopped), but if STOPTX and/or STOPRX is sent, software shall wait until the TXSTOPPED and/or RXTO event is received in response, before disabling the peripheral through the ENABLE register.

# 7.38.8 Pin configuration

The different signals RXD, CTS (Clear To Send, active low), RTS (Request To Send, active low), and TXD associated with UARTE are mapped to physical pins according to the configuration specified in the PSEL.RXD, PSEL.RTS, and PSEL.TXD registers respectively.

The PSEL.RXD, PSEL.CTS, PSEL.RTS, and PSEL.TXD registers and their configurations are only used as long as the UARTE is enabled, and retained only for the duration the device is in System ON mode. PSEL.RXD, PSEL.RTS, PSEL.RTS, and PSEL.TXD must only be configured when the UARTE is disabled.

To secure correct signal levels on the pins by the UARTE when in System OFF mode, the pins must be configured in the GPIO peripheral as described in the following table.

Only one peripheral can be assigned to drive a particular GPIO pin at a time. Failing to do so may result in unpredictable behavior.

| UARTE signal | UARTE pin                | Direction | Output value   |
|--------------|--------------------------|-----------|----------------|
| RXD          | As specified in PSEL.RXD | Input     | Not applicable |
| CTS          | As specified in PSEL.CTS | Input     | Not applicable |
| RTS          | As specified in PSEL.RTS | Output    | 1              |
| TXD          | As specified in PSEL.TXD | Output    | 1              |

Table 174: GPIO configuration before enabling peripheral

# 7.38.9 Registers

| Base address                            | Domain      | Peripheral | Instance    | Secure mapping | DMA security | Description               | Configuration |
|-----------------------------------------|-------------|------------|-------------|----------------|--------------|---------------------------|---------------|
| 0x50008000                              |             |            | UARTEO : S  |                |              | Universal asynchronous    |               |
|                                         | APPLICATION | UARTE      | UARTEO: NS  | US             | SA           | receiver/transmitter with |               |
| 0x40008000                              |             |            | UARTEU . NS |                |              | EasyDMA 0                 |               |
| 0x50009000                              |             |            | UARTE1:S    |                |              | Universal asynchronous    |               |
|                                         | APPLICATION | UARTE      | UARTE1: NS  | US             | SA           | receiver/transmitter with |               |
| 0x40009000                              |             |            | UARTEL: NS  |                |              | EasyDMA 1                 |               |
| 0x5000B000                              |             |            | UARTE2 : S  |                |              | Universal asynchronous    |               |
|                                         | APPLICATION | UARTE      | UARTE2 : NS | US             | SA           | receiver/transmitter with |               |
| 0.0000000000000000000000000000000000000 |             |            | UARTEZ . NS |                |              | EasyDMA 2                 |               |
| 0x5000C000                              |             |            | UARTE3 : S  |                |              | Universal asynchronous    |               |
|                                         | APPLICATION | UARTE      |             | US             | SA           | receiver/transmitter with |               |
| 0x4000C000                              |             |            | UARTE3 : NS |                |              | EasyDMA 3                 |               |
| 0x41013000                              | NETWORK     | UARTE      | UARTE0      | NS             | NA           | Universal asynchronous    |               |
|                                         |             |            |             |                |              | receiver/transmitter      |               |

Table 175: Instances



| Register          | Offset | Security | Description                                                            |
|-------------------|--------|----------|------------------------------------------------------------------------|
| TASKS_STARTRX     | 0x000  |          | Start UART receiver                                                    |
| TASKS_STOPRX      | 0x004  |          | Stop UART receiver                                                     |
| TASKS_STARTTX     | 0x008  |          | Start UART transmitter                                                 |
| TASKS_STOPTX      | 0x00C  |          | Stop UART transmitter                                                  |
| TASKS_FLUSHRX     | 0x02C  |          | Flush RX FIFO into RX buffer                                           |
| SUBSCRIBE_STARTRX | 0x080  |          | Subscribe configuration for task STARTRX                               |
| SUBSCRIBE_STOPRX  | 0x084  |          | Subscribe configuration for task STOPRX                                |
| SUBSCRIBE_STARTTX | 0x088  |          | Subscribe configuration for task STARTTX                               |
| SUBSCRIBE_STOPTX  | 0x08C  |          | Subscribe configuration for task STOPTX                                |
| SUBSCRIBE_FLUSHRX | 0x0AC  |          | Subscribe configuration for task FLUSHRX                               |
| EVENTS_CTS        | 0x100  |          | CTS is activated (set low). Clear To Send.                             |
| EVENTS_NCTS       | 0x104  |          | CTS is deactivated (set high). Not Clear To Send.                      |
| EVENTS_RXDRDY     | 0x108  |          | Data received in RXD (but potentially not yet transferred to Data RAM) |
| EVENTS_ENDRX      | 0x110  |          | Receive buffer is filled up                                            |
| EVENTS_TXDRDY     | 0x11C  |          | Data sent from TXD                                                     |
| EVENTS_ENDTX      | 0x120  |          | Last TX byte transmitted                                               |
| EVENTS_ERROR      | 0x124  |          | Error detected                                                         |
| EVENTS_RXTO       | 0x144  |          | Receiver timeout                                                       |
| EVENTS_RXSTARTED  | 0x14C  |          | UART receiver has started                                              |
| EVENTS_TXSTARTED  | 0x150  |          | UART transmitter has started                                           |
| EVENTS_TXSTOPPED  | 0x158  |          | Transmitter stopped                                                    |
| PUBLISH_CTS       | 0x180  |          | Publish configuration for event CTS                                    |
| PUBLISH_NCTS      | 0x184  |          | Publish configuration for event NCTS                                   |
| PUBLISH_RXDRDY    | 0x188  |          | Publish configuration for event RXDRDY                                 |
| PUBLISH_ENDRX     | 0x190  |          | Publish configuration for event ENDRX                                  |
| PUBLISH_TXDRDY    | 0x19C  |          | Publish configuration for event TXDRDY                                 |
| PUBLISH_ENDTX     | 0x1A0  |          | Publish configuration for event ENDTX                                  |
| PUBLISH_ERROR     | 0x1A4  |          | Publish configuration for event ERROR                                  |
| PUBLISH_RXTO      | 0x1C4  |          | Publish configuration for event RXTO                                   |
| PUBLISH_RXSTARTED | 0x1CC  |          | Publish configuration for event RXSTARTED                              |
| PUBLISH TXSTARTED | 0x1D0  |          | Publish configuration for event TXSTARTED                              |
| PUBLISH_TXSTOPPED | 0x1D8  |          | Publish configuration for event TXSTOPPED                              |
| SHORTS            | 0x200  |          | Shortcuts between local events and tasks                               |
| INTEN             | 0x300  |          | Enable or disable interrupt                                            |
| INTENSET          | 0x304  |          | Enable interrupt                                                       |
| INTENCLR          | 0x308  |          | Disable interrupt                                                      |
| ERRORSRC          | 0x480  |          | Error source                                                           |
| ENABLE            | 0x500  |          | Enable UART                                                            |
| PSEL.RTS          | 0x508  |          | Pin select for RTS signal                                              |
| PSEL.TXD          | 0x50C  |          | Pin select for TXD signal                                              |
| PSEL.CTS          | 0x510  |          | Pin select for CTS signal                                              |
| PSEL.RXD          | 0x514  |          | Pin select for RXD signal                                              |
| BAUDRATE          | 0x524  |          | Baud rate. Accuracy depends on the HFCLK source selected.              |
| RXD.PTR           | 0x534  |          | Data pointer                                                           |
| RXD.MAXCNT        | 0x538  |          | Maximum number of bytes in receive buffer                              |
| RXD.AMOUNT        | 0x53C  |          | Number of bytes transferred in the last transaction                    |
| TXD.PTR           | 0x544  |          | Data pointer                                                           |
| TXD.MAXCNT        | 0x548  |          | Maximum number of bytes in transmit buffer                             |
| TXD.AMOUNT        | 0x54C  |          | Number of bytes transferred in the last transaction                    |
| CONFIG            | 0x56C  |          | Configuration of parity and hardware flow control                      |
| -                 |        |          | 0                                                                      |

Table 176: Register overview



## 7.38.9.1 TASKS\_STARTRX

Address offset: 0x000 Start UART receiver



#### **7.38.9.2 TASKS STOPRX**

Address offset: 0x004 Stop UART receiver

| Α     | W       | TASKS_STOPRX | Trigger  |                   | Stop UART receiver<br>Trigger task                                  |
|-------|---------|--------------|----------|-------------------|---------------------------------------------------------------------|
| ID    | R/W     | Field        | Value ID | Value             | Description                                                         |
| Rese  | t 0x000 | 00000        |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
| ID    |         |              |          |                   | A                                                                   |
| Bit n | umber   |              |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

## 7.38.9.3 TASKS\_STARTTX

Address offset: 0x008 Start UART transmitter



## 7.38.9.4 TASKS\_STOPTX

Address offset: 0x00C Stop UART transmitter



## 7.38.9.5 TASKS\_FLUSHRX

Address offset: 0x02C



#### Flush RX FIFO into RX buffer



## 7.38.9.6 SUBSCRIBE\_STARTRX

Address offset: 0x080

Subscribe configuration for task STARTRX

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                     |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STARTRX will subscribe to                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       |          |                         |                                                                 |

## 7.38.9.7 SUBSCRIBE\_STOPRX

Address offset: 0x084

Subscribe configuration for task STOPRX

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 |
|-------|---------|-------|----------|-------------------------|-------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     |
| ID    |         |       |          |                         |                                                             |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STOPRX will subscribe to             |
| В     | RW      | EN    |          |                         |                                                             |
|       |         |       | Disabled | 0                       | Disable subscription                                        |
|       |         |       | Enabled  | 1                       | Enable subscription                                         |

## 7.38.9.8 SUBSCRIBE\_STARTTX

Address offset: 0x088

Subscribe configuration for task STARTTX







## 7.38.9.9 SUBSCRIBE\_STOPTX

Address offset: 0x08C

Subscribe configuration for task STOPTX



## 7.38.9.10 SUBSCRIBE\_FLUSHRX

Address offset: 0x0AC

Subscribe configuration for task FLUSHRX



#### 7.38.9.11 EVENTS CTS

Address offset: 0x100

CTS is activated (set low). Clear To Send.



#### 7.38.9.12 EVENTS NCTS

Address offset: 0x104

CTS is deactivated (set high). Not Clear To Send.





## 7.38.9.13 EVENTS\_RXDRDY

Address offset: 0x108

Data received in RXD (but potentially not yet transferred to Data RAM)

| Bit n            | umber |               |                                         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|-------|---------------|-----------------------------------------|-------------------------|-----------------------------------------------------------------|
| ID               |       |               |                                         |                         | A                                                               |
| Reset 0x00000000 |       | 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                         |                                                                 |
| ID               |       |               |                                         |                         | Description                                                     |
| Α                | RW    | EVENTS_RXDRDY |                                         |                         | Data received in RXD (but potentially not yet transferred to    |
|                  |       |               |                                         |                         | Data RAM)                                                       |
|                  |       |               | NotGenerated                            | 0                       | Event not generated                                             |
|                  |       |               | Generated                               | 1                       | Event generated                                                 |

## 7.38.9.14 EVENTS\_ENDRX

Address offset: 0x110

Receive buffer is filled up

| Bit n | umber   |              |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                        | A                                                               |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                        |                                                                 |
| Α     | RW      | EVENTS_ENDRX |              |                        | Receive buffer is filled up                                     |
|       |         |              | NotGenerated | 0                      | Event not generated                                             |
|       |         |              | Generated    | 1                      | Event generated                                                 |

## 7.38.9.15 EVENTS\_TXDRDY

Address offset: 0x11C
Data sent from TXD

| Bit n | umber   |               |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |               |              |                         | А                                                               |
| Rese  | t 0x000 | 00000         |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |               |              |                         |                                                                 |
| Α     | RW      | EVENTS_TXDRDY |              |                         | Data sent from TXD                                              |
|       |         |               | NotGenerated | 0                       | Event not generated                                             |
|       |         |               | Generated    | 1                       | Event generated                                                 |

## 7.38.9.16 EVENTS\_ENDTX

Address offset: 0x120 Last TX byte transmitted



| Bit number   |              |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------------|--------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID           |              |              |                         | А                                                               |
| Reset 0x0000 | 00000        |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W       |              |              |                         |                                                                 |
| A RW         | EVENTS_ENDTX |              |                         | Last TX byte transmitted                                        |
|              |              | NotGenerated | 0                       | Event not generated                                             |
|              |              | Generated    | 1                       | Event generated                                                 |

## 7.38.9.17 EVENTS\_ERROR

Address offset: 0x124

Error detected

| Bit n | umber   |              |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |              |              |                         | А                                                               |
| Rese  | t 0x000 | 00000        |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |              |                         | Description                                                     |
| Α     | RW      | EVENTS_ERROR |              |                         | Error detected                                                  |
|       |         |              | NotGenerated | 0                       | Event not generated                                             |
|       |         |              | Generated    | 1                       | Event generated                                                 |

## 7.38.9.18 EVENTS\_RXTO

Address offset: 0x144 Receiver timeout

| Bit n | umber   |             |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |             |              |                         | А                                                               |
| Rese  | t 0x000 | 00000       |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |             |              |                         |                                                                 |
| Α     | RW      | EVENTS_RXTO |              |                         | Receiver timeout                                                |
|       |         |             | NotGenerated | 0                       | Event not generated                                             |
|       |         |             | Generated    | 1                       | Event generated                                                 |

## 7.38.9.19 EVENTS\_RXSTARTED

Address offset: 0x14C **UART** receiver has started

| Bit n | umber   |                  |              | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------------|--------------|------------------------|-----------------------------------------------------------------|
| ID    |         |                  |              |                        | А                                                               |
| Rese  | t 0x000 | 00000            |              | 0 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                  |              |                        | Description                                                     |
| Α     | RW      | EVENTS_RXSTARTED |              |                        | UART receiver has started                                       |
|       |         |                  | NotGenerated | 0                      | Event not generated                                             |
|       |         |                  | Generated    | 1                      | Event generated                                                 |

## 7.38.9.20 EVENTS\_TXSTARTED

Address offset: 0x150

4406\_640 v1.3

**UART** transmitter has started



| Bit number            |              | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------|--------------|-------------------------|---------------------------------------------------------------|
| ID                    |              |                         | A                                                             |
| Reset 0x00000000      |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID R/W Field V        |              |                         |                                                               |
| A RW EVENTS_TXSTARTED |              |                         | UART transmitter has started                                  |
| N                     | lotGenerated | 0                       | Event not generated                                           |
| G                     | Generated    | 1                       | Event generated                                               |

## 7.38.9.21 EVENTS\_TXSTOPPED

Address offset: 0x158 Transmitter stopped

| Bit n | umber   |                  |              | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------------|--------------|-------------------------|---------------------------------------------------------------|
| ID    |         |                  |              |                         | А                                                             |
| Rese  | t 0x000 | 00000            |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |                  |              |                         |                                                               |
| Α     | RW      | EVENTS_TXSTOPPED |              |                         | Transmitter stopped                                           |
|       |         |                  | NotGenerated | 0                       | Event not generated                                           |
|       |         |                  | Generated    | 1                       | Event generated                                               |

## 7.38.9.22 PUBLISH\_CTS

Address offset: 0x180

Publish configuration for event CTS

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event CTS will publish to.                    |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       |          |                         |                                                                 |

## 7.38.9.23 PUBLISH\_NCTS

Address offset: 0x184

Publish configuration for event NCTS

| Bit n | umber    |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 | 4 3 | 2 1 0 |
|-------|----------|-------|----------|-------------------------|-----------------------------------------------------|-----|-------|
| ID    |          |       |          | В                       | ААА                                                 | А А | A A A |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0               | 0 0 | 0 0 0 |
| ID    |          |       |          |                         |                                                     |     |       |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that event NCTS will publish to.       |     |       |
| В     | RW       | EN    |          |                         |                                                     |     |       |
|       |          |       | Disabled | 0                       | Disable publishing                                  |     |       |
|       |          |       | Enabled  | 1                       | Enable publishing                                   |     |       |

## 7.38.9.24 PUBLISH\_RXDRDY

Address offset: 0x188





#### Publish configuration for event RXDRDY



## 7.38.9.25 PUBLISH\_ENDRX

Address offset: 0x190

Publish configuration for event ENDRX



### 7.38.9.26 PUBLISH\_TXDRDY

Address offset: 0x19C

Publish configuration for event TXDRDY



## 7.38.9.27 PUBLISH\_ENDTX

Address offset: 0x1A0

Publish configuration for event ENDTX





### 7.38.9.28 PUBLISH ERROR

Address offset: 0x1A4

Publish configuration for event ERROR



### 7.38.9.29 PUBLISH\_RXTO

Address offset: 0x1C4

Publish configuration for event RXTO

| Bit n | number   |        |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7  | 6 | 5 4 | 3   | 2 1 0 |
|-------|----------|--------|----------|-------------------------|-------------------------------------------------|----|---|-----|-----|-------|
| ID    |          |        |          | В                       |                                                 | Α. | Α | ΑА  | ι A | A A A |
| Rese  | et 0x000 | 000000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0  | 0 | 0 0 | 0   | 0 0 0 |
| ID    |          |        |          |                         |                                                 |    |   |     |     |       |
| Α     | RW       | CHIDX  |          | [2550]                  | DPPI channel that event RXTO will publish to.   |    |   |     |     |       |
|       |          |        |          |                         |                                                 |    |   |     |     |       |
| В     | RW       | EN     |          |                         |                                                 |    |   |     |     |       |
| В     | RW       | EN     | Disabled | 0                       | Disable publishing                              |    |   |     |     |       |

### 7.38.9.30 PUBLISH\_RXSTARTED

Address offset: 0x1CC

Publish configuration for event RXSTARTED







### 7.38.9.31 PUBLISH\_TXSTARTED

Address offset: 0x1D0

Publish configuration for event TXSTARTED



## 7.38.9.32 PUBLISH\_TXSTOPPED

Address offset: 0x1D8

Publish configuration for event TXSTOPPED



#### 7.38.9.33 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber    |               |          | 31 30 29 28 27 26 | 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------|----------|-------------------|---------------------------------------------------------------------|
| ID    |          |               |          |                   | D C                                                                 |
| Rese  | et 0x000 | 00000         |          | 0 0 0 0 0 0       | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                             |
|       |          |               |          |                   |                                                                     |
| С     | RW       | ENDRX_STARTRX |          |                   | Shortcut between event ENDRX and task STARTRX                       |
|       |          |               | Disabled | 0                 | Disable shortcut                                                    |
|       |          |               | Enabled  | 1                 | Enable shortcut                                                     |
| D     | RW       | ENDRX_STOPRX  |          |                   | Shortcut between event ENDRX and task STOPRX                        |
|       |          |               | Disabled | 0                 | Disable shortcut                                                    |
|       |          |               | Enabled  | 1                 | Enable shortcut                                                     |

### 7.38.9.34 INTEN

Address offset: 0x300

Enable or disable interrupt



| Bit r | number   |           |          | 31 30 29 28 27 26 25 24 | 1 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          |                         | L J I H G F E D C B A                                           |
|       | et 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    | R/W      | Field     |          | Value                   | Description                                                     |
| A     | RW       | CTS       |          |                         | Enable or disable interrupt for event CTS                       |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| В     | RW       | NCTS      |          |                         | Enable or disable interrupt for event NCTS                      |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| С     | RW       | RXDRDY    |          |                         | Enable or disable interrupt for event RXDRDY                    |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| D     | RW       | ENDRX     |          |                         | Enable or disable interrupt for event ENDRX                     |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| E     | RW       | TXDRDY    |          |                         | Enable or disable interrupt for event TXDRDY                    |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| F     | RW       | ENDTX     |          |                         | Enable or disable interrupt for event ENDTX                     |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| G     | RW       | ERROR     |          |                         | Enable or disable interrupt for event ERROR                     |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| Н     | RW       | RXTO      |          |                         | Enable or disable interrupt for event RXTO                      |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| I     | RW       | RXSTARTED |          |                         | Enable or disable interrupt for event RXSTARTED                 |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| J     | RW       | TXSTARTED |          |                         | Enable or disable interrupt for event TXSTARTED                 |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
| L     | RW       | TXSTOPPED |          |                         | Enable or disable interrupt for event TXSTOPPED                 |
|       |          |           | Disabled | 0                       | Disable                                                         |
|       |          |           | Enabled  | 1                       | Enable                                                          |
|       |          |           |          |                         |                                                                 |

## 7.38.9.35 INTENSET

Address offset: 0x304

Enable interrupt

| Bit nu | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID     |         |       |          |                         | L J I H G F E D C B A                                         |
| Rese   | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID     |         |       |          |                         |                                                               |
| Α      | RW      | CTS   |          |                         | Write '1' to enable interrupt for event CTS                   |
|        |         |       | Set      | 1                       | Enable                                                        |
|        |         |       | Disabled | 0                       | Read: Disabled                                                |
|        |         |       | Enabled  | 1                       | Read: Enabled                                                 |
| В      | RW      | NCTS  |          |                         | Write '1' to enable interrupt for event NCTS                  |
|        |         |       | Set      | 1                       | Enable                                                        |





| Bit n | umber   |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ( |
|-------|---------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |           |          |                         | L J I H G F E D C B /                                           |
| Rese  | t 0x000 | 00000     |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |         |           |          |                         |                                                                 |
| _     |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW      | RXDRDY    |          |                         | Write '1' to enable interrupt for event RXDRDY                  |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| D     | RW      | ENDRX     |          |                         | Write '1' to enable interrupt for event ENDRX                   |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| E     | RW      | TXDRDY    |          |                         | Write '1' to enable interrupt for event TXDRDY                  |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| F     | RW      | ENDTX     |          |                         | Write '1' to enable interrupt for event ENDTX                   |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| G     | RW      | ERROR     |          |                         | Write '1' to enable interrupt for event ERROR                   |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| Н     | RW      | RXTO      |          |                         | Write '1' to enable interrupt for event RXTO                    |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| I     | RW      | RXSTARTED |          |                         | Write '1' to enable interrupt for event RXSTARTED               |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| J     | RW      | TXSTARTED |          |                         | Write '1' to enable interrupt for event TXSTARTED               |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |
| L     | RW      | TXSTOPPED |          |                         | Write '1' to enable interrupt for event TXSTOPPED               |
|       |         |           | Set      | 1                       | Enable                                                          |
|       |         |           | Disabled | 0                       | Read: Disabled                                                  |
|       |         |           | Enabled  | 1                       | Read: Enabled                                                   |

## 7.38.9.36 INTENCLR

Address offset: 0x308

Disable interrupt

| A RW       | CTS     |    |    |       |      |      |      | W  | rite | '1' | to d | lisab | le ir | nteri | upt   | for e | even | t CT | S |     |     |     |   |     |     |   |
|------------|---------|----|----|-------|------|------|------|----|------|-----|------|-------|-------|-------|-------|-------|------|------|---|-----|-----|-----|---|-----|-----|---|
| ID R/W     |         |    |    |       |      |      |      |    |      |     |      |       |       |       |       |       |      |      |   |     |     |     |   |     |     |   |
| Reset 0x00 | 0000000 | 0  | 0  | 0 0   | 0    | 0 (  | 0    | 0  | 0    | 0   | 0    | 0 0   | 0     | 0     | 0 0   | 0     | 0 (  | 0 0  | 0 | 0 ( | ) ( | 0   | 0 | 0 ( | 0   | 0 |
| ID         |         |    |    |       |      |      |      |    | L    |     | J    | I     | Н     |       |       |       |      |      | G | F   |     |     | D | (   | В   | A |
| Bit numbe  | r       | 31 | 30 | 29 28 | 3 27 | 26 2 | 5 24 | 23 | 22   | 21  | 20 1 | .9 18 | 3 17  | 16 1  | L5 14 | 113   | 12 1 | 1 10 | 9 | 8   | 7 6 | 5 5 | 4 | 3 2 | 2 1 | 0 |

Write '1' to disable interrupt for event CTS



| Bit r | number   |           |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |          |                         | L J I H G F E D C B A                                           |
| Res   | et 0x000 | 00000     |          | 0 0 0 0 0 0 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |           |          |                         |                                                                 |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | NCTS      |          |                         | Write '1' to disable interrupt for event NCTS                   |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| С     | RW       | RXDRDY    |          |                         | Write '1' to disable interrupt for event RXDRDY                 |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| D     | RW       | ENDRX     |          |                         | Write '1' to disable interrupt for event ENDRX                  |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| E     | RW       | TXDRDY    |          |                         | Write '1' to disable interrupt for event TXDRDY                 |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| F     | RW       | ENDTX     |          |                         | Write '1' to disable interrupt for event ENDTX                  |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| G     | RW       | ERROR     |          |                         | Write '1' to disable interrupt for event ERROR                  |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| Н     | RW       | RXTO      |          |                         | Write '1' to disable interrupt for event RXTO                   |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| ı     | RW       | RXSTARTED |          |                         | Write '1' to disable interrupt for event RXSTARTED              |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| J     | RW       | TXSTARTED |          |                         | Write '1' to disable interrupt for event TXSTARTED              |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
| L     | RW       | TXSTOPPED |          |                         | Write '1' to disable interrupt for event TXSTOPPED              |
|       |          |           | Clear    | 1                       | Disable                                                         |
|       |          |           | Disabled | 0                       | Read: Disabled                                                  |
|       |          |           | Enabled  | 1                       | Read: Enabled                                                   |
|       |          |           |          |                         |                                                                 |

## 7.38.9.37 ERRORSRC

Address offset: 0x480

Error source

This register is read/write one to clear.

691 NORDIC\*

| Bit r | number   |         |            | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|------------|-------------------------|----------------------------------------------------------------------------|
| ID    |          |         |            |                         | D C B A                                                                    |
| Res   | et 0x000 | 00000   |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
| ID    |          |         |            |                         | Description                                                                |
| Α     | RW       | OVERRUN |            |                         | Overrun error                                                              |
|       |          |         |            |                         | A start bit is received while the previous data still lies in              |
|       |          |         |            |                         | RXD. (Previous data is lost.)                                              |
|       |          |         | NotPresent | 0                       | Read: error not present                                                    |
|       |          |         | Present    | 1                       | Read: error present                                                        |
| В     | RW       | PARITY  |            |                         | Parity error                                                               |
|       |          |         |            |                         | A character with bad parity is received, if HW parity check                |
|       |          |         |            |                         | is enabled.                                                                |
|       |          |         | NotPresent | 0                       | Read: error not present                                                    |
|       |          |         | Present    | 1                       | Read: error present                                                        |
| С     | RW       | FRAMING |            |                         | Framing error occurred                                                     |
|       |          |         |            |                         | A valid stop bit is not detected on the serial data input                  |
|       |          |         |            |                         | after all bits in a character have been received.                          |
|       |          |         | NotPresent | 0                       | Read: error not present                                                    |
|       |          |         | Present    | 1                       | Read: error present                                                        |
| D     | RW       | BREAK   |            |                         | Break condition                                                            |
|       |          |         |            |                         | The serial data input is '0' for longer than the length of a               |
|       |          |         |            |                         | data frame. (The data frame length is 10 bits without parity               |
|       |          |         |            |                         | bit and 11 bits with parity bit.)                                          |
|       |          |         | NotPresent | 0                       | Read: error not present                                                    |
|       |          |         | Present    | 1                       | Read: error present                                                        |
|       |          |         |            |                         |                                                                            |

### 7.38.9.38 ENABLE

Address offset: 0x500

**Enable UART** 



### 7.38.9.39 PSEL.RTS

Address offset: 0x508

Pin select for RTS signal





#### 7.38.9.40 PSEL.TXD

Address offset: 0x50C Pin select for TXD signal

| Bit n | umber           |         |                 | 31 30 29 28 27 26 25 2                  | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|-----------------|---------|-----------------|-----------------------------------------|-----------------------------------------------------------------|
| ID    |                 |         |                 | С                                       | ваааа                                                           |
| Rese  | Reset 0xFFFFFFF |         | 1 1 1 1 1 1 1 1 | . 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                                                 |
| ID    |                 |         |                 |                                         | Description                                                     |
| Α     | RW              | PIN     |                 | [031]                                   | Pin number                                                      |
| В     | RW              | PORT    |                 | [01]                                    | Port number                                                     |
| С     | RW              | CONNECT |                 |                                         | Connection                                                      |
|       |                 |         | Disconnected    | 1                                       | Disconnect                                                      |
|       |                 |         | Connected       | 0                                       | Connect                                                         |

### 7.38.9.41 PSEL.CTS

Address offset: 0x510

Pin select for CTS signal



### 7.38.9.42 PSEL.RXD

Address offset: 0x514

Pin select for RXD signal





#### 7.38.9.43 BAUDRATE

Address offset: 0x524

Baud rate. Accuracy depends on the HFCLK source selected.



#### 7.38.9.44 RXD.PTR

Address offset: 0x534

Data pointer

4406 640 v1.3



See the Memory chapter for details about which memories are available for EasyDMA.





#### 7.38.9.45 RXD.MAXCNT

Address offset: 0x538

Maximum number of bytes in receive buffer



#### 7.38.9.46 RXD.AMOUNT

Address offset: 0x53C

Number of bytes transferred in the last transaction

| A I     | R      | AMOUNT | [10xFFFF]           | Number of bytes transferred in the last transaction                |
|---------|--------|--------|---------------------|--------------------------------------------------------------------|
| ID I    |        |        |                     |                                                                    |
| Reset ( | 0x0000 | 00000  | 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                            |
| ID      |        |        |                     | A A A A A A A A A A A A A A A A A A A                              |
| Bit nun | nber   |        | 31 30 29 28 27 26 2 | 5 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 7.38.9.47 TXD.PTR

Address offset: 0x544

Data pointer



See the Memory chapter for details about which memories are available for EasyDMA.

#### 7.38.9.48 TXD.MAXCNT

Address offset: 0x548

Maximum number of bytes in transmit buffer



#### 7.38.9.49 TXD.AMOUNT

Address offset: 0x54C

Number of bytes transferred in the last transaction



#### 7.38.9.50 CONFIG

Address offset: 0x56C

Configuration of parity and hardware flow control



## 7.38.10 Electrical specification

### 7.38.10.1 UARTE electrical specification

| Symbol                   | Description                                            | Min. | Тур. | Max. | Units |
|--------------------------|--------------------------------------------------------|------|------|------|-------|
| f <sub>UARTE</sub>       | Baud rate for UARTE <sup>30</sup> .                    |      |      | 1000 | kbps  |
| t <sub>UARTE,CTSH</sub>  | CTS high time                                          | 0.5  |      |      | μs    |
| t <sub>UARTE,START</sub> | Time from STARTRX/STARTTX task to transmission started |      | 0.25 |      | μs    |

# 7.39 USBD — Universal serial bus device

The USB device (USBD) controller implements a full speed USB device function that meets 2.0 revision of the USB specification.



High baud rates may require GPIOs to be set as High Drive, see GPIO chapter for more details.



Figure 234: USB device block diagram

Listed here are the main features for USBD:

- Implements full-speed (12 Mbps) device fully compliant to Universal Serial Bus Specification Revision 2.0, including following engineering change notices (ECNs) issued by USB Implementers Forum:
  - Pull-up/pull-down Resistors ECN
  - 5V Short Circuit Withstand Requirement Change ECN
- USB device stack available in the Nordic SDK
- Integrated (on-chip) USB transceiver (PHY)
- Software controlled on-chip pull-up on D+
- Endpoints:
  - 2 control (1 IN, 1 OUT)
  - 14 bulk/interrupt (7 IN, 7 OUT)
  - 2 isochronous (1 IN, 1 OUT)
- Supports double buffering for isochronous (ISO) endpoints (IN/OUT)
- Supports USB suspend, resume, and remote wake-up
- 64 bytes buffer size for each bulk/interrupt endpoint
- Up to 1023 bytes buffer size for ISO endpoints
- EasyDMA for all data transfers

### 7.39.1 USB device states

The behavior of a USB device can be modelled through a state diagram.

The USB 2.0 Specification (see Chapter 9 USB Device Framework) defines a number of states for a USB device, as shown in the following figure.





Figure 235: Device state diagram

The device must change state according to host-initiated traffic and USB bus states. It is up to the software to implement a state machine that matches the above definition. To detect the presence or absence of USB supply (VBUS), two events USBDETECTED and USBREMOVED can be used to implement the state machine. For more details on these events, see USBREG — USB regulator control on page 58.

As a general rule when implementing the software, the host behavior shall never be assumed to be predictable. In particular the sequence of commands received during an enumeration. The software shall always react to the current bus conditions or commands sent by the host.

## 7.39.2 USB terminology

The USB specification defines bus states, rather than logic levels on the D+ and D- lines.

For a full speed device, the bus state where the D+ line is high and the D- line is low is defined as the J state. The bus state where D+ is low and D- high is called the K state.

An idle bus, where D+ and D- lines are only polarized through the pull-up on D+ and pull-downs on the host side, will be in J state.

Both lines low are called SEO (single-ended 0), and both lines high SE1 (single-ended 1).



### 7.39.3 USB pins

The USBD peripheral features a number of dedicated pins.

The dedicated USB pins can be grouped in two categories, signal and power. The signal pins consist of the D+ and D- pins, which are to be connected to the USB host. They are dedicated pins, and not available as standard GPIOs. The USBD peripheral is implemented according to the USB specification revision 2.0, 5V Short Circuit Withstand ECN Requirement Change, meaning these two pins are not 5 V tolerant.

The signal pins and the pull-up will operate only while VBUS is in its valid voltage range, and USBD is enabled through the ENABLE register. For details on the USB power supply and VBUS detection, see USBREG — USB regulator control on page 58.

For more information about the pinout, see Pin assignments on page 790.

### 7.39.4 USBD power-up sequence

The physical layer interface (PHY)/USB transceiver is powered separately from the rest of the device (VBUS pin), which has some implications on the USBD power-up sequence.

The device is not able to properly signal its presence to the USB host and handle traffic from the host, unless the PHY's power supply is enabled and stable. Turning the PHY's power supply on/off is directly linked to register ENABLE. The device provides events that help synchronizing software to the various steps during the power-up sequence.

To make sure that all resources in USBD are available and the dedicated USB voltage regulator stabilized, the following is recommended:

- Enable USBD only after VBUS has been detected
- Turn the USB pull-up on after the following events have occurred:
  - USBPWRRDY
  - USBEVENT, with the READY condition flagged in EVENTCAUSE

The following sequence chart illustrates a typical handling of VBUS power-up:



Figure 236: VBUS power-up sequence

Upon detecting VBUS removal, it is recommended to wait for ongoing EasyDMA transfers to finish before disabling USBD (relevant ENDEPIN[n], ENDISOIN, ENDEPOUT[n], or ENDISOOUT events, see EasyDMA on page 702). The USBREMOVED event, described in USBREG — USB regulator control on page 58, signals when the VBUS is removed. Reading the ENABLE register will return Enabled until USBD is completely disabled.

NOPDIC

### 7.39.5 USB pull-up

The USB pull-up serves two purposes: it indicates to the host that the device is connected to the USB bus, and it indicates the device's speed capability.

When no pull-up is connected to the USB bus, the host sees both D+ and D- lines low, as they are pulled down on the host side by 15 k $\Omega$  resistors. The device is not detected by the host, putting it in a detached state even if it is physically connected to the host. In this situation, the device is not allowed to draw current from VBUS, according to *USB 2.0 Specification*.

When a full-speed device connects its 1.5 k $\Omega$  pull-up to D+, the host sees the corresponding line high. The device is then in the attached state. During the enumeration process, the host attempts to determine if the full-speed device also supports higher speeds and initiates communication with the device to further identify it. The USBD peripheral implemented in this device supports only full-speed operation (12 Mbps), and thus ignores the negotiation for higher speeds in accordance with *USB 2.0 Specification*.

Register USBPULLUP enables software to connect or disconnect the pull-up on D+. This allows the software to control when USB enumeration takes place. It also allows to emulate a physical disconnect from the USB bus, for instance when re-enumeration is required. USBPULLUP has to be enabled to allow the USBD to handle USB traffic and generate appropriate events. This forbids the use of an external pull-up.

Note that disconnecting the pull-up through register USBPULLUP while connected to a host, will result in both D+ and D- lines to be pulled low by the host's pull-down resistors. However, as mentioned above, this will also inhibit the generation of the USBRESET event. The pull-up is disabled by default after a chip reset.

The pull-up shall only get connected after USBD has been enabled through register ENABLE. The USB pull-up value is automatically changed depending on the bus activity, as specified in *Resistor ECN* which amends the original *USB 2.0 Specification*. The user does not have access to this function as it is handled in hardware.

While they should never be used in normal traffic activity, lines D+ and D- may at any time be forced into state specified in register DPDMVALUE by the task DPDMDRIVE. The DPDMNODRIVE task stops driving them, and PHY returns to normal operation.

#### 7 39 6 USB reset

The USB specification defines a USB reset, which is not be confused with a chip reset. The USB reset is a normal USB bus condition, and is used as part of the enumeration sequence, it does not reset the chip.

The USB reset results from a single-ended low state (SE0) on lines D+/D- for a  $t_{USB,DETRST}$  amount of time. Only the host is allowed to drive a USB reset condition on the bus. The UBSD peripheral automatically interprets a SE0 longer than  $t_{USB,DETRST}$  as a USB reset. When the device detects a USB reset and generates a USBRESET event, the device USB stack and related parts of the application shall re-initialize themselves, and go back to the default state.

Some of the registers in the USBD peripheral get automatically reset to a known state, in particular all data endpoints are disabled and the USBADDR reset to 0.

After the device has connected to the USB bus (i.e. after VBUS is applied), the device shall not respond to any traffic from the time the pull-up is enabled until it has seen a USB reset condition. This is automatically ensured by the USBD.

After a USB reset, the device shall be fully responsive after at most  $T_{RSTRCY}$  (according to chapter 7 in the USB specification). Software shall take into account this time that takes the hardware to recover from a USB reset condition.



### 7.39.7 USB suspend and resume

Normally, the host will maintain activity on the USB at least every millisecond according to USB specification. A USB device will enter suspend when there is no activity on the bus (idle) for a given time. The device will resume operation when it receives any non idle signalling.

To signal that the device shall go into low power mode (suspend), the host stops activity on the USB bus, which becomes idle. Only the device pull-up and host pull-downs act on D+ and D-, and the bus is thus kept at a constant J state. It is up to the device to detect this lack of activity, and enter the low power mode (suspend) within a specified time.

The USB host can decide to suspend or resume USB activity at any time. If remote wake-up is enabled, the device may signal to the host to resume from suspend.

### 7.39.7.1 Entering suspend

The USBD peripheral automatically detects lack of activity for more than a defined amount of time, and performs steps needed to enter suspend.

When no activity has been detected for longer than  $t_{USB,SUSPEND}$ , the USBD generates the USBEVENT event with SUSPEND bit set in register EVENTCAUSE. The software shall ensure that the current drawn from the USB supply line VBUS is within the specified limits before  $T_{2SUSP}$ , as defined in chapter 7 of the USB specification. In order to reduce idle current of USBD, the software must explicitly place the USBD in low power mode through writing LowPower to register LOWPOWER.

In order to save power, and provided that no other peripheral needs it, the crystal oscillator (HFXO) in CLOCK may be disabled by software during the USB suspend, while the USB pull-up is disconnected, or when VBUS is not present. Software must explicitly enable it at any other time. The USBD will not be able to respond to USB traffic unless HFXO is enabled and stable.

#### 7.39.7.2 Host-initiated resume

Once the host resumes the bus activity, it has to be responsive to incoming requests on the USB bus within the time  $T_{RSMRCY}$  (as defined in chapter 7 of the USB specification) and revert to normal power consumption mode.

If the host resumes bus activity with or without a RESUME condition (in other words: bus activity is defined as any non-J state), the USBD peripheral will generate a USBEVENT event, with RESUME bit set in register EVENTCAUSE. If the host resumes bus activity simply by restarting sending frames, the USBD peripheral will generate SOF events.

#### 7.39.7.3 Device-initiated remote wake-up

Assuming the remote wake-up is supported by the device and enabled by the host, the device can request the host to resume from suspend if wake-up condition is met.

To do so, the HFXO needs to be enabled first. After waking up the HFXO, the software must bring USBD out of the low power mode and into the normal power consumption mode through writing ForceNormal in register LOWPOWER. It can then instruct the USBD peripheral to drive a RESUME condition (K state) on the USB bus by triggering the DPDMDRIVE task, and hence attempt to wake up the host. By choosing Resume in DPDMVALUE, the duration of the RESUME state is under hardware control (t<sub>USB,DRIVEK</sub>). By choosing J or K, the duration of that state is under software control (the J or K state is maintained until a DPDMNODRIVE task is triggered) and has to meet T<sub>DRSMUP</sub> as specified in USB specification chapter 7.

Upon writing the ForceNormal in register LOWPOWER, a USBEVENT event is generated with the USBWUALLOWED bit set in register EVENTCAUSE.

The value in register DPDMVALUE on page 734 will only be captured and used when the DPDMDRIVE task is triggered. This value defines the state the bus will be forced into after the DPDMDRIVE task.



The device shall ensure that it does not initiate a remote wake-up request before  $T_{WTRSM}$  (according to USB specification chapter 7) after the bus has entered idle state. Using the recommended resume value in DPDMVALUE (rather than K) takes care of this, and postpones the RESUME state accordingly.

### 7.39.8 EasyDMA

The USBD peripheral implements EasyDMA for accessing memory without CPU involvement.

Each endpoint has an associated set of registers, tasks and events. EasyDMA and traffic on USB are tightly related. A number of events provide insight of what is happening on the USB bus with a number of tasks allowing an automated response to the traffic.

**Note:** Endpoint 0 (IN and OUT) are implemented as control endpoint. For more information, see Control transfers on page 703.

#### Registers

Enabling endpoints is controlled through the EPINEN and EPOUTEN registers.

The following registers define the memory address of the buffer for a specific IN or OUT endpoint:

- EPIN[n].PTR, (n=0..7)
- EPOUT[n].PTR, (n=0..7)
- ISOIN.PTR
- ISOOUT.PTR

The following registers define the amount of bytes to be sent on USB for next transaction:

- EPIN[n].MAXCNT, (n=0..7)
- ISOIN.MAXCNT

The following registers define the length of the buffer (in bytes) for next transfer of incoming data:

- EPOUT[n].MAXCNT, (n=1..7)
- ISOOUT.MAXCNT

Since the host decides how many bytes are sent over USB, the MAXCNT value can be copied from register SIZE.EPOUT[n] (n=1..7) or register SIZE.ISOOUT.

Register EPOUT[0].MAXCNT defines the length of the OUT buffer (in bytes) for the control endpoint 0. Register SIZE.EPOUT[0] shall indicate the same value as MaxPacketSize from the device descriptor or wLength from the SETUP command, whichever is the least.

The .AMOUNT registers indicate how many bytes actually have been transferred over EasyDMA during the last transfer.

Stalling bulk/interrupt endpoints is controlled through the EPSTALL register.

**Note:** Due to USB specification requirements, the effect of the stalling control endpoint 0 may be overridden by hardware, in particular when a new SETUP token is received.

EasyDMA will not copy the SETUP data to memory (it will only transfer data from the data stage). The following are separate registers in the USBD peripheral that have setup data.

- BMREQUESTTYPE
- BREQUEST
- WVALUEL
- WVALUEH
- WINDEXL
- WINDEXH



- WLENGTHL
- WLENGTHH

The EVENTCAUSE register provides details on what caused a given USBEVENT event, for instance if a CRC error is detected during a transaction, or if bus activity stops or resumes.

#### **Tasks**

Tasks STARTEPIN[n], STARTEPOUT[n] (n=0..7), STARTISOIN, and STARTISOOUT capture the values for .PTR and .MAXCNT registers. For IN endpoints, a transaction over USB gets automatically triggered when the EasyDMA transfer is complete. For OUT endpoints, it is up to software to allow the next transaction over USB. See the examples in Control transfers on page 703, Bulk and interrupt transactions on page 706, and Isochronous transactions on page 708.

For the control endpoint 0, OUT transactions are allowed through the EPORCVOUT task. The EPOSTATUS task allows a status stage to be initiated, and the EPOSTALL task allows stalling further traffic (data or status stage) on the control endpoint.

#### **Events**

The STARTED event confirms that the values of the .PTR and .MAXCNT registers of the endpoints flagged in register EPSTATUS have been captured. Those can then be modified by software for the next transfer.

Events ENDEPIN[n], ENDEPOUT[n] (n=0..7), ENDISOIN, and ENDISOOUT events indicate that the entire buffer has been consumed. The buffer can be accessed safely by the software.

Only a single EasyDMA transfer can take place in USBD at any time. Software must ensure that tasks STARTEPIN[n] (n=0..7), STARTISOIN, STARTEPOUT[n] (n=0..7), or STARTISOOUT are not triggered before events ENDEPIN[n] (n=0..7), ENDISOIN, ENDEPOUT[n] (n=0..7), or ENDISOOUT are received from an ongoing transfer.

The EPDATA event indicates that a successful (acknowledged) data transaction has occurred on the data endpoint(s) flagged in register EPDATASTATUS. A successful (acknowledged) data transaction on endpoint 0 is signalled by the EPODATADONE event.

At any time a USBEVENT event may be sent, with details provided in EVENTCAUSE register.

The EPOSETUP event indicates that a SETUP token has been received on the control endpoint 0, and that the setup data is available in #unique\_1734/unique\_1734\_Connect\_42\_setup\_data\_registers on page 702.

#### 7.39.9 Control transfers

The USB specification mandates every USB device to implement endpoint 0 IN and OUT as control endpoints.

A control transfer consists of two or three stages:

- · Setup stage
- Data stage (optional)
- Status stage

Each control transfer can be one of following types:

- Control read
- · Control read no data
- Control write
- · Control write no data

An EPOSETUP event indicates that the data in the setup stage (following the SETUP token) is available in registers.



The data in the data stage (following the IN or OUT token) is transferred from or to the desired location using EasyDMA.

The control endpoint buffer can be of any size.

After receiving the SETUP token, the USB controller will not accept (NAK) any incoming IN or OUT tokens until the software has finished decoding the command, determined the type of transfer, and prepared for the next stage (data or status) appropriately.

The software can stall a command when in the data and status stages, through the EPOSTALL task, when the command is not supported or if its wValue, wIndex or wLength parameters are wrong. The following shows a stalled control read transfer, but the same mechanism (tasks) applies to stalling a control write transfer.



Figure 237: Control read gets stalled

See the USB 2.0 Specification and relevant class specifications for rules on stalling commands.

**Note:** The USBD peripheral handles the SetAddress transfer by itself. As a consequence, the software shall not process this command other than updating its state machine (see Device state diagram), nor initiate a status stage. If necessary, the address assigned by the host can be read out from the USBADDR register after the command has been processed.

#### 7.39.9.1 Control read transfer

This section describes how the software behaves when responding to a control read transfer.

As mentioned earlier, the USB controller will not accept (NAK) any incoming IN tokens until software has finished decoding the command, determining the type of transfer, and preparing for the next stage (data or status) appropriately.

For a control read, transferring the data from memory into USBD will trigger a valid, acknowledged (ACK) IN transaction on USB.

The software has to prepare EasyDMA by pointing to the buffer containing the data to be transferred. If no other EasyDMA transfers are on-going with USBD, the software can send the STARTEPINO task, which will initiate the data transfer and transaction on USB.

A STARTED event (with EPINO bit set in the EPSTATUS register) will be generated as soon as the EPIN[0].PTR and .MAXCNT registers have been captured. Software may then prepare them for the next data transaction.

NORDIC\*

An ENDEPIN[0] event will be generated when the data has been transferred from memory to the USBD peripheral.

Finally, an EPODATADONE event will be generated when the data has been transmitted over USB and acknowledged by the host.

The software can then either prepare and transmit the next data transaction by repeating the above sequence, or initiate the status stage through the EPOSTATUS task.



Figure 238: Control read transfer

It is possible to enable a shortcut from the EPODATADONE event to the EPOSTATUS task, typically if the data stage is expected to take a single transfer. If there is no data stage, the software can initiate the status stage through the EPOSTATUS task right away, as as shown in the following figure.



Figure 239: Control read no data transfer

#### 7.39.9.2 Control write transfer

This section describes how the software responds to a control write transfer.

The software has to prepare EasyDMA by pointing to the buffer in memory that shall contain the incoming data. If no other EasyDMA transfers are ongoing with USBD, the software can then send the EPORCVOUT task, which will make USBD acknowledge (ACK) the first OUT+DATA transaction from the host.

An EPODATADONE event will be generated when a new OUT+DATA has been transmitted over USB, and is about to get acknowledged by the device.

After receiving the first transaction, a STARTED event (the EPOUT0 bit set in the EPSTATUS register) is generated when the EPOUT[0].PTR and .MAXCNT registers have been captured. Software may then prepare them for the next data transaction.



An ENDEPOUT[0] event will be generated when the data has been transferred from the USBD peripheral to memory. The software can then either prepare to receive the next data transaction by repeating the above sequence, or initiate the status stage through the EPOSTATUS task. Until then, further incoming OUT +DATA transactions get a NAK response by the device.



Figure 240: Control write transfer



Figure 241: Control write no data transfer

## 7.39.10 Bulk and interrupt transactions

The USBD peripheral implements seven pairs of bulk/interrupt endpoints.

The bulk/interrupt endpoints have a fixed USB endpoint number, summarized in the following table.

| Bulk endpoint # | USB IN endpoint | USB OUT endpoint |
|-----------------|-----------------|------------------|
| [1]             | 0x81            | 0x01             |
| [2]             | 0x82            | 0x02             |
| [3]             | 0x83            | 0x03             |
| [4]             | 0x84            | 0x04             |
| [5]             | 0x85            | 0x05             |
| [6]             | 0x86            | 0x06             |
| [7]             | 0x87            | 0x07             |

Table 177: Bulk/interrupt endpoint numbering

A bulk/interrupt transaction consists of a single data stage. Two consecutive, successful transactions are distinguished through alternating leading process ID (PID): DATA0 follows DATA1, DATA1 follows DATA0, etc. A repeated transaction is detected by re-using the same PID as previous transaction, i.e DATA0 follows DATA0, or DATA1 follows DATA1.

The USBD controller automatically toggles DATAO/DATA1 PIDs for every bulk/interrupt transaction.



If incoming data is corrupted (CRC does not match), the USBD controller automatically prevents DATAO/DATA1 from toggling, to request the host to resend the data.

In some specific cases, the software may want to force a data toggle (usually reset) on a specific IN endpoint, or force the expected toggle on an OUT endpoint, for instance as a consequence of the host issuing ClearFeature, SetInterface, or selecting an alternate setting. Controlling the data toggle of data IN or OUT endpoint n (n=1..7) is done through register DTOGGLE.

The bulk/interrupt transaction in USB full-speed can be of any size up to 64 bytes. It must be a multiple of four bytes and 32-bit aligned in memory.

When the USB transaction has completed, an EPDATA event is generated. Until new data has been transferred by EasyDMA from memory to the USBD peripheral (signalled by the ENDEPIN[n] event), the hardware will automatically respond with NAK to all incoming IN tokens. Software has to configure and start the EasyDMA transfer once it is ready to send more data.

Each IN or OUT data endpoint has to be explicitly enabled by software through register EPINEN or EPOUTEN, according to the configuration declared by the device and selected by the host through the **SetConfig** command.

A disabled data endpoint will not respond to any traffic from the host. An enabled data endpoint will normally respond NAK or ACK (depending on the readiness of the buffers), or STALL (if configured in register EPSTALL), in which case the endpoint is asked to halt. The halted (or not) state of a given endpoint can be read back from register HALTED.EPIN[n] or HALTED.EPOUT[n]. The format of the returned 16-bit value can be copied as is, as a response to a GetStatusEndpoint request from the host.

Enabling or disabling an endpoint will not change its halted state. However, a USB reset will disable and clear the halted state of all data endpoints.

The control endpoint 0 IN and OUT can also be enabled and/or halted using the same mechanisms, but due to USB specification, receiving a SETUP will override its state.

#### 7.39.10.1 Bulk and interrupt IN transaction

The host issues IN tokens to receive bulk/interrupt data. In order to send data, the software has to enable the endpoint and prepare an EasyDMA transfer on the desired endpoint.

Bulk/interrupt IN endpoints are enabled or disabled through their respective INn bit (n=1..7) in EPINEN register.

It is also possible to stall or resume communication on an endpoint through the EPSTALL register.



Figure 242: Bulk/interrupt IN transaction



It is possible (and in some situations it is required) to respond to an IN token with a zero-length data packet.

**Note:** On many USB hosts, not responding (DATA+ACK or NAK) to three IN tokens on an interrupt endpoint would have the host disable that endpoint as a consequence. Re-enumerating the device (unplug-replug) may be required to restore functionality. Make sure that the relevant data endpoints are enabled for normal operation as soon as the device gets configured through a **SetConfig** request.

### 7.39.10.2 Bulk and interrupt OUT transaction

When the host wants to transmit bulk/interrupt data, it issues an OUT token (packet) followed by a DATA packet on a given endpoint n (n=1..7).

A NAK is returned until the software writes any value to register SIZE.EPOUT[n], indicating that the content of the local buffer can be overwritten. Upon receiving the next OUT+DATA transaction, an ACK is returned to the host while an EPDATA event is generated (and the EPDATASTATUS register flags are set to indicate on which endpoint this happened). Once the EasyDMA is prepared and enabled, by writing the EPOUT[n] registers and triggering the STARTEPOUT[n] task, the incoming data will be transferred to memory. Until that transfer is finished, the hardware will automatically NAK any other incoming OUT+DATA packets. Only when the EasyDMA transfer is done (signalled by the ENDEPOUT[n] event), or as soon as any values are written by the software in register SIZE.EPOUT[n], the endpoint n will accept incoming OUT+DATA again.

It is allowed for the host to send zero-length data packets.

Bulk/interrupt OUT endpoints are enabled or disabled through their respective OUTn bit (n=1..7) in the EPOUTEN register. It is also possible to stall or resume communication on an endpoint through the EPSTALL register.



Figure 243: Bulk/interrupt OUT transaction

### 7.39.11 Isochronous transactions

The USBD peripheral implements isochronous (ISO) endpoints.

The ISO endpoints have a fixed USB endpoint number, summarized in the following table.



Table 178: Isochronous endpoint numbering

An isochronous transaction consists of a single, non-acknowledged data stage. The host sends out a start of frame at a regular interval (1 ms), and data follows IN or OUT tokens within each frame.



EasyDMA allows transferring ISO data directly from and to memory. EasyDMA transfers must be initiated by the software, which can synchronize with the SOF (start of frame) events.

Because the timing of the start of frame is very accurate, the SOF event can be used for jobs such as synchronizing a local timer through the SOF event and PPI. The SOF event gets synchronized to the 16 MHz clock prior to being made available to the PPI.

Every start of frame increments a free-running counter, which can be read by software through the FRAMECNTR register.

Each IN or OUT ISO data endpoint has to be explicitly enabled by software through register EPINEN or EPOUTEN, according to the configuration declared by the device and selected by the host through the SetConfig command. A disabled ISO IN data endpoint will not respond to any traffic from the host. A disabled ISO OUT data endpoint will ignore any incoming traffic from the host.

The USBD peripheral has an internal 1 kB buffer associated with ISO endpoints. The user can either allocate the full amount to the IN or the OUT endpoint, or split the buffer allocation between the two using register ISOSPLIT.

The internal buffer also sets the maximum size of the ISO OUT and ISO IN transfers: 1023 bytes when the full buffer is dedicated to either ISO OUT or ISO IN, and half when the buffer is split between the two.

#### 7.39.11.1 Isochronous IN transaction

When the host wants to receive isochronous (ISO) data, it issues an IN token on the isochronous endpoint.

After the data has been transferred using the EasyDMA, the USB controller on the isochronous IN endpoint responds to the IN token with the transferred data using the ISOIN.MAXCNT for the size of the packet.

The ISO IN data endpoint has to be explicitly enabled by software through the ISOINO bit in register EPINEN.

When an ISO IN endpoint is enabled and no data transferred with EasyDMA, the response of the USBD depends on the setting of the RESPONSE field in register ISOINCONFIG. It can either provide no response to an IN token or respond with a zero-length data.

If the EasyDMA transfer on the isochronous endpoint is not completed before the next SOF event, the result of the transfer is undefined.

The maximum size of an ISO IN transfer in USB full-speed is 1023 bytes. The data buffer has to be a multiple of 4 bytes 32-bit aligned in memory. However, the amount of bytes transferred on the USB data endpoint can be of any size (up to 1023 bytes, if not shared with an OUT ISO endpoint).



Figure 244: Isochronous IN transfer



#### 7.39.11.2 Isochronous OUT transaction

When the host wants to send isochronous (ISO) data, it issues an OUT token on the isochronous endpoint, followed by data.

The ISO OUT data endpoint has to be explicitly enabled by software through the ISOOUT0 bit in register EPOUTEN.

The amount of last received ISO OUT data is provided in the SIZE.ISOOUT register. Software shall interpret the ZERO and SIZE fields as presented in the following table.

| ZERO     | SIZE              | Last received data size          |
|----------|-------------------|----------------------------------|
| Normal   | 0                 | No data received at all          |
| Normal   | 11023             | 11023 bytes of data received     |
| ZeroData | (not of interest) | Zero-length data packet received |

Table 179: ISO OUT incoming data size

When EasyDMA is prepared and started, triggering a STARTISOOUT task initiates an EasyDMA transfer to memory. Software shall synchronize ISO OUT transfers with the SOF events. EasyDMA uses the address in ISOOUT.PTR and size in ISOOUT.MAXCNT for every new transfer.

If the EasyDMA transfer on the isochronous endpoint is not completed before the next SOF event, the result of the transfer is undefined.

The maximum size of an isochronous OUT transfer in USB full-speed is 1023 bytes. The data buffer has to be a multiple of 4 bytes and 32-bit aligned in Data RAM. However, the amount of bytes transferred on the USB data endpoint can be of any size (up to 1023 bytes if not shared with an IN ISO endpoint).

If the last received ISO data packet is corrupted (wrong CRC), the USB controller generates an USBEVENT event (at the same time as SOF) and indicates a CRC error on ISOOUTCRC in register EVENTCAUSE. EasyDMA will transfer the data anyway if it has been set up properly.



Figure 245: Isochronous OUT transfer



## 7.39.12 USB register access limitations

Some of the registers in USBD cannot be accessed in specific conditions.

This may be the case when USBD is not enabled (using the ENABLE register) and ready (signalled by the READY bit in EVENTCAUSE after a USBEVENT event), or when USBD is in low power mode while the USB bus is suspended.

Triggering any tasks, including the tasks triggered through the PPI, is affected by this behavior. In addition, the following registers are affected:

- HALTED.EPIN[0..7]
- HALTED.EPOUT[0..7]
- USBADDR
- BMREQUESTTYPE
- BREQUEST
- WVALUEL
- WVALUEH
- WINDEXL
- WINDEXH
- WLENGTHL
- WLENGTHH
- SIZE.EPOUT[0..7]
- SIZE.ISOOUT
- USBPULLUP
- DTOGGLE
- EPINEN
- EPOUTEN
- EPSTALL
- ISOSPLIT
- FRAMECNTR

## 7.39.13 Registers

| Base address Domain                    | Peripheral | Instance              | Secure mapping | DMA security | Description                 | Configuration |
|----------------------------------------|------------|-----------------------|----------------|--------------|-----------------------------|---------------|
| 0x50036000<br>0x40036000 APPLICATION U | USBD       | USBD : S<br>USBD : NS | US             | SA           | Universal serial bus device |               |

Table 180: Instances

| Offset | Security                                  | Description                                                                        |
|--------|-------------------------------------------|------------------------------------------------------------------------------------|
| 0x004  |                                           | Captures the EPIN[n].PTR and EPIN[n].MAXCNT registers values, and enables endpoint |
|        |                                           | IN n to respond to traffic from host                                               |
| 0x024  |                                           | Captures the ISOIN.PTR and ISOIN.MAXCNT registers values, and enables sending data |
|        |                                           | on ISO endpoint                                                                    |
| 0x028  |                                           | Captures the EPOUT[n].PTR and EPOUT[n].MAXCNT registers values, and enables        |
|        |                                           | endpoint n to respond to traffic from host                                         |
| 0x048  |                                           | Captures the ISOOUT.PTR and ISOOUT.MAXCNT registers values, and enables receiving  |
|        |                                           | of data on ISO endpoint                                                            |
| 0x04C  |                                           | Allows OUT data stage on control endpoint 0                                        |
| 0x050  |                                           | Allows status stage on control endpoint 0                                          |
| 0x054  |                                           | Stalls data and status stage on control endpoint 0                                 |
| 0x058  |                                           | Forces D+ and D- lines into the state defined in the DPDMVALUE register            |
|        | 0x004 0x024 0x028 0x048 0x04C 0x050 0x054 | 0x004  0x024  0x028  0x048  0x04C  0x050  0x054                                    |



| Register                | Offset | Security | Description                                                                                     |
|-------------------------|--------|----------|-------------------------------------------------------------------------------------------------|
| TASKS_DPDMNODRIVE       | 0x05C  |          | Stops forcing D+ and D- lines into any state (USB engine takes control)                         |
| SUBSCRIBE_STARTEPIN[n]  | 0x084  |          | Subscribe configuration for task STARTEPIN[n]                                                   |
| SUBSCRIBE_STARTISOIN    | 0x0A4  |          | Subscribe configuration for task STARTISOIN                                                     |
| SUBSCRIBE_STARTEPOUT[n] | 0x0A8  |          | Subscribe configuration for task STARTEPOUT[n]                                                  |
| SUBSCRIBE_STARTISOOUT   | 0x0C8  |          | Subscribe configuration for task STARTISOOUT                                                    |
| SUBSCRIBE_EPORCVOUT     | 0x0CC  |          | Subscribe configuration for task EPORCVOUT                                                      |
| SUBSCRIBE_EPOSTATUS     | 0x0D0  |          | Subscribe configuration for task EPOSTATUS                                                      |
| SUBSCRIBE_EPOSTALL      | 0x0D4  |          | Subscribe configuration for task EPOSTALL                                                       |
| SUBSCRIBE_DPDMDRIVE     | 0x0D8  |          | Subscribe configuration for task DPDMDRIVE                                                      |
| SUBSCRIBE_DPDMNODRIVE   | 0x0DC  |          | Subscribe configuration for task DPDMNODRIVE                                                    |
| EVENTS_USBRESET         | 0x100  |          | Signals that a USB reset condition has been detected on USB lines                               |
| EVENTS_STARTED          | 0x104  |          | Confirms that the EPIN[n].PTR and EPIN[n].MAXCNT, or EPOUT[n].PTR and                           |
|                         |        |          | EPOUT[n].MAXCNT registers have been captured on all endpoints reported in the                   |
|                         |        |          | EPSTATUS register                                                                               |
| EVENTS_ENDEPIN[n]       | 0x108  |          | The whole EPIN[n] buffer has been consumed. The buffer can be accessed safely by                |
|                         |        |          | software.                                                                                       |
| EVENTS_EPODATADONE      | 0x128  |          | An acknowledged data transfer has taken place on the control endpoint                           |
| EVENTS_ENDISOIN         | 0x12C  |          | The whole ISOIN buffer has been consumed. The buffer can be accessed safely by                  |
|                         |        |          | software.                                                                                       |
| EVENTS_ENDEPOUT[n]      | 0x130  |          | The whole EPOUT[n] buffer has been consumed. The buffer can be accessed safely by               |
|                         |        |          | software.                                                                                       |
| EVENTS_ENDISOOUT        | 0x150  |          | The whole ISOOUT buffer has been consumed. The buffer can be accessed safely by                 |
|                         |        |          | software.                                                                                       |
| EVENTS_SOF              | 0x154  |          | Signals that a SOF (start of frame) condition has been detected on USB lines                    |
| EVENTS_USBEVENT         | 0x158  |          | An event or an error not covered by specific events has occurred. Check EVENTCAUSE              |
|                         |        |          | register to find the cause.                                                                     |
| EVENTS_EPOSETUP         | 0x15C  |          | A valid SETUP token has been received (and acknowledged) on the control endpoint                |
| EVENTS_EPDATA           | 0x160  |          | A data transfer has occurred on a data endpoint, indicated by the EPDATASTATUS                  |
|                         |        |          | register                                                                                        |
| PUBLISH_USBRESET        | 0x180  |          | Publish configuration for event USBRESET                                                        |
| PUBLISH_STARTED         | 0x184  |          | Publish configuration for event STARTED                                                         |
| PUBLISH_ENDEPIN[n]      | 0x188  |          | Publish configuration for event ENDEPIN[n]                                                      |
| PUBLISH_EPODATADONE     | 0x1A8  |          | Publish configuration for event EPODATADONE                                                     |
| PUBLISH_ENDISOIN        | 0x1AC  |          | Publish configuration for event ENDISOIN                                                        |
| PUBLISH_ENDEPOUT[n]     | 0x1B0  |          | Publish configuration for event ENDEPOUT[n]                                                     |
| PUBLISH_ENDISOOUT       | 0x1D0  |          | Publish configuration for event ENDISOOUT                                                       |
| PUBLISH_SOF             | 0x1D4  |          | Publish configuration for event SOF                                                             |
| PUBLISH_USBEVENT        | 0x1D8  |          | Publish configuration for event USBEVENT                                                        |
| PUBLISH_EPOSETUP        | 0x1DC  |          | Publish configuration for event EPOSETUP                                                        |
| PUBLISH_EPDATA          | 0x1E0  |          | Publish configuration for event EPDATA                                                          |
| SHORTS                  | 0x200  |          | Shortcuts between local events and tasks                                                        |
| INTEN                   | 0x300  |          | Enable or disable interrupt                                                                     |
| INTENSET                | 0x304  |          | Enable interrupt                                                                                |
| INTENCLR                | 0x308  |          | Disable interrupt                                                                               |
| EVENTCAUSE              | 0x400  |          | Details on what caused the USBEVENT event                                                       |
| HALTED.EPIN[n]          | 0x420  |          | IN endpoint halted status. Can be used as is as response to a GetStatus() request to endpoint.  |
| HALTED.EPOUT[n]         | 0x444  |          | OUT endpoint halted status. Can be used as is as response to a GetStatus() request to endpoint. |
| EPSTATUS                | 0x468  |          | Provides information on which endpoint's EasyDMA registers have been captured                   |
| EPDATASTATUS            | 0x46C  |          | Provides information on which endpoint(s) an acknowledged data transfer has                     |
|                         |        |          | occurred (EPDATA event)                                                                         |
| USBADDR                 | 0x470  |          | Device USB address                                                                              |
|                         |        |          |                                                                                                 |



| Register        | Offset | Security | Description                                                                          |
|-----------------|--------|----------|--------------------------------------------------------------------------------------|
| BMREQUESTTYPE   | 0x480  |          | SETUP data, byte 0, bmRequestType                                                    |
| BREQUEST        | 0x484  |          | SETUP data, byte 1, bRequest                                                         |
| WVALUEL         | 0x488  |          | SETUP data, byte 2, LSB of wValue                                                    |
| WVALUEH         | 0x48C  |          | SETUP data, byte 3, MSB of wValue                                                    |
| WINDEXL         | 0x490  |          | SETUP data, byte 4, LSB of windex                                                    |
| WINDEXH         | 0x494  |          | SETUP data, byte 5, MSB of windex                                                    |
| WLENGTHL        | 0x498  |          | SETUP data, byte 6, LSB of wLength                                                   |
| WLENGTHH        | 0x49C  |          | SETUP data, byte 7, MSB of wLength                                                   |
| SIZE.EPOUT[n]   | 0x4A0  |          | Number of bytes received last in the data stage of this OUT endpoint                 |
| SIZE.ISOOUT     | 0x4C0  |          | Number of bytes received last on this ISO OUT data endpoint                          |
| ENABLE          | 0x500  |          | Enable USB                                                                           |
| USBPULLUP       | 0x504  |          | Control of the USB pull-up                                                           |
| DPDMVALUE       | 0x508  |          | State D+ and D- lines will be forced into by the DPDMDRIVE task. The DPDMNODRIVE     |
|                 |        |          | task reverts the control of the lines to MAC IP (no forcing).                        |
| DTOGGLE         | 0x50C  |          | Data toggle control and status                                                       |
| EPINEN          | 0x510  |          | Endpoint IN enable                                                                   |
| EPOUTEN         | 0x514  |          | Endpoint OUT enable                                                                  |
| EPSTALL         | 0x518  |          | STALL endpoints                                                                      |
| ISOSPLIT        | 0x51C  |          | Controls the split of ISO buffers                                                    |
| FRAMECNTR       | 0x520  |          | Returns the current value of the start of frame counter                              |
| LOWPOWER        | 0x52C  |          | Controls USBD peripheral low power mode during USB suspend                           |
| ISOINCONFIG     | 0x530  |          | Controls the response of the ISO IN endpoint to an IN token when no data is ready to |
|                 |        |          | be sent                                                                              |
| EPIN[n].PTR     | 0x600  |          | Data pointer                                                                         |
| EPIN[n].MAXCNT  | 0x604  |          | Maximum number of bytes to transfer                                                  |
| EPIN[n].AMOUNT  | 0x608  |          | Number of bytes transferred in the last transaction                                  |
| ISOIN.PTR       | 0x6A0  |          | Data pointer                                                                         |
| ISOIN.MAXCNT    | 0x6A4  |          | Maximum number of bytes to transfer                                                  |
| ISOIN.AMOUNT    | 0x6A8  |          | Number of bytes transferred in the last transaction                                  |
| EPOUT[n].PTR    | 0x700  |          | Data pointer                                                                         |
| EPOUT[n].MAXCNT | 0x704  |          | Maximum number of bytes to transfer                                                  |
| EPOUT[n].AMOUNT | 0x708  |          | Number of bytes transferred in the last transaction                                  |
| ISOOUT.PTR      | 0x7A0  |          | Data pointer                                                                         |
| ISOOUT.MAXCNT   | 0x7A4  |          | Maximum number of bytes to transfer                                                  |
| ISOOUT.AMOUNT   | 0x7A8  |          | Number of bytes transferred in the last transaction                                  |

Table 181: Register overview

## 7.39.13.1 TASKS\_STARTEPIN[n] (n=0..7)

Address offset:  $0x004 + (n \times 0x4)$ 

Captures the EPIN[n].PTR and EPIN[n].MAXCNT registers values, and enables endpoint IN n to respond to traffic from host







### 7.39.13.2 TASKS\_STARTISOIN

Address offset: 0x024

Captures the ISOIN.PTR and ISOIN.MAXCNT registers values, and enables sending data on ISO endpoint



### 7.39.13.3 TASKS\_STARTEPOUT[n] (n=0..7)

Address offset:  $0x028 + (n \times 0x4)$ 

Captures the EPOUT[n].PTR and EPOUT[n].MAXCNT registers values, and enables endpoint n to respond to traffic from host



### 7.39.13.4 TASKS STARTISOOUT

Address offset: 0x048

Captures the ISOOUT.PTR and ISOOUT.MAXCNT registers values, and enables receiving of data on ISO endpoint



### 7.39.13.5 TASKS\_EPORCVOUT

Address offset: 0x04C

Allows OUT data stage on control endpoint 0





### 7.39.13.6 TASKS\_EPOSTATUS

Address offset: 0x050

Allows status stage on control endpoint 0



### 7.39.13.7 TASKS\_EPOSTALL

Address offset: 0x054

Stalls data and status stage on control endpoint 0



### 7.39.13.8 TASKS DPDMDRIVE

Address offset: 0x058

Forces D+ and D- lines into the state defined in the DPDMVALUE register



### 7.39.13.9 TASKS DPDMNODRIVE

Address offset: 0x05C

Stops forcing D+ and D- lines into any state (USB engine takes control)





## 7.39.13.10 SUBSCRIBE\_STARTEPIN[n] (n=0..7)

Address offset:  $0x084 + (n \times 0x4)$ 

Subscribe configuration for task STARTEPIN[n]

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         | Description                                                   |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STARTEPIN[n] will subscribe to         |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable subscription                                          |
|       |         |       |          |                         |                                                               |

### 7.39.13.11 SUBSCRIBE\_STARTISOIN

Address offset: 0x0A4

Subscribe configuration for task STARTISOIN

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A                                                     |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that task STARTISOIN will subscribe to             |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable subscription                                            |
|       |         |       | Enabled  | 1                       | Enable subscription                                             |

## 7.39.13.12 SUBSCRIBE\_STARTEPOUT[n] (n=0..7)

Address offset:  $0x0A8 + (n \times 0x4)$ 

Subscribe configuration for task STARTEPOUT[n]





### 7.39.13.13 SUBSCRIBE\_STARTISOOUT

Address offset: 0x0C8

Subscribe configuration for task STARTISOOUT



### 7.39.13.14 SUBSCRIBE\_EPORCVOUT

Address offset: 0x0CC

Subscribe configuration for task EPORCVOUT



### 7.39.13.15 SUBSCRIBE EPOSTATUS

Address offset: 0x0D0

Subscribe configuration for task EPOSTATUS



### 7.39.13.16 SUBSCRIBE\_EPOSTALL

Address offset: 0x0D4

Subscribe configuration for task EPOSTALL





### 7.39.13.17 SUBSCRIBE DPDMDRIVE

Address offset: 0x0D8

Subscribe configuration for task DPDMDRIVE



## 7.39.13.18 SUBSCRIBE\_DPDMNODRIVE

Address offset: 0x0DC

Subscribe configuration for task DPDMNODRIVE



### 7.39.13.19 EVENTS\_USBRESET

Address offset: 0x100

Signals that a USB reset condition has been detected on USB lines







### 7.39.13.20 EVENTS\_STARTED

Address offset: 0x104

Confirms that the EPIN[n].PTR and EPIN[n].MAXCNT, or EPOUT[n].PTR and EPOUT[n].MAXCNT registers have been captured on all endpoints reported in the EPSTATUS register



### 7.39.13.21 EVENTS\_ENDEPIN[n] (n=0..7)

Address offset:  $0x108 + (n \times 0x4)$ 

The whole EPIN[n] buffer has been consumed. The buffer can be accessed safely by software.



### 7.39.13.22 EVENTS EPODATADONE

Address offset: 0x128

An acknowledged data transfer has taken place on the control endpoint



### 7.39.13.23 EVENTS\_ENDISOIN

Address offset: 0x12C

The whole ISOIN buffer has been consumed. The buffer can be accessed safely by software.





### 7.39.13.24 EVENTS ENDEPOUT[n] (n=0..7)

Address offset:  $0x130 + (n \times 0x4)$ 

The whole EPOUT[n] buffer has been consumed. The buffer can be accessed safely by software.



## 7.39.13.25 EVENTS\_ENDISOOUT

Address offset: 0x150

The whole ISOOUT buffer has been consumed. The buffer can be accessed safely by software.



### 7.39.13.26 EVENTS SOF

Address offset: 0x154

Signals that a SOF (start of frame) condition has been detected on USB lines





### 7.39.13.27 EVENTS\_USBEVENT

Address offset: 0x158

An event or an error not covered by specific events has occurred. Check EVENTCAUSE register to find the cause.



### 7.39.13.28 EVENTS\_EPOSETUP

Address offset: 0x15C

A valid SETUP token has been received (and acknowledged) on the control endpoint



### 7.39.13.29 EVENTS EPDATA

Address offset: 0x160

A data transfer has occurred on a data endpoint, indicated by the EPDATASTATUS register



### 7.39.13.30 PUBLISH\_USBRESET

Address offset: 0x180

Publish configuration for event USBRESET





### 7.39.13.31 PUBLISH\_STARTED

Address offset: 0x184

Publish configuration for event STARTED

| Bit n            | umber |                 |                                         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|-------|-----------------|-----------------------------------------|-------------------------|-----------------------------------------------------------------|
| ID               |       |                 |                                         | В                       | A A A A A A A                                                   |
| Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                         |                                                                 |
| ID               |       |                 |                                         |                         |                                                                 |
| Α                | RW    | CHIDX           |                                         | [2550]                  | DPPI channel that event STARTED will publish to.                |
| В                | RW    | EN              |                                         |                         |                                                                 |
|                  |       |                 | Disabled                                | 0                       | Disable publishing                                              |
|                  |       |                 | Enabled                                 | 1                       | Enable publishing                                               |

### 7.39.13.32 PUBLISH\_ENDEPIN[n] (n=0..7)

Address offset:  $0x188 + (n \times 0x4)$ 

Publish configuration for event <a href="ENDEPIN[n">ENDEPIN[n]</a>

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event ENDEPIN[n] will publish to.             |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

### 7.39.13.33 PUBLISH\_EPODATADONE

Address offset: 0x1A8

Publish configuration for event EPODATADONE





### 7.39.13.34 PUBLISH\_ENDISOIN

Address offset: 0x1AC

Publish configuration for event ENDISOIN



### 7.39.13.35 PUBLISH\_ENDEPOUT[n] (n=0..7)

Address offset:  $0x1B0 + (n \times 0x4)$ 

Publish configuration for event ENDEPOUT[n]



### 7.39.13.36 PUBLISH ENDISOOUT

Address offset: 0x1D0

Publish configuration for event ENDISOOUT



### 7.39.13.37 PUBLISH\_SOF

Address offset: 0x1D4

Publish configuration for event SOF





### 7.39.13.38 PUBLISH\_USBEVENT

Address offset: 0x1D8

Publish configuration for event USBEVENT

| Bit n            | umber |                 |                                         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|-------|-----------------|-----------------------------------------|-------------------------|-----------------------------------------------------------------|
| ID               |       |                 |                                         | В                       | A A A A A A                                                     |
| Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |                         |                                                                 |
| ID               |       |                 |                                         |                         |                                                                 |
| Α                | RW    | CHIDX           |                                         | [2550]                  | DPPI channel that event USBEVENT will publish to.               |
| В                | RW    | EN              |                                         |                         |                                                                 |
|                  |       |                 | Disabled                                | 0                       | Disable publishing                                              |
|                  |       |                 | Enabled                                 | 1                       | Enable publishing                                               |

### 7.39.13.39 PUBLISH\_EPOSETUP

Address offset: 0x1DC

Publish configuration for event EPOSETUP

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                 |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       |
| ID    |         |       |          |                         | Description                                                   |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event EPOSETUP will publish to.             |
| В     | RW      | EN    |          |                         |                                                               |
|       |         |       | Disabled | 0                       | Disable publishing                                            |
|       |         |       | Enabled  | 4                       | Enable publishing                                             |

### 7.39.13.40 PUBLISH\_EPDATA

Address offset: 0x1E0

Publish configuration for event EPDATA

| Bit n | umber            |       |                 | 31 30 29 28 27 26 25 24                 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0 |
|-------|------------------|-------|-----------------|-----------------------------------------|-------------------------------------------------------|---------|
| ID    |                  |       |                 | В                                       | АААА                                                  | A A A A |
| Rese  | Reset 0x00000000 |       | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0                                               |         |
| ID    |                  |       |                 |                                         |                                                       |         |
| Α     | RW               | CHIDX |                 | [2550]                                  | DPPI channel that event EPDATA will publish to.       |         |
| В     | RW               | EN    |                 |                                         |                                                       |         |
|       |                  |       | Disabled        | 0                                       | Disable publishing                                    |         |
|       |                  |       | Enabled         | 1                                       | Enable publishing                                     |         |





### 7.39.13.41 SHORTS

Address offset: 0x200

Shortcuts between local events and tasks

| Bit n | umber    |                    |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |                    |          |                         | E D C B A                                                       |
| Rese  | et 0x000 | 00000              |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                    |          |                         | Description                                                     |
| Α     | RW       | EPODATADONE_STARTE | EPIN0    |                         | Shortcut between event EPODATADONE and task                     |
|       |          |                    |          |                         | STARTEPIN[0]                                                    |
|       |          |                    | Disabled | 0                       | Disable shortcut                                                |
|       |          |                    | Enabled  | 1                       | Enable shortcut                                                 |
| В     | RW       | EPODATADONE_STARTE | EP       |                         | Shortcut between event EPODATADONE and task                     |
|       |          |                    |          |                         | STARTEPOUT[0]                                                   |
|       |          |                    | Disabled | 0                       | Disable shortcut                                                |
|       |          |                    | Enabled  | 1                       | Enable shortcut                                                 |
| С     | RW       | EPODATADONE_EPOSTA | ATUS     |                         | Shortcut between event EPODATADONE and task                     |
|       |          |                    |          |                         | EPOSTATUS                                                       |
|       |          |                    | Disabled | 0                       | Disable shortcut                                                |
|       |          |                    | Enabled  | 1                       | Enable shortcut                                                 |
| D     | RW       | ENDEPOUTO_EPOSTATU | JS       |                         | Shortcut between event ENDEPOUT[0] and task EPOSTATUS           |
|       |          |                    | Disabled | 0                       | Disable shortcut                                                |
|       |          |                    | Enabled  | 1                       | Enable shortcut                                                 |
| Ε     | RW       | ENDEPOUTO_EPORCVO  | UT       |                         | Shortcut between event ENDEPOUT[0] and task                     |
|       |          |                    |          |                         | EPORCVOUT                                                       |
|       |          |                    | Disabled | 0                       | Disable shortcut                                                |
|       |          |                    | Enabled  | 1                       | Enable shortcut                                                 |

### 7.39.13.42 INTEN

Address offset: 0x300

Enable or disable interrupt

| Bit n | umber    |                   |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-------------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |          |                   |          | Y                      | /XWVUTSRQPONMLKJIHGFEDCBA                                       |
| Rese  | et 0x000 | 00000             |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |                   |          |                        |                                                                 |
| Α     | RW       | USBRESET          |          |                        | Enable or disable interrupt for event USBRESET                  |
|       |          |                   | Disabled | 0                      | Disable                                                         |
|       |          |                   | Enabled  | 1                      | Enable                                                          |
| В     | RW       | STARTED           |          |                        | Enable or disable interrupt for event STARTED                   |
|       |          |                   | Disabled | 0                      | Disable                                                         |
|       |          |                   | Enabled  | 1                      | Enable                                                          |
| C-J   | RW       | ENDEPIN[i] (i=07) |          |                        | Enable or disable interrupt for event ENDEPIN[i]                |
|       |          |                   | Disabled | 0                      | Disable                                                         |
|       |          |                   | Enabled  | 1                      | Enable                                                          |
| K     | RW       | EPODATADONE       |          |                        | Enable or disable interrupt for event EPODATADONE               |
|       |          |                   | Disabled | 0                      | Disable                                                         |
|       |          |                   | Enabled  | 1                      | Enable                                                          |
| L     | RW       | ENDISOIN          |          |                        | Enable or disable interrupt for event ENDISOIN                  |
|       |          |                   | Disabled | 0                      | Disable                                                         |
|       |          |                   | Enabled  | 1                      | Enable                                                          |
|       |          |                   |          |                        |                                                                 |





| Bit n | umber   |                    |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                    |          | Y                       | X W V U T S R Q P O N M L K J I H G F E D C B A                 |
| Rese  | t 0x000 | 00000              |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                    |          |                         | Description                                                     |
| M-T   | RW      | ENDEPOUT[i] (i=07) |          |                         | Enable or disable interrupt for event ENDEPOUT[i]               |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |
| U     | RW      | ENDISOOUT          |          |                         | Enable or disable interrupt for event ENDISOOUT                 |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |
| ٧     | RW      | SOF                |          |                         | Enable or disable interrupt for event SOF                       |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |
| W     | RW      | USBEVENT           |          |                         | Enable or disable interrupt for event USBEVENT                  |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |
| Χ     | RW      | EPOSETUP           |          |                         | Enable or disable interrupt for event EPOSETUP                  |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |
| Υ     | RW      | EPDATA             |          |                         | Enable or disable interrupt for event EPDATA                    |
|       |         |                    | Disabled | 0                       | Disable                                                         |
|       |         |                    | Enabled  | 1                       | Enable                                                          |

### 7.39.13.43 INTENSET

Address offset: 0x304

Enable interrupt

| Bit n | umber   |                    |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                    |          | Υ                       | 'XWVUTSRQPONMLKJIHGFEDCBA                                       |
| Rese  | t 0x000 | 00000              |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                    |          |                         |                                                                 |
| Α     | RW      | USBRESET           |          |                         | Write '1' to enable interrupt for event USBRESET                |
|       |         |                    | Set      | 1                       | Enable                                                          |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW      | STARTED            |          |                         | Write '1' to enable interrupt for event STARTED                 |
|       |         |                    | Set      | 1                       | Enable                                                          |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                   |
| C-J   | RW      | ENDEPIN[i] (i=07)  |          |                         | Write '1' to enable interrupt for event ENDEPIN[i]              |
|       |         |                    | Set      | 1                       | Enable                                                          |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                   |
| K     | RW      | EPODATADONE        |          |                         | Write '1' to enable interrupt for event EPODATADONE             |
|       |         |                    | Set      | 1                       | Enable                                                          |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                   |
| L     | RW      | ENDISOIN           |          |                         | Write '1' to enable interrupt for event ENDISOIN                |
|       |         |                    | Set      | 1                       | Enable                                                          |
|       |         |                    | Disabled | 0                       | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                       | Read: Enabled                                                   |
| M-T   | RW      | ENDEPOUT[i] (i=07) |          |                         | Write '1' to enable interrupt for event ENDEPOUT[i]             |



| Bit r | number   |           |          | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|----------|------------------------|------------------------------------------------------------------|
| ID    |          |           |          | <u> </u>               | YXWVUTSRQPONMLKJIHGFEDCBA                                        |
| Res   | et 0x000 | 00000     |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|       |          |           |          |                        |                                                                  |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
| U     | RW       | ENDISOOUT |          |                        | Write '1' to enable interrupt for event ENDISOOUT                |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
| V     | RW       | SOF       |          |                        | Write '1' to enable interrupt for event SOF                      |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
| W     | RW       | USBEVENT  |          |                        | Write '1' to enable interrupt for event USBEVENT                 |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
| Χ     | RW       | EPOSETUP  |          |                        | Write '1' to enable interrupt for event EPOSETUP                 |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
| Υ     | RW       | EPDATA    |          |                        | Write '1' to enable interrupt for event EPDATA                   |
|       |          |           | Set      | 1                      | Enable                                                           |
|       |          |           | Disabled | 0                      | Read: Disabled                                                   |
|       |          |           | Enabled  | 1                      | Read: Enabled                                                    |
|       |          |           |          |                        |                                                                  |

### 7.39.13.44 INTENCLR

Address offset: 0x308

Disable interrupt

| umber   |                   |                                                         | 31 30 29 28 27 26 25 24                                                                                                                                                           | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                  |
|---------|-------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                   |                                                         | Υ                                                                                                                                                                                 | XWVUTSRQPONMLKJIHGFEDCBA                                                                                                                                                                                                                                                                                                                                                                                         |
| t 0x000 | 00000             |                                                         | 0 0 0 0 0 0 0 0                                                                                                                                                                   | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                          |
|         |                   |                                                         |                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RW      | USBRESET          |                                                         |                                                                                                                                                                                   | Write '1' to disable interrupt for event USBRESET                                                                                                                                                                                                                                                                                                                                                                |
|         |                   | Clear                                                   | 1                                                                                                                                                                                 | Disable                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                   | Disabled                                                | 0                                                                                                                                                                                 | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |                   | Enabled                                                 | 1                                                                                                                                                                                 | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                    |
| RW      | STARTED           |                                                         |                                                                                                                                                                                   | Write '1' to disable interrupt for event STARTED                                                                                                                                                                                                                                                                                                                                                                 |
|         |                   | Clear                                                   | 1                                                                                                                                                                                 | Disable                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                   | Disabled                                                | 0                                                                                                                                                                                 | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |                   | Enabled                                                 | 1                                                                                                                                                                                 | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                    |
| RW      | ENDEPIN[i] (i=07) |                                                         |                                                                                                                                                                                   | Write '1' to disable interrupt for event ENDEPIN[i]                                                                                                                                                                                                                                                                                                                                                              |
|         |                   | Clear                                                   | 1                                                                                                                                                                                 | Disable                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                   | Disabled                                                | 0                                                                                                                                                                                 | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |                   | Enabled                                                 | 1                                                                                                                                                                                 | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                    |
| RW      | EPODATADONE       |                                                         |                                                                                                                                                                                   | Write '1' to disable interrupt for event EPODATADONE                                                                                                                                                                                                                                                                                                                                                             |
|         |                   | Clear                                                   | 1                                                                                                                                                                                 | Disable                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                   | Disabled                                                | 0                                                                                                                                                                                 | Read: Disabled                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |                   | Enabled                                                 | 1                                                                                                                                                                                 | Read: Enabled                                                                                                                                                                                                                                                                                                                                                                                                    |
|         | RW RW             | R/W Field RW USBRESET  RW STARTED  RW ENDEPIN[i] (i=07) | R/W Field Value ID  RW USBRESET  Clear Disabled Enabled  RW STARTED  Clear Disabled Enabled  RW ENDEPIN[i] (i=07)  Clear Disabled Enabled  RW EPODATADONE  Clear Disabled Enabled | R/W Field Value ID Value  Clear 1 Disabled 0 STARTED  Clear 1 Disabled 0 Enabled 1 STARTED  RW ENDEPIN[i] (i=07)  Clear 1 Disabled 0 Enabled 1 STARTED  Clear 1 Disabled 0 Enabled 1 STARTED  RW ENDEPIN[i] (i=07)  Clear 1 Disabled 0 Enabled 1 STARTED  Clear 1 Disabled 0 Enabled 1 STARTED |



| Bit n | umber   |                    |          | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------------|----------|------------------------|-----------------------------------------------------------------|
| ID    |         |                    |          | ١                      | 'X W V U T S R Q P O N M L K J I H G F E D C B A                |
| Rese  | t 0x000 | 00000              |          | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |         |                    |          |                        |                                                                 |
| L     | RW      | ENDISOIN           |          |                        | Write '1' to disable interrupt for event ENDISOIN               |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| M-T   | RW      | ENDEPOUT[i] (i=07) |          |                        | Write '1' to disable interrupt for event ENDEPOUT[i]            |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| U     | RW      | ENDISOOUT          |          |                        | Write '1' to disable interrupt for event ENDISOOUT              |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| V     | RW      | SOF                |          |                        | Write '1' to disable interrupt for event SOF                    |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| W     | RW      | USBEVENT           |          |                        | Write '1' to disable interrupt for event USBEVENT               |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| Х     | RW      | EPOSETUP           |          |                        | Write '1' to disable interrupt for event EPOSETUP               |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |
| Υ     | RW      | EPDATA             |          |                        | Write '1' to disable interrupt for event EPDATA                 |
|       |         |                    | Clear    | 1                      | Disable                                                         |
|       |         |                    | Disabled | 0                      | Read: Disabled                                                  |
|       |         |                    | Enabled  | 1                      | Read: Enabled                                                   |

### 7.39.13.45 EVENTCAUSE

Address offset: 0x400

Details on what caused the USBEVENT event

| Bit n | umber   |           |             | 31 30 29 28 27 26 25 2 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-----------|-------------|------------------------|-----------------------------------------------------------------|
| ID    |         |           |             |                        | E D C B A                                                       |
| Rese  | t 0x000 | 00000     |             | 0 0 0 0 0 0 0          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |           |             |                        |                                                                 |
| Α     | RW      | ISOOUTCRC |             |                        | CRC error was detected on isochronous OUT endpoint 8.           |
|       |         |           |             |                        | Write '1' to clear.                                             |
|       |         |           | NotDetected | 0                      | No error detected                                               |
|       |         |           | Detected    | 1                      | Error detected                                                  |
| В     | RW      | SUSPEND   |             |                        | Signals that USB lines have been idle long enough for the       |
|       |         |           |             |                        | device to enter suspend. Write '1' to clear.                    |
|       |         |           | NotDetected | 0                      | Suspend not detected                                            |
|       |         |           | Detected    | 1                      | Suspend detected                                                |
| С     | RW      | RESUME    |             |                        | Signals that a RESUME condition (K state or activity restart)   |
|       |         |           |             |                        | has been detected on USB lines. Write '1' to clear.             |
|       |         |           | NotDetected | 0                      | Resume not detected                                             |







### 7.39.13.46 HALTED.EPIN[n] (n=0..7)

Address offset:  $0x420 + (n \times 0x4)$ 

IN endpoint halted status. Can be used as is as response to a GetStatus() request to endpoint.



### 7.39.13.47 HALTED.EPOUT[n] (n=0..7)

Address offset:  $0x444 + (n \times 0x4)$ 

OUT endpoint halted status. Can be used as is as response to a GetStatus() request to endpoint.



#### 7.39.13.48 EPSTATUS

Address offset: 0x468

Provides information on which endpoint's EasyDMA registers have been captured



| Bit numb | per               |          | 31 30 29 28 27 26 25 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|----------|-------------------|----------|----------------------|------------------------------------------------------------------|
| ID       |                   |          |                      | R Q P O N M L K J I H G F E D C B A                              |
| Reset 0x | 00000000          |          | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
|          |                   |          |                      |                                                                  |
| A-I R\   | W EPIN[i] (i=08)  |          |                      | Captured state of endpoint's EasyDMA registers. Write '1'        |
|          |                   |          |                      | to clear.                                                        |
|          |                   | NoData   | 0                    | EasyDMA registers have not been captured for this                |
|          |                   |          |                      | endpoint                                                         |
|          |                   | DataDone | 1                    | EasyDMA registers have been captured for this endpoint           |
| J-R RV   | W EPOUT[i] (i=08) |          |                      | Captured state of endpoint's EasyDMA registers. Write '1'        |
|          |                   |          |                      | to clear.                                                        |
|          |                   | NoData   | 0                    | EasyDMA registers have not been captured for this                |
|          |                   |          |                      | endpoint                                                         |
|          |                   | DataDone | 1                    | EasyDMA registers have been captured for this endpoint           |

### 7.39.13.49 EPDATASTATUS

Address offset: 0x46C

Provides information on which endpoint(s) an acknowledged data transfer has occurred (EPDATA event)

| Bit number             |            | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------------|------------|-------------------------|-----------------------------------------------------------------|
| ID                     |            |                         | N M L K J I H G F E D C B A                                     |
| Reset 0x00000000       |            | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W Field           |            |                         | Description                                                     |
| A-G RW EPIN[i] (i=17)  |            |                         | Acknowledged data transfer on this IN endpoint. Write '1'       |
|                        |            |                         | to clear.                                                       |
|                        | NotDone    | 0                       | No acknowledged data transfer on this endpoint                  |
|                        | DataDone   | 1                       | Acknowledged data transfer on this endpoint has occurred        |
| H-N RW EPOUT[i] (i=17) |            |                         | Acknowledged data transfer on this OUT endpoint. Write          |
|                        |            |                         | '1' to clear.                                                   |
|                        | NotStarted | 0                       | No acknowledged data transfer on this endpoint                  |
|                        | Started    | 1                       | Acknowledged data transfer on this endpoint has occurred        |

#### 7.39.13.50 USBADDR

Address offset: 0x470
Device USB address



### 7.39.13.51 BMREQUESTTYPE

Address offset: 0x480

SETUP data, byte 0, bmRequestType



| Bit n | umber    |           |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|-----------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |          |           |              |                         | СВВАААА                                                         |
| Rese  | et 0x000 | 00000     |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |           |              |                         | Description                                                     |
| Α     | R        | RECIPIENT |              |                         | Data transfer type                                              |
|       |          |           | Device       | 0                       | Device                                                          |
|       |          |           | Interface    | 1                       | Interface                                                       |
|       |          |           | Endpoint     | 2                       | Endpoint                                                        |
|       |          |           | Other        | 3                       | Other                                                           |
| В     | R        | TYPE      |              |                         | Data transfer type                                              |
|       |          |           | Standard     | 0                       | Standard                                                        |
|       |          |           | Class        | 1                       | Class                                                           |
|       |          |           | Vendor       | 2                       | Vendor                                                          |
| С     | R        | DIRECTION |              |                         | Data transfer direction                                         |
|       |          |           | HostToDevice | 0                       | Host-to-device                                                  |
|       |          |           | DeviceToHost | 1                       | Device-to-host                                                  |

### 7.39.13.52 BREQUEST

Address offset: 0x484

SETUP data, byte 1, bRequest

| mber  |          |                             | 31 30 29 28 27 26 25 24                                                                                                                                                                                                        | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |                             |                                                                                                                                                                                                                                | АААА                                                    | A A A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x000 | 00000    |                             | 0 0 0 0 0 0 0 0                                                                                                                                                                                                                | $\begin{array}{cccccccccccccccccccccccccccccccccccc$    | 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |          |                             |                                                                                                                                                                                                                                |                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R     | BREQUEST |                             |                                                                                                                                                                                                                                | SETUP data, byte 1, bRequest. Values provided for       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          |                             |                                                                                                                                                                                                                                | standard requests only, user must implement class and   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          |                             |                                                                                                                                                                                                                                | vendor values.                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_GET_STATUS              | 0                                                                                                                                                                                                                              | Standard request GET_STATUS                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_CLEAR_FEATURE           | 1                                                                                                                                                                                                                              | Standard request CLEAR_FEATURE                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SET_FEATURE             | 3                                                                                                                                                                                                                              | Standard request SET_FEATURE                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SET_ADDRESS             | 5                                                                                                                                                                                                                              | Standard request SET_ADDRESS                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_GET_DESCRIPTOR          | 6                                                                                                                                                                                                                              | Standard request GET_DESCRIPTOR                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SET_DESCRIPTOR          | 7                                                                                                                                                                                                                              | Standard request SET_DESCRIPTOR                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_GET_CONFIGURATI         | OBN                                                                                                                                                                                                                            | Standard request GET_CONFIGURATION                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SET_CONFIGURATION       | O9N                                                                                                                                                                                                                            | Standard request SET_CONFIGURATION                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_GET_INTERFACE           | 10                                                                                                                                                                                                                             | Standard request GET_INTERFACE                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SET_INTERFACE           | 11                                                                                                                                                                                                                             | Standard request SET_INTERFACE                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | STD_SYNCH_FRAME             | 12                                                                                                                                                                                                                             | Standard request SYNCH_FRAME                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       | R/W      | <b>0x00000000</b> R/W Field | Ox00000000  R/W Field Value ID  R BREQUEST  STD_GET_STATUS STD_CLEAR_FEATURE STD_SET_FEATURE STD_SET_ADDRESS STD_GET_DESCRIPTOR STD_SET_DESCRIPTOR STD_GET_CONFIGURATI STD_SET_CONFIGURATI STD_GET_INTERFACE STD_SET_INTERFACE | Ox000000000000000000000000000000000000                  | Note   Note |

### 7.39.13.53 WVALUEL

Address offset: 0x488

SETUP data, byte 2, LSB of wValue







#### 7.39.13.54 WVALUEH

Address offset: 0x48C

SETUP data, byte 3, MSB of wValue



#### 7.39.13.55 WINDEXL

Address offset: 0x490

SETUP data, byte 4, LSB of wIndex



#### 7.39.13.56 WINDEXH

Address offset: 0x494

SETUP data, byte 5, MSB of wIndex



#### 7.39.13.57 WLENGTHL

Address offset: 0x498

SETUP data, byte 6, LSB of wLength



### 7.39.13.58 WLENGTHH

Address offset: 0x49C

SETUP data, byte 7, MSB of wLength





### 7.39.13.59 SIZE.EPOUT[n] (n=0..7)

Address offset:  $0x4A0 + (n \times 0x4)$ 

Number of bytes received last in the data stage of this OUT endpoint

Write to any value to accept further OUT traffic on this endpoint, and overwrite the intermediate buffer



#### 7.39.13.60 SIZE.ISOOUT

Address offset: 0x4C0

Number of bytes received last on this ISO OUT data endpoint

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          |                         | B A A A A A A A A                                               |
| Rese  | t 0x000 | 10000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | R       | SIZE  |          |                         | Number of bytes received last on this ISO OUT data              |
|       |         |       |          |                         | endpoint                                                        |
| В     | R       | ZERO  |          |                         | Zero-length data packet received                                |
|       |         |       | Normal   | 0                       | No zero-length data received, use value in SIZE                 |
|       |         |       | ZeroData | 1                       | Zero-length data received, ignore value in SIZE                 |

#### 7.39.13.61 ENABLE

Address offset: 0x500

**Enable USB** 

After writing Disabled to this register, reading the register will return Enabled until USBD is completely disabled.





### 7.39.13.62 USBPULLUP

Address offset: 0x504

Control of the USB pull-up



#### 7.39.13.63 DPDMVALUE

Address offset: 0x508

State D+ and D- lines will be forced into by the DPDMDRIVE task. The DPDMNODRIVE task reverts the control of the lines to MAC IP (no forcing).



#### 7.39.13.64 DTOGGLE

Address offset: 0x50C

Data toggle control and status

First write this register with VALUE=Nop to select the endpoint, then either read it to get the status from VALUE, or write it again with VALUE=Data0 or Data1



| Bit n | umber   |       |       | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|-------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |       |                         | ССВ ААА                                                         |
| Rese  | t 0x000 | 00100 |       | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |       |                         |                                                                 |
| Α     | RW      | EP    |       |                         | Select bulk endpoint number                                     |
| В     | RW      | 10    |       |                         | Selects IN or OUT endpoint                                      |
|       |         |       | Out   | 0                       | Selects OUT endpoint                                            |
|       |         |       | In    | 1                       | Selects IN endpoint                                             |
| С     | RW      | VALUE |       |                         | Data toggle value                                               |
|       |         |       | Nop   | 0                       | No action on data toggle when writing the register with         |
|       |         |       |       |                         | this value                                                      |
|       |         |       | Data0 | 1                       | Data toggle is DATAO on endpoint set by EP and IO               |
|       |         |       | Data1 | 2                       | Data toggle is DATA1 on endpoint set by EP and IO               |
|       |         |       |       |                         |                                                                 |

### 7.39.13.65 EPINEN

Address offset: 0x510 Endpoint IN enable

| Bit n | umber   |              |         | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|--------------|---------|-------------------------|-----------------------------------------------------------------|
| ID    |         |              |         |                         | IHGFEDCBA                                                       |
| Rese  | t 0x000 | 00001        |         | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |              |         |                         | Description                                                     |
| A-H   | RW      | IN[i] (i=07) |         |                         | Enable IN endpoint i                                            |
|       |         |              | Disable | 0                       | Disable endpoint IN i (no response to IN tokens)                |
|       |         |              | Enable  | 1                       | Enable endpoint IN i (response to IN tokens)                    |
| 1     | RW      | ISOIN        |         |                         | Enable ISO IN endpoint                                          |
|       |         |              | Disable | 0                       | Disable ISO IN endpoint 8                                       |
|       |         |              | Enable  | 1                       | Enable ISO IN endpoint 8                                        |

### 7.39.13.66 EPOUTEN

Address offset: 0x514 Endpoint OUT enable

| Bit nu | umber   |               |         | 31 30 29 28 27 2 | 7 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|--------|---------|---------------|---------|------------------|--------------------------------------------------------------------------|
| ID     |         |               |         |                  | IHGFEDCBA                                                                |
| Rese   | t 0x000 | 00001         |         | 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                  |
| ID     |         |               |         |                  |                                                                          |
| A-H    | RW      | OUT[i] (i=07) |         |                  | Enable OUT endpoint i                                                    |
|        |         |               | Disable | 0                | Disable endpoint OUT i (no response to OUT tokens)                       |
|        |         |               | Enable  | 1                | Enable endpoint OUT i (response to OUT tokens)                           |
| 1      | RW      | ISOOUT        |         |                  | Enable ISO OUT endpoint 8                                                |
|        |         |               | Disable | 0                | Disable ISO OUT endpoint 8                                               |
|        |         |               | Enable  | 1                | Enable ISO OUT endpoint 8                                                |

### 7.39.13.67 EPSTALL

Address offset: 0x518

STALL endpoints





#### 7.39.13.68 ISOSPLIT

Address offset: 0x51C

Controls the split of ISO buffers



#### 7.39.13.69 FRAMECNTR

Address offset: 0x520

Returns the current value of the start of frame counter



#### 7.39.13.70 LOWPOWER

Address offset: 0x52C

Controls USBD peripheral low power mode during USB suspend





#### 7.39.13.71 ISOINCONFIG

Address offset: 0x530

Controls the response of the ISO IN endpoint to an IN token when no data is ready to be sent



### 7.39.13.72 EPIN[n].PTR (n=0..7)

Address offset:  $0x600 + (n \times 0x14)$ 

Data pointer



### 7.39.13.73 EPIN[n].MAXCNT (n=0..7)

Address offset:  $0x604 + (n \times 0x14)$ 

Maximum number of bytes to transfer







### 7.39.13.74 EPIN[n].AMOUNT (n=0..7)

Address offset:  $0x608 + (n \times 0x14)$ 

Number of bytes transferred in the last transaction



#### 7.39.13.75 ISOIN.PTR

Address offset: 0x6A0

Data pointer

| Bit n | umber   |        | 31 | 30 | 29 | 28 2 | 27 : | 26 2 | 25 2 | 4 2 | 23 22 | 2 21 | 1 20 | 19 | 18 : | 17 1 | 6 15 | 5 14 | 13 | 12 1 | .11 | .0 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2  | 1 0 |
|-------|---------|--------|----|----|----|------|------|------|------|-----|-------|------|------|----|------|------|------|------|----|------|-----|------|-----|---|---|---|---|---|----|-----|
| ID    |         |        | А  | Α  | Α  | A    | Α    | Α.   | A    | Δ,  | А А   | A    | A    | Α  | Α    | A    | 4 А  | Α    | Α  | Α    | Δ / | Δ Δ  | A A | Α | Α | Α | Α | Α | Α. | А А |
| Rese  | t 0x000 | 000000 | 0  | 0  | 0  | 0    | 0    | 0    | 0 (  | 0 ( | 0 0   | 0    | 0    | 0  | 0    | 0 (  | 0 0  | 0    | 0  | 0    | 0 ( | 0    | 0   | 0 | 0 | 0 | 0 | 0 | 0  | 0 0 |
| ID    |         |        |    |    |    |      |      |      |      |     |       |      |      |    |      |      |      |      |    |      |     |      |     |   |   |   |   |   |    |     |
| Α     | RW      | PTR    |    |    |    |      |      |      |      | [   | Data  | ро   | inte | er |      |      |      |      |    |      |     |      |     |   |   |   |   |   |    |     |

See the memory chapter for details about which memories are available for EasyDMA.

#### 7.39.13.76 ISOIN.MAXCNT

Address offset: 0x6A4

Maximum number of bytes to transfer

| Α     | RW      | MAXCNT | [10231] Maximum number of bytes to transfer                                       |     |
|-------|---------|--------|-----------------------------------------------------------------------------------|-----|
| ID    |         |        |                                                                                   |     |
| Rese  | t 0x000 | 00000  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                           | 0 0 |
| ID    |         |        | A A A A A A A                                                                     | A A |
| Bit n | umber   |        | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |

#### 7.39.13.77 ISOIN.AMOUNT

Address offset: 0x6A8

Number of bytes transferred in the last transaction



### 7.39.13.78 EPOUT[n].PTR (n=0..7)

Address offset:  $0x700 + (n \times 0x14)$ 

Data pointer





See the memory chapter for details about which memories are available for EasyDMA.

### 7.39.13.79 EPOUT[n].MAXCNT (n=0..7)

Address offset:  $0x704 + (n \times 0x14)$ Maximum number of bytes to transfer



### 7.39.13.80 EPOUT[n].AMOUNT (n=0..7)

Address offset:  $0x708 + (n \times 0x14)$ 

Number of bytes transferred in the last transaction



#### 7.39.13.81 ISOOUT.PTR

Address offset: 0x7A0

Data pointer



See the memory chapter for details about which memories are available for EasyDMA.

#### 7.39.13.82 ISOOUT.MAXCNT

Address offset: 0x7A4

Maximum number of bytes to transfer

NORDIC\*



#### 7.39.13.83 ISOOUT.AMOUNT

Address offset: 0x7A8

Number of bytes transferred in the last transaction



### 7.39.14 Electrical specification

### 7.39.14.1 USB Electrical Specification

| Symbol                     | Description                                              | Min. | Тур. | Max.  | Units |
|----------------------------|----------------------------------------------------------|------|------|-------|-------|
| R <sub>USB,PU,ACTIVE</sub> | Value of pull-up on D+, bus active (upstream device      | 1425 | 2300 | 3090  | Ω     |
|                            | transmitting)                                            |      |      |       |       |
| R <sub>USB,PU,IDLE</sub>   | Value of pull-up on D+, bus idle                         | 900  | 1200 | 1575  | Ω     |
| t <sub>USB,DETRST</sub>    | Minimum duration of an SEO state to be detected as a USB |      |      | 10    | μs    |
|                            | reset condition                                          |      |      |       |       |
| f <sub>USB,CLK</sub>       | Frequency of local clock, USB active                     |      | 48   |       | MHz   |
| $f_{USB,TOL}$              | Accuracy of local clock, USB active <sup>31</sup>        |      |      | ±1000 | ppm   |
| T <sub>USB,JITTER</sub>    | Jitter on USB local clock, USB active                    |      |      | ±1    | ns    |

# 7.40 VMC — Volatile memory controller

VMC provides power control for RAM blocks.

Each RAM block, which may contain multiple RAM sections, can power up or power down independently in System ON and System OFF mode using RAM[n] registers. See the Memory chapter for more information about RAM blocks and sections.

### 7.40.1 RAM power states

The RAM power control registers are used for configuring the following:

- The RAM sections to be retained during System OFF
- The RAM sections to be retained and accessible during System ON

In System OFF, retention of a RAM section is configured in the RETENTION field of the corresponding register RAM[n].POWER (n=0..7) on page 741.

In System ON, retention and accessibility for a RAM section is configured in the RETENTION and POWER fields of the corresponding register RAM[n].POWER (n=0..7) on page 741.



The local clock can be stopped during USB suspend

The following table summarizes the behavior of these registers.

| Configuration |                    |                        | RAM section status |          |
|---------------|--------------------|------------------------|--------------------|----------|
| System on/off | RAM[n].POWER.POWER | RAM[n].POWER.RETENTION | Accessible         | Retained |
| Off           | Х                  | Off                    | No                 | No       |
| Off           | X                  | On                     | No                 | Yes      |
| On            | Off                | Off                    | No                 | No       |
| On            | Off                | On                     | No                 | Yes      |
| On            | On                 | x                      | Yes                | Yes      |

Table 182: RAM section configuration

The advantage of not retaining RAM contents is that the overall current consumption is reduced. See chapter Memory on page 19 for more information on RAM sections.

### 7.40.2 Registers

| Base address Dor                | main      | Peripheral | Instance            | Secure mapping | DMA security | Description                | Configuration            |
|---------------------------------|-----------|------------|---------------------|----------------|--------------|----------------------------|--------------------------|
| 0x50081000<br>APF<br>0x40081000 | PLICATION | VMC        | VMC : S<br>VMC : NS | US             | NA           | Volatile memory controller |                          |
| 0x41081000 NET                  | TWORK     | VMC        | VMC                 | NS             | NA           | Volatile memory controller | 4 RAM slaves implemented |
|                                 |           |            |                     |                |              |                            | 4 RAM slaves implemented |

Table 183: Instances

| Register        | Offset | Security | Description                         |
|-----------------|--------|----------|-------------------------------------|
| RAM[n].POWER    | 0x600  |          | RAM[n] power control register       |
| RAM[n].POWERSET | 0x604  |          | RAM[n] power control set register   |
| RAM[n].POWERCLR | 0x608  |          | RAM[n] power control clear register |

Table 184: Register overview

### 7.40.2.1 RAM[n].POWER (n=0..7)

Address offset:  $0x600 + (n \times 0x10)$ 

RAM[n] power control register

NORDIC

RAM section power off gives negligible reduction in current consumption when retention is on.

| Bit nu | umber   |                       |     | 31 | 30 2 | 9 28 | 3 27 | 26 2 | 5 24 | 123 | 22 2       | 21 2 | 0 19  | 18   | 17 : | 16 1 | 15 1 | 4 13 | 12   | 11 1  | .0 9   | 8    | 7   | 6   | 5 4 | 4 3 | 2 | 1 0 |
|--------|---------|-----------------------|-----|----|------|------|------|------|------|-----|------------|------|-------|------|------|------|------|------|------|-------|--------|------|-----|-----|-----|-----|---|-----|
| ID     |         |                       |     | f  | e d  | d c  | b    | a Z  | Z Y  | Х   | W          | νι   | J T   | S    | R    | Q    | Р (  | O N  | М    | L     | < J    | -1   | Н   | G   | FI  | E D | С | В А |
| Reset  | t 0x000 | OFFFF                 |     | 0  | 0 (  | 0 0  | 0    | 0 (  | 0 0  | 0   | 0          | 0 (  | 0 0   | 0    | 0    | 0    | 1 :  | 1 1  | 1    | 1     | 1 1    | 1    | 1   | 1   | 1 : | 1 1 | 1 | 1 1 |
| ID     |         |                       |     |    |      |      |      |      |      |     |            |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
| A-P    | RW      | S[i]POWER (i=015)     |     |    |      |      |      |      |      | Ke  | ep R       | RAM  | 1 sec | tior | Si   | of F | AN   | 1[n] | on ( | or of | f in S | Syst | em  | ON  |     |     |   |     |
|        |         |                       |     |    |      |      |      |      |      | mo  | ode        |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
|        |         |                       |     |    |      |      |      |      |      |     |            |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
|        |         |                       |     |    |      |      |      |      |      | All | IRAN       | VI S | ectio | ns v | vill | be   | swi  | tche | d o  | f in  | Syst   | em ( | OFF | mo  | ode |     |   |     |
|        |         |                       | Off | 0  |      |      |      |      |      | Of  | ff         |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
|        |         |                       |     |    |      |      |      |      |      |     |            |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
|        |         |                       | On  | 1  |      |      |      |      |      | On  | n          |      |       |      |      |      |      |      |      |       |        |      |     |     |     |     |   |     |
| Q-f    | RW      | S[i]RETENTION (i=015) |     | 1  |      |      |      |      |      |     | n<br>eep r | etei | ntio  | n on | RA   | .M s | ect  | ion  | Si o | f RAI | M[n]   | ] wh | nen | RAI | VI  |     |   |     |
| Q-f    | RW      | S[i]RETENTION (i=015) |     | 1  |      |      |      |      |      | Ke  |            |      |       |      |      |      | ect  | ion  | Si o | f RAI | M[n]   | l wh | nen | RAI | M   |     |   |     |
| Q-f    | RW      | S[i]RETENTION (i=015) |     |    |      |      |      |      |      | Ke  | ep r       |      |       |      |      |      | sect | ion  | Si o | f RAI | M[n]   | wh   | nen | RAI | M   |     |   |     |
| Q-f    | RW      | S[i]RETENTION (i=015) |     | 0  |      |      |      |      |      | Ke  | ep r       |      |       |      |      |      | sect | ion  | Si o | f RAI | M[n]   | wh   | nen | RAI | M   |     |   |     |

### 7.40.2.2 RAM[n].POWERSET (n=0..7)

Address offset:  $0x604 + (n \times 0x10)$ RAM[n] power control set register

When read, this register will return the value of the RAM[n].POWER register.



### 7.40.2.3 RAM[n].POWERCLR (n=0..7)

Address offset:  $0x608 + (n \times 0x10)$ RAM[n] power control clear register

When read, this register will return the value of the RAM[n].POWER register.

| Bit n | umber   |                       |     | 31 | 30 | 29 | 28 | 27 2 | 6 2! | 5 24     | 1 23 | 3 2 2 | 2 21 | . 20  | 19   | 18 1 | 7 1  | 5 1  | 5 14 | 13   | 12   | 11:  | 10 9 | 8    | 7   | 6    | 5 | 4 | 3 | 2 | 1 0 |
|-------|---------|-----------------------|-----|----|----|----|----|------|------|----------|------|-------|------|-------|------|------|------|------|------|------|------|------|------|------|-----|------|---|---|---|---|-----|
| ID    |         |                       |     | f  | е  | d  | С  | b a  | a Z  | <u> </u> | X    | W     | / V  | U     | Т    | S I  | R C  | Q P  | 0    | N    | M    | L    | Κ.   | l I  | Н   | G    | F | Ε | D | С | ВА  |
| Rese  | t 0x000 | OFFFF                 |     | 0  | 0  | 0  | 0  | 0 (  | 0    | 0        | 0    | 0     | 0    | 0     | 0    | 0 (  | 0    | 1    | 1    | 1    | 1    | 1    | 1 :  | l 1  | 1   | 1    | 1 | 1 | 1 | 1 | 1 1 |
| ID    |         |                       |     |    |    |    |    |      |      |          |      |       |      |       |      |      |      |      |      |      |      |      |      |      |     |      |   |   |   |   |     |
| A-P   | RW      | S[i]POWER (i=015)     |     |    |    |    |    |      |      |          | Ke   | eep   | RA   | M s   | ect  | ion  | Si o | f RA | MA   | n] c | n o  | r of | f in | Sys  | ten | 10 1 | N |   |   |   |     |
|       |         |                       |     |    |    |    |    |      |      |          | m    | ode   | e    |       |      |      |      |      |      |      |      |      |      |      |     |      |   |   |   |   |     |
|       |         |                       | Off | 1  |    |    |    |      |      |          | 0    | ff    |      |       |      |      |      |      |      |      |      |      |      |      |     |      |   |   |   |   |     |
| Q-f   | RW      | S[i]RETENTION (i=015) |     |    |    |    |    |      |      |          | Ke   | eep   | ret  | tenti | ion  | on l | RAN  | A se | ecti | on S | i of | RA   | M[r  | 1] w | her | RA   | M |   |   |   |     |
|       |         |                       |     |    |    |    |    |      |      |          | se   | ecti  | on i | is sw | vitc | hed  | off  |      |      |      |      |      |      |      |     |      |   |   |   |   |     |
|       |         |                       | Off | 1  |    |    |    |      |      |          | 0    | ff    |      |       |      |      |      |      |      |      |      |      |      |      |     |      |   |   |   |   |     |





# 7.41 WDT — Watchdog timer

The countdown watchdog timer (WDT) uses the low-frequency clock source (LFCLK) and offers configurable and robust protection against application lock-up.

WDT must be configured before it is started. After configuration, WDT is started by triggering the START task.

When WDT is running, its configuration registers (CRV, RREN, and CONFIG) are blocked for further configuration.

WDT can be paused while the CPU is sleeping, or when the debugger has halted the CPU. WDT is implemented as a down-counter that generates a TIMEOUT event when it wraps over after counting down to 0. When WDT is started by the START task, the watchdog counter is loaded with the value specified in the CRV register. This counter is also reloaded with the value specified in the CRV register when a reload request is granted.

The timeout period for the watchdog is given by the following equation:

```
timeout [s] = ( CRV + 1 ) / 32768
```

When started, WDT will make the 32.768 kHz RC oscillator start if no other 32.768 kHz clock source is running and generating the 32.768 kHz system clock, see chapter CLOCK — Clock control on page 73.

#### 7.41.1 Reload criteria

WDT has eight separate reload request registers. These registers are used to request WDT to reload its counter with the value specified in the CRV register. To reload the watchdog counter, write  $0 \times 6 \times 5 \times 24635$  to all enabled reload registers.

One or more RR registers can be individually enabled through the RREN register.

### 7.41.2 Temporarily pausing the watchdog

By default, the watchdog will be active counting down the down-counter while the CPU is sleeping. It is possible to configure the watchdog to automatically pause when the CPU is sleeping or when it is stopped by the debugger.

Entering System OFF mode will stop and disable the watchdog.

### 7.41.3 Watchdog reset

A TIMEOUT event automatically leads to a watchdog reset.

If the watchdog is configured to generate an interrupt on the TIMEOUT event, the watchdog reset is postponed by two 32.768 kHz clock cycles after the TIMEOUT event is generated. Once the TIMEOUT event is generated, and unless the watchdog is stopped, the impending watchdog reset will occur.

The watchdog can be reset from several reset sources, see Application core reset behavior on page 67. After a reset, the watchdog configuration registers are available for configuration.

See RESET — Reset control on page 65 for more information about reset sources.

### 7.41.4 Stopping the watchdog

By default, the watchdog cannot be stopped. It is possible to configure the watchdog to allow the STOP task.



To stop the watchdog, perform the following steps.

- 1. Set the CONFIG register's STOPEN field to Enable during watchdog configuration.
- 2. Write the special value 0x6E524635 to the TSEN register.
- 3. Invoke the STOP task.

When these conditions are met, the watchdog is stopped and a STOPPED event is issued.

When the watchdog is stopped, its configuration registers CRV, RREN, and CONFIG are no longer blocked.

**Note:** It is recommended to write zeros to TSEN on page 749 after the watchdog has stopped, to avoid runaway code triggering the STOP task.

### 7.41.5 Registers

| Base address Domain      | Peripheral | Instance | Secure mapping | DMA security | Description      | Configuration |
|--------------------------|------------|----------|----------------|--------------|------------------|---------------|
| 0x50018000<br>APPLICATIO | N WDT      | WDT0:S   | US             | NA           | Watchdog timer 0 |               |
| 0x40018000               | N WDI      | WDT0: NS | 03             | NA           | Watchdog timer o |               |
| 0x50019000<br>APPLICATIO | N WDT      | WDT1:S   | US             | NA           | Watchdog timer 1 |               |
| 0x40019000               | N WDI      | WDT1: NS | 03             | NA           | Watchdog timer 1 |               |
| 0x4100B000 NETWORK       | WDT        | WDT      | NS             | NA           | Watchdog timer   |               |

Table 185: Instances

| Register        | Offset | Security | Description                                  |
|-----------------|--------|----------|----------------------------------------------|
| TASKS_START     | 0x000  |          | Start WDT                                    |
| TASKS_STOP      | 0x004  |          | Stop WDT                                     |
| SUBSCRIBE_START | 0x080  |          | Subscribe configuration for task START       |
| SUBSCRIBE_STOP  | 0x084  |          | Subscribe configuration for task STOP        |
| EVENTS_TIMEOUT  | 0x100  |          | Watchdog timeout                             |
| EVENTS_STOPPED  | 0x104  |          | Watchdog stopped                             |
| PUBLISH_TIMEOUT | 0x180  |          | Publish configuration for event TIMEOUT      |
| PUBLISH_STOPPED | 0x184  |          | Publish configuration for event STOPPED      |
| INTENSET        | 0x304  |          | Enable interrupt                             |
| INTENCLR        | 0x308  |          | Disable interrupt                            |
| NMIENSET        | 0x324  |          | Enable interrupt                             |
| NMIENCLR        | 0x328  |          | Disable interrupt                            |
| RUNSTATUS       | 0x400  |          | Run status                                   |
| REQSTATUS       | 0x404  |          | Request status                               |
| CRV             | 0x504  |          | Counter reload value                         |
| RREN            | 0x508  |          | Enable register for reload request registers |
| CONFIG          | 0x50C  |          | Configuration register                       |
| TSEN            | 0x520  |          | Task stop enable                             |
| RR[n]           | 0x600  |          | Reload request n                             |

Table 186: Register overview

### 7.41.5.1 TASKS\_START

Address offset: 0x000

Start WDT





### 7.41.5.2 TASKS STOP

Address offset: 0x004

Stop WDT



### 7.41.5.3 SUBSCRIBE\_START

Address offset: 0x080

Subscribe configuration for task START



### 7.41.5.4 SUBSCRIBE STOP

Address offset: 0x084

Subscribe configuration for task STOP

| Bit n | number   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
|-------|----------|-------|----------|-------------------------|-------------------------------------------------------------|-----|
| ID    |          |       |          | В                       | A A A A A A                                                 | А А |
| Rese  | et 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                     | 0 0 |
| ID    |          |       |          |                         |                                                             |     |
| Α     | RW       | CHIDX |          | [2550]                  | DPPI channel that task STOP will subscribe to               |     |
| В     | RW       | EN    |          |                         |                                                             |     |
|       |          |       | Disabled | 0                       | Disable subscription                                        |     |
|       |          |       | Enabled  | 1                       | Enable subscription                                         |     |

### 7.41.5.5 EVENTS\_TIMEOUT

Address offset: 0x100
Watchdog timeout



| Bit n | umber   |                |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |              |                         | A                                                               |
| Rese  | t 0x000 | 00000          |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |              |                         |                                                                 |
| Α     | RW      | EVENTS_TIMEOUT |              |                         | Watchdog timeout                                                |
|       |         |                | NotGenerated | 0                       | Event not generated                                             |
|       |         |                | Generated    | 1                       | Event generated                                                 |

### 7.41.5.6 EVENTS\_STOPPED

Address offset: 0x104 Watchdog stopped

| Bit n | umber   |                |              | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|--------------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |              |                         | А                                                               |
| Rese  | t 0x000 | 00000          |              | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |              |                         | Description                                                     |
| Α     | RW      | EVENTS_STOPPED |              |                         | Watchdog stopped                                                |
|       |         |                | NotGenerated | 0                       | Event not generated                                             |
|       |         |                | Generated    | 1                       | Event generated                                                 |

### 7.41.5.7 PUBLISH\_TIMEOUT

Address offset: 0x180

Publish configuration for event TIMEOUT

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|-------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |       |          | В                       | A A A A A A A                                                   |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |       |          |                         |                                                                 |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event TIMEOUT will publish to.                |
| В     | RW      | EN    |          |                         |                                                                 |
|       |         |       | Disabled | 0                       | Disable publishing                                              |
|       |         |       | Enabled  | 1                       | Enable publishing                                               |

### 7.41.5.8 PUBLISH\_STOPPED

Address offset: 0x184

Publish configuration for event STOPPED

| Bit n | umber   |       |          | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0 |
|-------|---------|-------|----------|-------------------------|---------------------------------------------------------|-------|
| ID    |         |       |          | В                       | ААААА                                                   | A A A |
| Rese  | t 0x000 | 00000 |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 0 0 |
| ID    |         |       |          |                         |                                                         |       |
| Α     | RW      | CHIDX |          | [2550]                  | DPPI channel that event STOPPED will publish to.        |       |
| В     | RW      | EN    |          |                         |                                                         |       |
|       |         |       | Disabled | 0                       | Disable publishing                                      |       |
|       |         |       | Enabled  | 1                       | Enable publishing                                       |       |

### 7.41.5.9 INTENSET

Address offset: 0x304



### Enable interrupt

| Bit n | umber   |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |         |         |          |                         | В А                                                             |
| Rese  | t 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |         |          |                         | Description                                                     |
| Α     | RW      | TIMEOUT |          |                         | Write '1' to enable interrupt for event TIMEOUT                 |
|       |         |         | Set      | 1                       | Enable                                                          |
|       |         |         | Disabled | 0                       | Read: Disabled                                                  |
|       |         |         | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW      | STOPPED |          |                         | Write '1' to enable interrupt for event STOPPED                 |
|       |         |         | Set      | 1                       | Enable                                                          |
|       |         |         | Disabled | 0                       | Read: Disabled                                                  |
|       |         |         | Enabled  | 1                       | Read: Enabled                                                   |

### 7.41.5.10 INTENCLR

Address offset: 0x308

Disable interrupt

| Bit r | number   |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |          |                         | ВА                                                              |
| Rese  | et 0x000 | 00000   |          | 0 0 0 0 0 0 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|       |          |         |          |                         |                                                                 |
| Α     | RW       | TIMEOUT |          |                         | Write '1' to disable interrupt for event TIMEOUT                |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | STOPPED |          |                         | Write '1' to disable interrupt for event STOPPED                |
|       |          |         | Clear    | 1                       | Disable                                                         |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |

### 7.41.5.11 NMIENSET

Address offset: 0x324 Enable interrupt

| Bit r | umber    |         |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------|----------|-------------------------|-----------------------------------------------------------------|
| ID    |          |         |          |                         | В А                                                             |
| Rese  | et 0x000 | 00000   |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |         |          |                         |                                                                 |
| Α     | RW       | TIMEOUT |          |                         | Write '1' to enable interrupt for event TIMEOUT                 |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |
| В     | RW       | STOPPED |          |                         | Write '1' to enable interrupt for event STOPPED                 |
|       |          |         | Set      | 1                       | Enable                                                          |
|       |          |         | Disabled | 0                       | Read: Disabled                                                  |
|       |          |         | Enabled  | 1                       | Read: Enabled                                                   |



#### 7.41.5.12 NMIENCLR

Address offset: 0x328

Disable interrupt



### 7.41.5.13 RUNSTATUS

Address offset: 0x400

Run status



#### 7.41.5.14 REQSTATUS

Address offset: 0x404

Request status



#### 7.41.5.15 CRV

Address offset: 0x504 Counter reload value







### 7.41.5.16 RREN

Address offset: 0x508

Enable register for reload request registers

| Bit number  |              |          | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------|--------------|----------|-------------------------|-----------------------------------------------------------------|
| ID          |              |          |                         | HGFEDCBA                                                        |
| Reset 0x000 | 000001       |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID R/W      |              |          |                         |                                                                 |
| A-H RW      | RR[i] (i=07) |          |                         | Enable or disable RR[i] register                                |
|             |              | Disabled | 0                       | Disable RR[i] register                                          |
|             |              | Enabled  | 1                       | Enable RR[i] register                                           |

### 7.41.5.17 CONFIG

Address offset: 0x50C Configuration register

| Bit n | Bit number 31 30 29 28 27 26 25 24 |        |         | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                                           |
|-------|------------------------------------|--------|---------|-----------------------------------------------------------------|-----------------------------------------------------------|
| ID    |                                    |        |         |                                                                 | F C A                                                     |
| Rese  | t 0x000                            | 00001  |         | 0 0 0 0 0 0 0 0                                                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                   |
| ID    |                                    |        |         |                                                                 | Description                                               |
| Α     | RW                                 | SLEEP  |         |                                                                 | Configure WDT to either be paused, or kept running, while |
|       |                                    |        |         |                                                                 | the CPU is sleeping                                       |
|       |                                    |        | Pause   | 0                                                               | Pause WDT while the CPU is sleeping                       |
|       |                                    |        | Run     | 1                                                               | Keep WDT running while the CPU is sleeping                |
| С     | RW                                 | HALT   |         |                                                                 | Configure WDT to either be paused, or kept running, while |
|       |                                    |        |         |                                                                 | the CPU is halted by the debugger                         |
|       |                                    |        | Pause   | 0                                                               | Pause WDT while the CPU is halted by the debugger         |
|       |                                    |        | Run     | 1                                                               | Keep WDT running while the CPU is halted by the           |
|       |                                    |        |         |                                                                 | debugger                                                  |
| F     | RW                                 | STOPEN |         |                                                                 | Allow stopping WDT                                        |
|       |                                    |        | Disable | 0                                                               | Do not allow stopping WDT                                 |
|       |                                    |        | Enable  | 1                                                               | Allow stopping WDT                                        |

### 7.41.5.18 TSEN

Address offset: 0x520

Task stop enable





# 7.41.5.19 RR[n] (n=0..7)

Address offset:  $0x600 + (n \times 0x4)$ 

Reload request n



# 7.41.6 Electrical specification

### 7.41.6.1 Watchdog Timer Electrical Specification

| Symbol           | Description       | Min. | Тур. | Max. | Units |
|------------------|-------------------|------|------|------|-------|
| t <sub>WDT</sub> | Time out interval |      |      |      |       |



# 8 Debug and trace

The debug and trace system offers a flexible and powerful mechanism for non-intrusive debugging.



Figure 246: Debug and trace overview

The main features of the debug and trace system are:

- Access port connection to application core Arm Cortex-M33
  - Eight breakpoints
  - Four watchpoint comparators
  - Instrumentation trace macrocell (ITM)
  - Embedded trace macrocell (ETM)
  - Access protection through APPROTECT, ERASEPROTECT and SECUREAPPROTECT
- Access port connection to network core Arm Cortex-M33
  - · Eight breakpoints
  - Four watchpoints
  - Access protection through APPROTECT and ERASEPROTECT
- Serial wire debug (SWD) interface protocol version 2 with multidrop support
- Trace port interface unit (TPIU)



- 4-bit parallel trace of ITM and ETM trace data
- Serial wire output (SWO) trace of ITM data

# 8.1 DAP — Debug access port

An external debugger can access the device using the DAP.

The DAP is a standard Arm CoreSight<sup>™</sup> serial wire debug port (SW-DP) that implements the serial wire debug (SWD) protocol – a two-pin serial interface using SWDCLK and SWDIO pins (see Debug and trace overview on page 751).

#### Note:

- The SWDIO line has an internal pull-up resistor.
- The SWDCLK line has an internal pull-down resistor.

There are several access ports that connect to different parts of the system. See the following table for more information.

| AP ID | Туре    | Description                               |
|-------|---------|-------------------------------------------|
| 0     | AHB-AP  | Application subsystem access port         |
| 1     | AHB-AP  | Network subsystem access port             |
| 2     | CTRL-AP | Application subsystem control access port |
| 3     | CTRL-AP | Network subsystem control access port     |

Table 187: Access port overview

The AHB-AP and APB-AP access ports are standard Arm components documented in the *Arm CoreSight SoC-400 Technical Reference Manual, Revision r3p2*. The CTRL-AP access port is proprietary (see CTRL-AP - Control access port on page 764).

### 8.1.1 Registers

| Register | Offset | Security | Description                                                                                                                                                                                                                             |
|----------|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TARGETID | 0x042  |          | The TARGETID register provides information about the target when the host is connected to a single device.  The TARGETID register is accessed by a read of DP register 0x4 when the DPBANKSEL bit in the SELECT register is set to 0x2. |
| DLPIDR   | 0x043  |          | The DLPIDR register provides information about the serial wire debug protocol version.  Accessed by a read of DP register 0x4 when the DPBANKSEL bit in the SELECT register is set to 0x3.                                              |

Table 188: Register overview

### **8.1.1.1 TARGETID**

Address offset: 0x042



The TARGETID register provides information about the target when the host is connected to a single device.

The TARGETID register is accessed by a read of DP register 0x4 when the DPBANKSEL bit in the SELECT register is set to 0x2.



#### 8.1.1.2 DLPIDR

Address offset: 0x043

The DLPIDR register provides information about the serial wire debug protocol version.

Accessed by a read of DP register 0x4 when the DPBANKSEL bit in the SELECT register is set to 0x3.



### 8.1.2 Electrical specification

#### 8.1.2.1 SW-DP

| Symbol              | Description                                       | Min.  | Тур. | Max. | Units |
|---------------------|---------------------------------------------------|-------|------|------|-------|
| R <sub>pull</sub>   | Internal SWDIO and SWDCLK pull up/down resistance |       | 13   |      | kΩ    |
| f <sub>SWDCLK</sub> | SWDCLK frequency                                  | 0.125 |      | 8    | MHz   |

### 8.1.2.2 Trace port

| Symbol    | Description                                              | Min.   | Тур. | Max. | Units |
|-----------|----------------------------------------------------------|--------|------|------|-------|
| $T_{cyc}$ | Clock period, as defined by Arm in Embedded Trace        | 15.625 |      | 250  | ns    |
|           | Macrocell Architecture Specification (see Timing         |        |      |      |       |
|           | specifications in Trace Port Physical Interface section) |        |      |      |       |





# 8.2 Access port protection

The control access ports are always accessible from the debugger, while access to the system resources through each core's individual access ports (AHB-AP) can be protected in different ways.

The following tables give an overview of the access port protection methods.

| Registers                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UICR.APPROTECT and CTRL-AP.APPROTECT.DISABLE                    | These registers control the generation of the application core AHB-AP DBGEN signal, which controls all non-secure access through the application core AHB-AP. This can be used to provide readback protection of the flash contents. See also Application core access port protection for non-secure debug access on page 755. For more information about the DBGEN signal, see the <i>Arm CoreSight SoC-400 Technical Reference Manual, Revision r3p2</i> . |
| UICR.SECUREAPPROTECT<br>and CTRL-<br>AP.SECUREAPPROTECT.DISABLE | These registers control the generation of the application core AHB-AP SPIDEN signal, which blocks all secure access through the application core AHB-AP. This means that only the non-secure code can be debugged and accessed.                                                                                                                                                                                                                              |
|                                                                 | To enable access to the secure access port, APPROTECT must be unprotected. See also Application core access port protection for secure debug access on page 755.                                                                                                                                                                                                                                                                                             |
|                                                                 | For more information about the SPIDEN signal, see the <i>Arm CoreSight SoC-400 Technical Reference Manual, Revision r3p2</i> .                                                                                                                                                                                                                                                                                                                               |
| UICR.ERASEPROTECT and CTRL-<br>AP.ERASEPROTECT.DISABLE          | Disables the application core CTRL-AP.ERASEALL and NVMC ERASEALL functionality. This can be used together with APPROTECT to provide read-back and re-purposing protection.                                                                                                                                                                                                                                                                                   |

Table 189: Application core access port protection overview

| Registers                                    | Description                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UICR.APPROTECT and CTRL-AP.APPROTECT.DISABLE | These registers control the generation of the network core AHB-AP DBGEN signal, which blocks all access through the network core AHB-AP. See also Network core access port protection for debug access on page 755.  For the network core that does not feature TrustZone, only DBGEN can be controlled and SPIDEN is not used. |
|                                              | can be controlled and SFIDEN is not used.                                                                                                                                                                                                                                                                                       |
| UICR.ERASEPROTECT                            | Disables the network core CTRL-AP.ERASEALL and NVMC ERASEALL functionality. This can be used together with APPROTECT to provide read-back and re-purposing protection.                                                                                                                                                          |

Table 190: Network core access port protection overview

For both cores, UICR and CTRL-AP are combined to enable or disable the access port protection. The access port is normally protected, and is opened when the following conditions are met:

1. UICR.APPROTECT must be Unprotected.



2. CTRL-AP.APPROTECT.DISABLE on both CPU and debugger side must match. However, after reset the debugger side register value is known and CPU can open the port by writing Unprotected to the register.

The following tables lists the available APPROTECT combinations.

| Application core UICR.APPROTECT | CPU and debugger side CTRL-AP.APPROTECT.DISABLE registers are equal | DBGEN | Debug access to application core AHB-AP |
|---------------------------------|---------------------------------------------------------------------|-------|-----------------------------------------|
| Protected                       | No                                                                  | 0     | Not permitted                           |
| Protected                       | Yes                                                                 | 0     | Not permitted                           |
| Unprotected                     | No                                                                  | 0     | Not permitted                           |
| Unprotected                     | Yes                                                                 | 1     | Permitted                               |

Table 191: Application core access port protection for non-secure debug access

| Application core UICR.SECUREAPPROTECT | CPU and debugger side CTRL-AP.SECUREAP- PROTECT.DISABLE registers are equal | SPIDEN | Secure debug access to application core AHB-AP |
|---------------------------------------|-----------------------------------------------------------------------------|--------|------------------------------------------------|
| Protected                             | No                                                                          | 0      | Not permitted                                  |
| Protected                             | Yes                                                                         | 0      | Not permitted                                  |
| Unprotected                           | No                                                                          | 0      | Not permitted                                  |
| Unprotected                           | Yes                                                                         | 1      | Permitted                                      |

Table 192: Application core access port protection for secure debug access

| Network core UICR.AP-<br>PROTECT | CPU and debugger side CTRL-<br>AP.APPROTECT registers are equal | DBGEN | Debug access to AHB-AP |
|----------------------------------|-----------------------------------------------------------------|-------|------------------------|
| Protected                        | No                                                              | 0     | Not permitted          |
| Protected                        | Yes                                                             | 0     | Not permitted          |
| Unprotected                      | No                                                              | 0     | Not permitted          |
| Unprotected                      | Yes                                                             | 1     | Permitted              |

Table 193: Network core access port protection for debug access

The access port is also open after the completion of the CTRL-AP.ERASEALL operation. After completing the erase operation, CTRL-AP will temporarily unprotect AHB-AP. AHB-AP will be protected when one of the following conditions are met:

- Power-on reset
- Brown-out reset
- Watchdog timer reset
- Pin reset

The following figure is an example on how nRF5340 with access port protection enabled can be erased, programmed, and configured to allow debugging. Operations sent from debugger as well as registers written by firmware will affect the access port state. The operation named Reset\* is one of the conditions listed above.



Figure 247: Access port unlocking

The debugger can read the access port protection status in the core's AHB-AP, using the Arm AHB-AP Control/Status Word register (CSW), defined in the *Arm CoreSight SoC-400 Technical Reference Manual, Revision r3p2*. The DbgStatus field indicates that the AHB-AP can perform AHB transfers, while the SPIStatus field indicates if secure AHB transfers are permitted. For a list of all debug access ports, see DAP — Debug access port on page 752.

For more details on CTRLAP.ERASEALL, CTRLAP.SECUREAPPROTECT, and CTRLAP.APPROTECT, see CTRL-AP - Control access port on page 764.

**Note:** Using SPU — System protection unit on page 590, the application core can be configured to grant the network core access to its resources. This grant also applies to the network core AHB-AP.

## 8.3 Debug Interface mode

Before the external debugger can use any of the access ports, the debugger must first request the device to power up via CxxxPWRUPREQ in the SWJ-DP.

As long as the debugger is requesting power via CxxxPWRUPREQ, the device will be in Debug interface mode. Otherwise, the device is in Normal mode. When a debug session is over, the external debugger must return the device back to Normal mode and perform a pin reset. This is due to the overall power consumption being higher in Debug interface mode compared to Normal mode.

Some peripherals behave differently in Debug interface mode compared to Normal mode. These differences are described in more detail in the chapters of the affected peripherals.

For details on how to use the debug capabilities, read the debug documentation of your IDE.

If the device is in System OFF when power is requested via CxxxPWRUPREQ, the device will wake up and the DIF flag in RESETREAS on page 70 will be set.



# 8.4 Real-time debug

The device supports real-time debugging, which allows interrupts to execute to completion in real time when breakpoints are set in Thread mode or lower priority interrupts.

Real-time debugging enables breakpoint setting and single-stepping through code without causing the failure of real-time event-driven threads running at higher priority. For example, this enables the device to continue to service the high-priority interrupts of an external controller or sensor without failure or loss of state synchronization while stepping through code in a low-priority thread.

### 8.5 ROM tables

Each ROM Table on the SoC contains a listing of the components that are connected to the debug port or AHB-AP. These listings allow an external debugger or on-chip software to discover the CoreSight devices on the SoC.



Figure 248: Application core ROM table overview



| Address    | Component | Value      |
|------------|-----------|------------|
| 0xE00FEFFC | CIDR3     | 0x000000B1 |
| 0xE00FEFF8 | CIDR2     | 0x0000005  |
| 0xE00FEFF4 | CIDR1     | 0x0000010  |
| 0xE00FEFF0 | CIDR0     | 0x000000D  |
| 0xE00FEFDC | PIDR7     | 0x0000000  |
| 0xE00FEFD8 | PIDR6     | 0x0000000  |
| 0xE00FEFD4 | PIDR5     | 0x0000000  |
| 0xE00FEFD0 | PIDR4     | 0x00000002 |
| 0xE00FEFEC | PIDR3     | 0x0000000  |
| 0xE00FEFE8 | PIDR2     | 0x000001C  |
| 0xE00FEFE4 | PIDR1     | 0x00000040 |
| 0xE00FEFE0 | PIDR0     | 0x0000007  |
| 0xE00FEFCC | МЕМТҮРЕ   | 0x0000001  |
| 0xE00FE004 | TPIU      | 0xFFF42003 |
| 0xE00FE000 | ROM table | 0x00001003 |

Table 194: Application core ROM table entries

| Address    | Component             | Value      |
|------------|-----------------------|------------|
| 0xE00FF01C | MTB (not implemented) | 0xFFF44002 |
| 0xE00FF018 | СТІ                   | 0xFFF43003 |
| 0xE00FF014 | ETM                   | 0xFFF42003 |
| 0xE00FF00C | ITM                   | 0xFFF01003 |
| 0xE00FF008 | BPU                   | 0xFFF03003 |
| 0xE00FF004 | DWT                   | 0xFFF02003 |
| 0xE00FF000 | SCS                   | 0xFFF0F003 |

Table 195: Application Arm Cortex-M33 ROM table entries





Figure 249: Network core ROM table overview

| Address    | Component | Value      |
|------------|-----------|------------|
| 0xE00FEFFC | CIDR3     | 0x000000B1 |
| 0xE00FEFF8 | CIDR2     | 0x00000005 |
| 0xE00FEFF4 | CIDR1     | 0x00000010 |
| 0xE00FEFF0 | CIDR0     | 0x000000D  |
| 0xE00FEFDC | PIDR7     | 0x0000000  |
| 0xE00FEFD8 | PIDR6     | 0x0000000  |
| 0xE00FEFD4 | PIDR5     | 0x0000000  |
| 0xE00FEFD0 | PIDR4     | 0x00000002 |
| 0xE00FEFEC | PIDR3     | 0x0000000  |
| 0xE00FEFE8 | PIDR2     | 0x0000001C |
| 0xE00FEFE4 | PIDR1     | 0x00000040 |
| 0xE00FEFE0 | PIDR0     | 0x0000007  |
| 0xE00FEFCC | МЕМТҮРЕ   | 0x0000001  |
| 0xE00FE000 | ROM table | 0x00001003 |

Table 196: Network core ROM table entries



| Address    | Component             | Value      |
|------------|-----------------------|------------|
| 0xE00FF01C | MTB (not implemented) | 0xFFF44002 |
| 0xE00FF018 | СТІ                   | 0xFFF43003 |
| 0xE00FF014 | ETM (not implemented) | 0xFFF42002 |
| 0xE00FF00C | ITM (not implemented) | 0xFFF01002 |
| 0xE00FF008 | BPU                   | 0xFFF03003 |
| 0xE00FF004 | DWT                   | 0xFFF02003 |
| 0xE00FF000 | scs                   | 0xFFF0F003 |

Table 197: Network Arm Cortex-M33 ROM table entries

# 8.6 Cross-trigger network

The debug system has a cross-trigger network used to simultaneously start and halt the cores in the system.

The following diagram shows an overview of the cross-trigger connections.



Figure 250: Cross-trigger network block diagram

Both the application and network cores have a cross-trigger interface (CTI) peripheral that can trigger events or be triggered by signals in the processor or debug blocks. The CTI can be configured to route trigger in-signals to trigger out-signals within the CTI or the cross-trigger matrix. The cross-trigger matrix has four channels in total that can be used to communicate trigger signals between cores.

You can stop the network core when the application core is stopped (due to a breakpoint or a stopped debug session), by doing the following:

- **1.** Configure the application core CTI to generate an event on channel 0 for CTITRIGIN[0] (processor halted) using CTIINEN[0].
- 2. Configure the network core CTI to trigger CTITRIGOUT[0] (processor debug request) on channel 0 using CTIOUTEN[0].



#### Configuring the cross-trigger interface

In this example, the following CTI channels are used:

- Channel 0 is used to relay debug requests from the application to the network domain.
- Channel 1 is used to relay debug requests from the network to the application domain.
- Channel 2 is used by the debugger to send a common trigger for restarting both domains after a breakpoint.

For the application core, add the following code:

```
#define CTI_TRIGIN_CPUHALTED 0
#define CTI_TRIGOUT_DEBUGREQ 0
#define CTI_TRIGOUT_CPURESTART 1
...
// Enable global CTI routing
NRF_CTI_S->CTICONTROL = CTI_CTICONTROL_GLBEN_Enabled;
// Connect the CPU halted trigger of this domain to debug request of the other domain
NRF_CTI_S->CTIINEN[CTI_TRIGIN_CPUHALTED] = CTI_CTIINEN_TRIGINEN_0_Msk;
NRF_CTI_S->CTIOUTEN[CTI_TRIGOUT_DEBUGREQ] = CTI_CTIOUTEN_TRIGOUTEN_1_Msk;
NRF_CTI_S->CTIOUTEN[CTI_TRIGOUT_CPURESTART] = CTI_CTIOUTEN_TRIGOUTEN_2_Msk;
```

For the network core, add the following code:

```
#define CTI_TRIGOUT_DEBUGREQ 0
#define CTI_TRIGOUT_CPURESTART 1
...
// Enable global CTI routing
NRF_CTI_NS->CTICONTROL = CTI_CTICONTROL_GLBEN_Enabled;
// Connect the CPU halted trigger of this domain to debug request of the other domain
NRF_CTI_NS->CTIINEN[CTI_TRIGIN_CPUHALTED] = CTI_CTIINEN_TRIGINEN_1_Msk;
NRF_CTI_NS->CTIOUTEN[CTI_TRIGOUT_DEBUGREQ] = CTI_CTIOUTEN_TRIGOUTEN_0_Msk;
NRF_CTI_NS->CTIOUTEN[CTI_TRIGOUT_CPURESTART] = CTI_CTIOUTEN_TRIGOUTEN_2_Msk;
```

See the following tables for more information about trigger connections to and from the CTI.

| Signal       | Description             |  |  |
|--------------|-------------------------|--|--|
| CTITRIGIN[0] | Processor halted        |  |  |
| CTITRIGIN[1] | DWT comparator output 0 |  |  |
| CTITRIGIN[2] | DWT comparator output 1 |  |  |
| CTITRIGIN[3] | DWT comparator output 2 |  |  |
| CTITRIGIN[4] | ETM event output 0      |  |  |
| CTITRIGIN[5] | ETM event output 1      |  |  |

Table 198: Application core triggers to CTI



| Signal        | Description             |
|---------------|-------------------------|
| CTITRIGOUT[0] | Processor debug request |
| CTITRIGOUT[1] | Processor restart       |
| CTITRIGOUT[2] | N/A                     |
| CTITRIGOUT[3] | N/A                     |
| CTITRIGOUT[4] | ETM event input 0       |
| CTITRIGOUT[5] | ETM event input 1       |
| CTITRIGOUT[6] | ETM event input 2       |
| CTITRIGOUT[7] | ETM event input 3       |

Table 199: Application core triggers from CTI

| Signal       | Description             |
|--------------|-------------------------|
| CTITRIGIN[0] | Processor halted        |
| CTITRIGIN[1] | DWT comparator output 0 |
| CTITRIGIN[2] | DWT comparator output 1 |
| CTITRIGIN[3] | DWT comparator output 2 |

Table 200: Network core triggers to CTI

| Signal        | Description             |
|---------------|-------------------------|
| CTITRIGOUT[0] | Processor debug request |
| CTITRIGOUT[1] | Processor restart       |

Table 201: Network core triggers from CTI

# 8.7 Multidrop serial wire debug

Multidrop serial wire debug allows simultaneous access to an unlimited number of devices through a single connection. This is useful for connectivity-constrained products that contain multiple chips with multidrop support.

In order to select a target in a multidrop capable product, the debugger must write the correct TINSTANCE, TPARTNO, and TDESIGNER fields into the SW-DP TARGETSEL register. The values for these fields are located in and fetched from two registers, TARGETID on page 752 and DLPIDR on page 753.

For more information about multidrop SWD, see *Arm Debug Interface Architecture Specification*, ADIv5.0 to ADIv5.2.

## 8.8 Trace

The device supports ETM and ITM trace.



Trace data from the ETM and the ITM is sent to an external debugger via a 4-bit wide parallel trace port (TPIU), see Debug and trace overview on page 751 (TRACEDATA[0] through TRACEDATA[3], and TRACECLK).

In addition to parallel trace, the TPIU supports serial trace via the serial wire output (SWO) trace protocol. Parallel and serial trace cannot be used at the same time. ETM trace is supported in Parallel trace mode only, while both parallel and Serial trace modes support the ITM trace. For details on how to use the trace capabilities, see the debug documentation of your IDE.

TPIU's dedicated trace pins are multiplexed with GPIOs. SWO and TRACEDATA[0] use the same GPIO. Trace is limited to dedicated pins. See Pin assignments on page 790 for more information.

Trace speed is configured in the register TRACEPORTSPEED (Retained) on page 788. The speed of the trace pins depends on the drive setting of the GPIOs that the trace pins are multiplexed with. The drive setting is configured using the DRIVE field of the GPIO register PIN\_CNF[n] (n=0..31) (Retained) on page 233.

Only drive settings SOS1, H0H1, and E0E1 should be used for debugging. SOS1 is the default drive at reset. If parallel or serial trace port signals are not fast enough in the debugging conditions, all GPIOs in use for tracing should be set to high drive (H0H1), or extra high drive (E0E1) for the fastest trace port speeds. Ensure that the drive setting of the GPIOs are not overwritten by software during the debugging session.

In addition to DRIVE, the GPIO pin must be assigned to trace and debug (TND), using the MCUSEL field of the the PIN\_CNF register. When pins are assigned to TND, these GPIOs are output-only, and other functionality of the pins is disabled.

# 8.9 Enabling the trace port

A specific sequence of operations must be performed to enable the trace port.

1. Enable the debug master.

```
NRF_TAD_S->ENABLE = TAD_ENABLE_ENABLE_Msk;
```

**2.** Request clock startup.

```
NRF_TAD_S->CLOCKSTART = TAD_CLOCKSTART_START_Msk;
```

**3.** Configure the trace port to use pins P0.08 through P0.12.

```
NRF_TAD_S->PSEL.TRACECLK = TAD_PSEL_TRACECLK_PIN_Traceclk;
NRF_TAD_S->PSEL.TRACEDATA0 = TAD_PSEL_TRACEDATA0_PIN_Tracedata0;
NRF_TAD_S->PSEL.TRACEDATA1 = TAD_PSEL_TRACEDATA1_PIN_Tracedata1;
NRF_TAD_S->PSEL.TRACEDATA2 = TAD_PSEL_TRACEDATA2_PIN_Tracedata2;
NRF_TAD_S->PSEL.TRACEDATA3 = TAD_PSEL_TRACEDATA3_PIN_Tracedata3;
```

**4.** Configure the GPIO pins so that the trace and debug system can control them. Set high drive strength to ensure sufficiently fast operation. Do this for all trace pins that should be used.



5. Set trace port speed to 64 MHz.

```
NRF_TAD_S->TRACEPORTSPEED = TAD_TRACEPORTSPEED_TRACEPORTSPEED_64MHz;
```

**Note:** Although possible, it is not recommended to run the trace port at less than half the CPU frequency, as it risks dropping some trace packets.

6. Configure Arm CoreSight components (see Arm CoreSight documentation for more information).

# 8.10 CTRL-AP - Control access port

The control access port (CTRL-AP) is a custom access port that enables control of the device when other debug access ports (DAP) have been disabled by the access port protection.

For an overview of the other debug access ports, see DAP — Debug access port on page 752.



Figure 251: Control access port details

Access port protection (APPROTECT) blocks the debugger access to the AHB-AP, and prevents read and write access to all CPU registers and memory-mapped addresses. To enable port protection access for both secure and non-secure modes, use the registers UICR.SECUREAPPROTECT and UICR.APPROTECT, as well as CTRLAP.APPROTECT.DISABLE and CTRLAP.SECUREAPPROTECT.DISABLE. The debugger can use the register to read the status of secure and non-secure access port protection.

Erase protection (ERASEPROTECT) protects the flash and UICR parts of the non-volatile memory from being erased. Erase protection can be temporarily disabled from the control access port.

NORDIC\*

CTRL-AP has the following features:

- Soft reset
- Erase all
- · Mailbox interface
- Debug of protected devices

#### 8.10.1 Reset request

The debugger can request the device to perform a soft reset.

Use the register RESET on page 768 to request a soft reset. Once the soft reset is performed, the reset reason is accessible on the on-chip firmware through the RESETREAS register. For more information about the soft reset, see RESET — Reset control on page 65.

#### 8.10.2 Frase all

The erase all function lets the debugger trigger an erase of flash, user information configuration registers (UICR), RAM, all peripheral settings, and also temporarily removes the access port protection.

To trigger an erase all function, the debugger writes to the register ERASEALL on page 768. The register ERASEALLSTATUS on page 768 will read as busy for the duration of the operation. The ERASEALL mechanism completes its tasks by writing UICR.APPROTECT to the Unprotected value, in addition to writing the CPU side CTRLAP.SECUREAPPROTECT.DISABLE and CTRLAP.APPROTECT.DISABLE registers to the value  $0 \times 50 \, \text{FA} 50 \, \text{FA}$ . After the next soft reset, the access port protection is temporarily removed. This temporary unprotection is removed by the next pin reset, power-on reset, brown-out reset, or watchdog timer reset. For more information about access port protection, see Access port protection on page 754.

If the debugger performs an erase all function on a slave MCU, the erase sequence will always erase the application MCU first, independently of how the application is protected, before erasing the slave MCU.

#### **Erase all protection**

It is possible to prevent the debugger from performing an erase all operation by writing to the UICR.ERASEPROTECT register. Once the register is configured and the device is reset, the CTRL-AP ERASEALL operation is disabled, and all flash write and erase operations are restricted to the firmware. In addition, it is still possible to write/erase from the debugger as long as the UICR.APPROTECT register is not set.

**Note:** Setting the UICR.ERASEPROTECT register only affects the erase all operation and not the debugger access.

The register ERASEPROTECT.STATUS on page 769 holds the status for erase protection.

#### 8.10.3 Mailbox interface

CTRL-AP implements a mailbox interface which enables the CPU to communicate with a debugger over the SWD interface.

The mailbox interface consists of a transmit register MAILBOX.TXDATA on page 770 with its corresponding status register MAILBOX.TXSTATUS on page 770, and a receive register MAILBOX.RXDATA on page 771 with its corresponding status register MAILBOX.RXSTATUS on page 771. Status bits in the TXSTATUS/RXSTATUS registers are set and cleared automatically when the TXDATA/RXDATA registers are written to and read from, independently of the direction.





Figure 252: Mailbox register interface

#### Mailbox transfer sequence

- 1. Sender writes TXDATA.
- 2. Hardware sets sender's TXSTATUS to DataPending.
- 3. Hardware sets receiver's RXSTATUS to DataPending.
- 4. Receiver reads RXDATA.
- 5. Hardware sets receiver's RXSTATUS to NoDataPending.
- 6. Hardware sets sender's TXSTATUS to NoDataPending.

#### 8.10.4 Disabling erase protection

The erase protection mechanism can be disabled to return a device to factory default settings on next reset.

The debugger can read the erase protection status in the register ERASEPROTECT.STATUS on page 769.

If ERASEPROTECT has been enabled, both the debugger and on-chip firmware must write the same non-zero 32-bit KEY value into their respective ERASEPROTECT.DISABLE registers to disable the erase protection. When both registers have been written with the same non-zero 32-bit KEY value, the device is automatically erased as described in Erase all on page 765. The access ports will be re-enabled on the next reset once the secure erase sequence has completed.

The write-once register ERASEPROTECT.LOCK on page 773 should be set to Locked as early as possible in the start-up sequence, preferably as soon as the on-chip firmware has determined it does not need to communicate with a debugger over the CTRL-AP mailbox interface. Once written, it will not be possible to remove the erase protection until the next reset.

# 8.10.5 Disabling access port protection

The access port protection mechanisms can be temporarily disabled to debug the device.

The disabling of the access port protection is done through a combination of UICR and CTRL-AP registers.

#### Disabling non-secure access port protection

If UICR.APPROTECT has been enabled from UICR, the device access port is protected.

If UICR.APPROTECT has not been enabled from UICR, both the debugger and on-chip firmware must write the same non-zero 32-bit KEY value into their respective registers CTRLAP.APPROTECT.DISABLE (CPU-side) and CTRLAP.APPROTECT.DISABLE (debugger-side) to disable the access port protection to non-secure mode.



The write-once register APPROTECT.LOCK on page 774 should be set to Locked as early as possible in the start-up sequence. Once written, it will not be possible to remove the non-secure mode access port protection until next reset.

#### Disabling secure access port protection

If UICR.APPROTECT has been enabled from UICR, the device access port is protected.

If UICR.SECUREAPPROTECT has not been enabled from UICR, both the debugger and onchip firmware must write the same non-zero 32-bit KEY value into their respective registers CTRLAP.SECUREAPPROTECT.DISABLE (CPU-side) and CTRLAP.SECUREAPPROTECT.DISABLE (debugger-side) to disable the access port protection to secure mode.

The write-once register SECUREAPPROTECT.LOCK on page 774 should be set to Locked as early as possible in the start-up sequence, preferably as soon as on-chip firmware has determined it does not need to communicate with a debugger over the CTRL-AP mailbox interface. Once written, it will not be possible to remove the secure mode access port protection until next reset.

**Note:** If secure mode debug is enabled, an ERASEALL sequence can also be initiated by writing the same 32-bit KEY value into the respective ERASEPROTECT.DISABLE registers

The CTRLAP.APPROTECT.DISABLE and CTRLAP.SECUREAPPROTECT.DISABLE registers are only reset by pin reset, brown-out reset, or watchdog timer reset. This allows keeping the debug session active through soft resets.

After an ERASEALL sequence has completed, the access port protection of the core's AHB-AP is disabled until the next pin reset, power-on reset, brown-out reset, or watchdog timer reset. This will allow initial firmware to be written. For more details on ERASEALL, see Erase all on page 765.

#### Access port protection status

The debugger can read the access port protection status in the core's AHB-AP, using the Arm AHB-AP Control/Status Word register (CSW), defined in the *Arm CoreSight SoC-400 Technical Reference Manual, Revision r3p2*. The <code>DbgStatus</code> field indicates that the AHB-AP can perform AHB transfers, while the <code>SPIStatus</code> indicates if secure AHB transfers are permitted. For a list of all debug access ports, see <code>DAP — Debug access port</code> on page 752.

#### 8.10.6 Debugger registers

CTRL-AP has a set of registers that can only be accessed from the debugger over the SWD interface. These are not accessible from the CPU.

The SECUREAPPROTECT fields and registers only apply for cores that have the Arm Cortex-M33 with TrustZone technology.

#### 8.10.6.1 Registers

| Register                | Offset | Security | Description                                                                         |
|-------------------------|--------|----------|-------------------------------------------------------------------------------------|
| register                | Offset | Security | Description                                                                         |
| RESET                   | 0x000  |          | System reset request.                                                               |
| ERASEALL                | 0x004  |          | Perform a secure erase of the device, where flash, SRAM, and UICR will be erased in |
|                         |        |          | sequence. The device will be returned to factory default settings upon next reset.  |
| ERASEALLSTATUS          | 0x008  |          | This is the status register for the ERASEALL operation.                             |
| APPROTECT.DISABLE       | 0x010  |          | This register disables APPROTECT and enables debug access to non-secure mode.       |
| SECUREAPPROTECT.DISABLE | 0x014  |          | This register disables SECUREAPPROTECT and enables debug access to secure mode.     |
| ERASEPROTECT.STATUS     | 0x018  |          | This is the status register for the UICR ERASEPROTECT configuration.                |
| ERASEPROTECT.DISABLE    | 0x01C  |          | This register disables ERASEPROTECT and performs ERASEALL.                          |
| MAILBOX.TXDATA          | 0x020  |          | Data sent from the debugger to the CPU.                                             |



| Register         | Offset | Security | Description                                                                           |
|------------------|--------|----------|---------------------------------------------------------------------------------------|
| MAILBOX.TXSTATUS | 0x024  |          | This register shows a status that indicates if data sent from the debugger to the CPU |
|                  |        |          | has been read.                                                                        |
| MAILBOX.RXDATA   | 0x028  |          | Data sent from the CPU to the debugger.                                               |
| MAILBOX.RXSTATUS | 0x02C  |          | This register shows a status that indicates if data sent from the CPU to the debugger |
|                  |        |          | has been read.                                                                        |
| IDR              | 0x0FC  |          | CTRL-AP Identification Register, IDR.                                                 |

Table 202: Register overview

#### 8.10.6.1.1 RESET

Address offset: 0x000 System reset request.

This register is automatically deactivated during an ERASEALL operation.



#### 8.10.6.1.2 ERASEALL

Address offset: 0x004

Perform a secure erase of the device, where flash, SRAM, and UICR will be erased in sequence. The device will be returned to factory default settings upon next reset.



#### 8.10.6.1.3 ERASEALLSTATUS

Address offset: 0x008

This is the status register for the ERASEALL operation.





#### 8.10.6.1.4 APPROTECT.DISABLE

Address offset: 0x010

This register disables APPROTECT and enables debug access to non-secure mode.



#### 8.10.6.1.5 SECUREAPPROTECT.DISABLE

Address offset: 0x014

This register disables SECUREAPPROTECT and enables debug access to secure mode.



#### 8.10.6.1.6 ERASEPROTECT.STATUS

Address offset: 0x018

This is the status register for the UICR ERASEPROTECT configuration.





#### 8.10.6.1.7 ERASEPROTECT.DISABLE

Address offset: 0x01C

This register disables ERASEPROTECT and performs ERASEALL.



#### 8.10.6.1.8 MAILBOX.TXDATA

Address offset: 0x020

Data sent from the debugger to the CPU.

Writing to this register will automatically set a DataPending value in the TXSTATUS register.



#### 8.10.6.1.9 MAILBOX.TXSTATUS

Address offset: 0x024

This register shows a status that indicates if data sent from the debugger to the CPU has been read.







#### 8.10.6.1.10 MAILBOX.RXDATA

Address offset: 0x028

Data sent from the CPU to the debugger.

Reading from this register will automatically set a NoDataPending value in the RXSTATUS register.



#### 8.10.6.1.11 MAILBOX.RXSTATUS

Address offset: 0x02C

This register shows a status that indicates if data sent from the CPU to the debugger has been read.



#### 8.10.6.1.12 IDR

Address offset: 0x0FC

CTRL-AP Identification Register, IDR.

| Bit n | umber   |            |            | 31 30 29 28 27 26 25 2 | 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|------------|------------|------------------------|------------------------------------------------------------------|
| ID    |         |            |            | EEEEDDD                | D C C C C C C B B B B A A A A A A A                              |
| Rese  | t 0x128 | 80000      |            | 0 0 0 1 0 0 1          | 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0                          |
| ID    |         |            |            |                        |                                                                  |
| Α     | R       | APID       |            |                        | AP Identification                                                |
| В     | R       | CLASS      |            |                        | Access Port (AP) class                                           |
|       |         |            | NotDefined | 0x0                    | No defined class                                                 |
|       |         |            | MEMAP      | 0x8                    | Memory Access Port                                               |
| С     | R       | JEP106ID   |            |                        | JEDEC JEP106 identity code                                       |
| D     | R       | JEP106CONT |            |                        | JEDEC JEP106 continuation code                                   |
| Е     | R       | REVISION   |            |                        | Revision                                                         |



# 8.10.7 Registers

| Base address | Domain      | Peripheral  | Instance   | Secure mapping | DMA security | Description             | Configuration            |
|--------------|-------------|-------------|------------|----------------|--------------|-------------------------|--------------------------|
| 0x50006000   | APPLICATION | CTDI ADDEDI | CTRLAP: S  | US             | NSA          | Control access port CPU |                          |
| 0x40006000   | APPLICATION | CIRLAPPERI  | CTRLAP: NS | 03             |              | side                    |                          |
| 0x41006000   | NETWORK     | CTRLAPPERI  | CTRLAP     | NS             | NA           | Control access port CPU | SECUREAPPROTECT.LOCK,    |
|              |             |             |            |                |              | side                    | SECUREAPPROTECT.DISABLI  |
|              |             |             |            |                |              |                         | and                      |
|              |             |             |            |                |              |                         | STATUS.SECUREAPPROTECT   |
|              |             |             |            |                |              |                         | registers not supported. |

Table 203: Instances

| Register                | Offset | Security | Description                                                                           |
|-------------------------|--------|----------|---------------------------------------------------------------------------------------|
| MAILBOX.RXDATA          | 0x400  |          | Data sent from the debugger to the CPU.                                               |
| MAILBOX.RXSTATUS        | 0x404  |          | This register shows a status that indicates if data sent from the debugger to the CPU |
|                         |        |          | has been read.                                                                        |
| MAILBOX.TXDATA          | 0x480  |          | Data sent from the CPU to the debugger.                                               |
| MAILBOX.TXSTATUS        | 0x484  |          | This register shows a status that indicates if the data sent from the CPU to the      |
|                         |        |          | debugger has been read.                                                               |
| ERASEPROTECT.LOCK       | 0x500  |          | This register locks the ERASEPROTECT.DISABLE register from being written until next   |
|                         |        |          | reset.                                                                                |
| ERASEPROTECT.DISABLE    | 0x504  |          | This register disables the ERASEPROTECT register and performs an ERASEALL             |
|                         |        |          | operation.                                                                            |
| APPROTECT.LOCK          | 0x540  |          | This register locks the APPROTECT.DISABLE register from being written to until next   |
|                         |        |          | reset.                                                                                |
| APPROTECT.DISABLE       | 0x544  |          | This register disables the APPROTECT register and enables debug access to non-secure  |
|                         |        |          | mode.                                                                                 |
| SECUREAPPROTECT.LOCK    | 0x548  |          | This register locks the SECUREAPPROTECT.DISABLE register from being written until     |
|                         |        |          | next reset.                                                                           |
| SECUREAPPROTECT.DISABLE | 0x54C  |          | This register disables the SECUREAPPROTECT register and enables debug access to       |
|                         |        |          | secure mode.                                                                          |
| STATUS                  | 0x600  |          | Status bits for CTRL-AP peripheral.                                                   |

Table 204: Register overview

#### 8.10.7.1 MAILBOX.RXDATA

Address offset: 0x400

Data sent from the debugger to the CPU.

Reading from this register will automatically set a NoDataPending value in the RXSTATUS register.

| Α     | R        | RXDATA |                      | Data received from debugger                                     |
|-------|----------|--------|----------------------|-----------------------------------------------------------------|
| ID    |          |        |                      |                                                                 |
| Res   | et 0x000 | 000000 | 0 0 0 0 0 0 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |          |        | A A A A A A          | A A A A A A A A A A A A A A A A A A A                           |
| Bit r | number   |        | 31 30 29 28 27 26 25 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |

#### 8.10.7.2 MAILBOX.RXSTATUS

Address offset: 0x404

This register shows a status that indicates if data sent from the debugger to the CPU has been read.





#### 8.10.7.3 MAILBOX.TXDATA

Address offset: 0x480

Data sent from the CPU to the debugger.

Writing to this register will automatically set a DataPending value in the TXSTATUS register.



#### 8.10.7.4 MAILBOX.TXSTATUS

Address offset: 0x484

This register shows a status that indicates if the data sent from the CPU to the debugger has been read.



#### 8.10.7.5 ERASEPROTECT.LOCK

Address offset: 0x500

This register locks the ERASEPROTECT.DISABLE register from being written until next reset.



#### 8.10.7.6 ERASEPROTECT.DISABLE

Address offset: 0x504

This register disables the ERASEPROTECT register and performs an ERASEALL operation.





#### 8.10.7.7 APPROTECT.LOCK

Address offset: 0x540

This register locks the APPROTECT.DISABLE register from being written to until next reset.



#### 8.10.7.8 APPROTECT. DISABLE

Address offset: 0x544

This register disables the APPROTECT register and enables debug access to non-secure mode.



#### 8.10.7.9 SECUREAPPROTECT.LOCK

Address offset: 0x548

This register locks the SECUREAPPROTECT.DISABLE register from being written until next reset.





#### 8.10.7.10 SECUREAPPROTECT.DISABLE

Address offset: 0x54C

This register disables the SECUREAPPROTECT register and enables debug access to secure mode.



#### 8.10.7.11 STATUS

Address offset: 0x600

Status bits for CTRL-AP peripheral.



| Bit r | number   |                     |          | 31 30 29 28 27 26 25 24 | <sup>4</sup> 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|---------------------|----------|-------------------------|----------------------------------------------------------------------------|
| ID    |          |                     |          |                         | СВА                                                                        |
| Res   | et 0x000 | 00000               |          | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
| ID    |          |                     |          |                         |                                                                            |
| Α     | R        | UICRAPPROTECT       |          |                         | Status bit for UICR part of access port protection at last                 |
|       |          |                     |          |                         | reset.                                                                     |
|       |          |                     |          |                         | The reset value is automatically read from the APPROTECT                   |
|       |          |                     |          |                         | register in UICR.                                                          |
|       |          |                     | Enabled  | 0                       | APPROTECT was enabled in UICR                                              |
|       |          |                     | Disabled | 1                       | APPROTECT wasdisabled in UICR                                              |
| В     | R        | UICRSECUREAPPROTECT | Г        |                         | Status bit for UICR part of secure access port protection at               |
|       |          |                     |          |                         | last reset.                                                                |
|       |          |                     |          |                         | The reset value is automatically read from the                             |
|       |          |                     |          |                         | SECUREAPPROTECT register in UICR.                                          |
|       |          |                     | Enabled  | 0                       | SECUREAPPROTECT was enabled in UICR                                        |
|       |          |                     | Disabled | 1                       | SECUREAPPROTECT was disabled in UICR                                       |
| С     | R        | DBGIFACEMODE        |          |                         | Status bit for device debug interface mode                                 |
|       |          |                     | Disabled | 0                       | No debugger attached                                                       |
|       |          |                     | Enabled  | 1                       | Debugger is attached and device is in debug interface                      |
|       |          |                     |          |                         | mode                                                                       |

# 8.11 CTI - Cross Trigger Interface

Configuration interface for the Cross Trigger Interface

Please refer to the CTI section for more information about how to configure the Cross Trigger Interface.

# 8.11.1 Registers

| Base address Domain    | Peripheral | Instance | Secure mapping | DMA security | Description             | Configuration        |
|------------------------|------------|----------|----------------|--------------|-------------------------|----------------------|
| 0xE0042000 APPLICATION | CTI        | CTI      | S              | NA           | Cross-trigger interface | Application core CTI |
| 0xE0042000 NETWORK     | CTI        | CTI      | NS             | NA           | Cross-trigger interface | Network core CTI     |

Table 205: Instances

| Offset | Security                                                                            | Description                                                                               |
|--------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 0x000  |                                                                                     | CTI Control register                                                                      |
| 0x010  |                                                                                     | CTI Interrupt Acknowledge register                                                        |
| 0x014  |                                                                                     | CTI Application Trigger Set register                                                      |
| 0x018  |                                                                                     | CTI Application Trigger Clear register                                                    |
| 0x01C  |                                                                                     | CTI Application Pulse register                                                            |
| 0x020  |                                                                                     | CTI Trigger to Channel Enable register                                                    |
| 0x0A0  |                                                                                     | CTI Channel to Trigger Enable register                                                    |
| 0x130  |                                                                                     | CTI Trigger In Status register                                                            |
| 0x134  |                                                                                     | CTI Trigger Out Status register                                                           |
| 0x138  |                                                                                     | CTI Channel In Status register                                                            |
| 0x140  |                                                                                     | Enable CTI Channel Gate register                                                          |
| 0xFBC  |                                                                                     | Device Architecture register                                                              |
| 0xFC8  |                                                                                     | Device Configuration register                                                             |
| 0xFCC  |                                                                                     | Device Type Identifier register                                                           |
| 0xFD0  |                                                                                     | Peripheral ID4 Register                                                                   |
| 0xFD4  |                                                                                     | Peripheral ID5 register                                                                   |
|        | 0x000 0x010 0x014 0x018 0x01C 0x020 0x0A0 0x130 0x134 0x138 0x140 0xFBC 0xFCS 0xFCC | 0x000 0x010 0x014 0x018 0x01C 0x020 0x0A0 0x130 0x134 0x138 0x140 0xFBC 0xFCS 0xFCC 0xFD0 |



| Register | Offset | Security | Description             |
|----------|--------|----------|-------------------------|
| PIDR6    | 0xFD8  |          | Peripheral ID6 register |
| PIDR7    | 0xFDC  |          | Peripheral ID7 register |
| PIDR0    | 0xFE0  |          | Peripheral IDO Register |
| PIDR1    | 0xFE4  |          | Peripheral ID1 Register |
| PIDR2    | 0xFE8  |          | Peripheral ID2 Register |
| PIDR3    | 0xFEC  |          | Peripheral ID3 Register |
| CIDR0    | 0xFF0  |          | Component IDO Register  |
| CIDR1    | 0xFF4  |          | Component ID1 Register  |
| CIDR2    | 0xFF8  |          | Component ID2 Register  |
| CIDR3    | 0xFFC  |          | Component ID3 Register  |
|          |        |          |                         |

Table 206: Register overview

#### **8.11.1.1 CTICONTROL**

Address offset: 0x000 CTI Control register

The CTICONTROL register enables the CTI.



#### 8.11.1.2 CTIINTACK

Address offset: 0x010

CTI Interrupt Acknowledge register

The CTIINTACK register is a software acknowledge for a trigger output. This register is used when ctitrigout is used as a sticky output. That is, no hardware acknowledge is available and a software acknowledge is required.



#### 8.11.1.3 CTIAPPSET

Address offset: 0x014

CTI Application Trigger Set register

Writing to the CTIAPPSET register causes a channel event to be raised, corresponding to the bit written to.





#### 8.11.1.4 CTIAPPCLEAR

Address offset: 0x018

CTI Application Trigger Clear register

Writing to a bit in the CTIAPPCLEAR register clears the corresponding channel event.

| Bit nu | umber   |                    |       | 31 30 29 28 27 2 | 26 25 24 : | 23 22 2:             | 1 20 1 | 9 18   | 17 1  | 6 15  | 14 1   | 3 12 | 11 1 | 0 9  | 8     | 7 6   | 5 5  | 4  | 3 | 2 | 1 0 |
|--------|---------|--------------------|-------|------------------|------------|----------------------|--------|--------|-------|-------|--------|------|------|------|-------|-------|------|----|---|---|-----|
| ID     |         |                    |       |                  |            |                      |        |        |       |       |        |      |      |      |       |       |      |    | D | С | ВА  |
| Rese   | t 0x000 | 00000              |       | 0 0 0 0 0        | 0 0 0      | 0 0 0                | 0 0    | 0 0    | 0 (   | 0     | 0 (    | 0 0  | 0 (  | 0    | 0     | 0 (   | 0    | 0  | 0 | 0 | 0 0 |
| ID     |         |                    |       |                  |            | Descrip <sup>®</sup> |        |        |       |       |        |      |      |      |       |       |      |    |   |   |     |
| A-D    | W       | APPCLEAR[i] (i=03) |       |                  |            | Sets the             | e corr | espor  | ndin  | g bit | s in t | he C | TIAP | PSET | Γto ( | ). Th | nere | is |   |   |     |
|        |         |                    |       |                  |            | one bit              | of the | e regi | ster  | for e | ach    | chan | nel. |      |       |       |      |    |   |   |     |
|        |         |                    | Clear | 1                |            | Clears t             | he ev  | ent fo | or ch | nann  | el i.  |      |      |      |       |       |      |    |   |   |     |

#### 8.11.1.5 CTIAPPPULSE

Address offset: 0x01C

CTI Application Pulse register

A write to this register causes a channel event pulse of one cticlk period to be generated. This corresponds to the bit that was written to. The pulse external to the CTI can be extended to multi-cycle by the handshaking interface circuits. This register clears itself immediately, so it can be repeatedly written to without software having to clear it.



#### 8.11.1.6 CTIINEN[n] (n=0..7)

Address offset:  $0x020 + (n \times 0x4)$ 

CTI Trigger to Channel Enable register

The CTIINENn register enables the signaling of an event on CTM channels when a trigger event is received by the CTI. There is a bit for each of the four channels implemented. This register does not affect the application trigger operations.





#### 8.11.1.7 CTIOUTEN[n] (n=0..7)

Address offset:  $0x0A0 + (n \times 0x4)$ 

CTI Channel to Trigger Enable register

The CTIOUTENn register defines which channels can generate a ctitrigout[n] output. There is a bit for each of the four channels implemented. This register affects the mapping from application trigger to trigger outputs.



#### 8.11.1.8 CTITRIGINSTATUS

Address offset: 0x130

CTI Trigger In Status register

The CTITRIGINSTATUS register provides the status of the ctitrigin inputs.



#### 8.11.1.9 CTITRIGOUTSTATUS

Address offset: 0x134

CTI Trigger Out Status register

The CTITRIGOUTSTATUS register provides the status of the ctitrigout outputs.





#### **8.11.1.10 CTICHINSTATUS**

Address offset: 0x138

CTI Channel In Status register

The CTICHINSTATUS register provides the status of the ctichin inputs.



#### 8.11.1.11 CTIGATE

Address offset: 0x140

**Enable CTI Channel Gate register** 

The CTIGATE register prevents the channels from propagating through the CTM to other CTIs. This enables local cross-triggering (e.g. causing an interrupt when the ETM trigger occurs). It can be used effectively with CTIAPPSET, CTIAPPCLEAR, and CTIAPPPULSE for asserting trigger outputs by asserting channels, without affecting the rest of the system. On reset, this register is 0xF and channel propagation is enabled.



#### 8.11.1.12 DEVARCH

Address offset: 0xFBC

Device Architecture register





#### 8.11.1.13 DEVID

Address offset: 0xFC8

**Device Configuration register** 

The DEVID register indicates the capabilities of the component.



#### 8.11.1.14 DEVTYPE

Address offset: 0xFCC

Device Type Identifier register

The DEVTYPE register provides a debugger with information about the component when the Part Number field is not recognized. The debugger can then report this information.



#### 8.11.1.15 PIDR4

Address offset: 0xFD0
Peripheral ID4 Register

The PIDR4 register is part of the set of peripheral identification registers. It contains part of the designer identity and the memory size.





#### 8.11.1.16 PIDR5

Address offset: 0xFD4
Peripheral ID5 register



#### 8.11.1.17 PIDR6

Address offset: 0xFD8
Peripheral ID6 register



#### 8.11.1.18 PIDR7

Address offset: 0xFDC Peripheral ID7 register



#### 8.11.1.19 PIDRO

Address offset: 0xFE0
Peripheral ID0 Register

The PIDRO register is part of the set of peripheral identification registers. It contains part of the designer-specific part number.





#### 8.11.1.20 PIDR1

Address offset: 0xFE4
Peripheral ID1 Register

The PIDR1 register is part of the set of peripheral identification registers. It contains part of the designer-specific part number and part of the designer identity.

| Bit n | umber    |        |             | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|----------|--------|-------------|-------------------------|---------------------------------------------------------------|
| ID    |          |        |             |                         | B B B B A A A A                                               |
| Rese  | et 0x000 | 000BD  |             | 0 0 0 0 0 0 0 0         | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1                       |
| ID    |          |        |             |                         |                                                               |
| Α     | R        | PART_1 |             |                         | Bits[11:8] of the 12-bit part number of the component.        |
|       |          |        |             |                         | The designer of the component assigns this part number.       |
|       |          |        | PartnumberH | 13                      | Indicates bits[11:8] of the part number of the component.     |
| В     | R        | DES_0  |             |                         | Together, PIDR1.DES_0, PIDR2.DES_1, and PIDR4.DES_2           |
|       |          |        |             |                         | identify the designer of the component.                       |
|       |          |        | Arm         | 11                      | Arm. Bits[3:0] of the JEDEC JEP106 Identity Code              |

#### 8.11.1.21 PIDR2

Address offset: 0xFE8
Peripheral ID2 Register

The PIDR2 register is part of the set of peripheral identification registers. It contains part of the designer identity and the product revision.



#### 8.11.1.22 PIDR3

Address offset: 0xFEC
Peripheral ID3 Register

The PIDR3 register is part of the set of peripheral identification registers. It contains the REVAND and CMOD fields.



| umber            |          |                                        | 31 30 29 28 27 26 25 2                           | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|----------|----------------------------------------|--------------------------------------------------|-----------------------------------------------------------------|
| umber            |          |                                        | 010013101710101                                  | B B B B A A A A                                                 |
| Reset 0x00000000 |          |                                        | 0 0 0 0 0 0 0                                    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
|                  |          |                                        |                                                  |                                                                 |
| R                | CMOD     |                                        |                                                  | Customer Modified. Indicates whether the customer has           |
|                  |          |                                        |                                                  | modified the behavior of the component. In most cases,          |
|                  |          |                                        |                                                  | this field is 0b0000. Customers change this value when          |
|                  |          |                                        |                                                  | they make authorized modifications to this component.           |
|                  |          | Unmodified                             | 0                                                | Indicates that the customer has not modified this               |
|                  |          |                                        |                                                  | component.                                                      |
| R                | REVAND   |                                        |                                                  | Indicates minor errata fixes specific to the revision of        |
|                  |          |                                        |                                                  | the component being used, for example metal fixes after         |
|                  |          |                                        |                                                  | implementation. In most cases, this field is 0b0000. Arm        |
|                  |          |                                        |                                                  | recommends that the component designers ensure that a           |
|                  |          |                                        |                                                  | metal fix can change this field if required, for example, by    |
|                  |          |                                        |                                                  | driving it from registers that reset to 0b0000.                 |
|                  |          | NoErrata                               | 0                                                | Indicates that there are no errata fixes to this component.     |
|                  | R/W<br>R | et <b>0x00000000</b> R/W Field  R CMOD | R/W Field Value ID  R CMOD  Unmodified  R REVAND | R/W Field Value ID Value  R CMOD  Unmodified 0                  |

#### 8.11.1.23 CIDRO

Address offset: 0xFF0

Component IDO Register

The CIDRO register is a component identification register that indicates the presence of identification registers.



#### 8.11.1.24 CIDR1

Address offset: 0xFF4

Component ID1 Register

The CIDR1 register is a component identification register that indicates the presence of identification registers. This register also indicates the component class.





#### 8.11.1.25 CIDR2

Address offset: 0xFF8

Component ID2 Register

The CIDR2 register is a component identification register that indicates the presence of identification registers.



#### 8.11.1.26 CIDR3

Address offset: 0xFFC

Component ID3 Register

The CIDR3 register is a component identification register that indicates the presence of identification registers.



# 8.12 TAD - Trace and debug control

Configuration interface for trace and debug

Please refer to the Trace section for more information about how to configure the trace and debug interface.

**Note:** Although there are PSEL registers for the trace port, each function can only be mapped to a single pin due to pin speed requirements. Setting the PIN field to anything else will not have any effect. See Pin assignment chapter for more information

# 8.12.1 Registers



Table 207: Instances



| Register        | Offset | Security | Description                                         |          |
|-----------------|--------|----------|-----------------------------------------------------|----------|
| CLOCKSTART      | 0x004  |          | Start all trace and debug clocks.                   |          |
| CLOCKSTOP       | 0x008  |          | Stop all trace and debug clocks.                    |          |
| ENABLE          | 0x500  |          | Enable debug domain and aquire selected GPIOs       |          |
| PSEL.TRACECLK   | 0x504  |          | Pin configuration for TRACECLK                      |          |
| PSEL.TRACEDATA0 | 0x508  |          | Pin configuration for TRACEDATA[0]                  |          |
| PSEL.TRACEDATA1 | 0x50C  |          | Pin configuration for TRACEDATA[1]                  |          |
| PSEL.TRACEDATA2 | 0x510  |          | Pin configuration for TRACEDATA[2]                  |          |
| PSEL.TRACEDATA3 | 0x514  |          | Pin configuration for TRACEDATA[3]                  |          |
| TRACEPORTSPEED  | 0x518  |          | Clocking options for the Trace Port debug interface | Retained |
|                 |        |          | Poset helpovier is the same as debug compenents     |          |

Reset behavior is the same as debug components

Table 208: Register overview

#### **8.12.1.1 CLOCKSTART**

Address offset: 0x004

Start all trace and debug clocks.



#### 8.12.1.2 CLOCKSTOP

Address offset: 0x008

Stop all trace and debug clocks.



#### 8.12.1.3 ENABLE

Address offset: 0x500

Enable debug domain and aquire selected GPIOs







#### 8.12.1.4 PSEL.TRACECLK

Address offset: 0x504

Pin configuration for TRACECLK



#### 8.12.1.5 PSEL.TRACEDATAO

Address offset: 0x508

Pin configuration for TRACEDATA[0]



#### 8.12.1.6 PSEL.TRACEDATA1

Address offset: 0x50C

Pin configuration for TRACEDATA[1]







#### 8.12.1.7 PSEL.TRACEDATA2

Address offset: 0x510

Pin configuration for TRACEDATA[2]



#### 8.12.1.8 PSEL.TRACEDATA3

Address offset: 0x514

Pin configuration for TRACEDATA[3]



#### 8.12.1.9 TRACEPORTSPEED (Retained)

Address offset: 0x518

This register is a retained register

Clocking options for the Trace Port debug interface

Reset behavior is the same as debug components



| Bit n | umber   |                |       | 31 30 29 28 27 26 25 24 | 4 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------|---------|----------------|-------|-------------------------|-----------------------------------------------------------------|
| ID    |         |                |       |                         | АА                                                              |
| Rese  | t 0x000 | 00000          |       | 0 0 0 0 0 0 0           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                         |
| ID    |         |                |       |                         |                                                                 |
| Α     | RW      | TRACEPORTSPEED |       |                         | Speed of Trace Port clock. Note that the TRACECLK pin           |
|       |         |                |       |                         | output will be divided again by two from the Trace Port         |
|       |         |                |       |                         | clock.                                                          |
|       |         |                | 64MHz | 0                       | Trace Port clock is:                                            |
|       |         |                |       |                         | 64MHz                                                           |
|       |         |                | 32MHz | 1                       | Trace Port clock is:                                            |
|       |         |                |       |                         | 32MHz                                                           |
|       |         |                | 16MHz | 2                       | Trace Port clock is:                                            |
|       |         |                |       |                         | 16MHz                                                           |
|       |         |                | 8MHz  | 3                       | Trace Port clock is:                                            |
|       |         |                |       |                         | 8MHz                                                            |



# 9 Hardware and layout

# 9.1 Pin assignments

This section describes the pin assignment and the pin functions.

This device provides flexibility when it comes to routing and configuration of the GPIO pins. However, some pins have recommendations for how the pin should be configured or what it should be used for.

In addition to the information in the pinout tables for the respective packages, the following peripherals have dedicated pins that should be used for proper operation:

- TWI For the fastest TWI 1 Mbps mode, the two high-speed TWI pins must be configured in the TWI
  peripheral's PSEL registers, and the 20 mA open drain driver enabled using the E0E1 drive setting in the
  DRIVE field of the PIN\_CNF GPIO register.
- QSPI For QSPI only the dedicated GPIO pins from the following table shall be used. These must be enabled using the Peripheral option of the PIN\_CNF[p].MCUSEL register. The GPIO must use the high drive H0H1 configuration in the DRIVE field of the PIN\_CNF GPIO register.
- SPIM4 For the 32 Mbps SPI mode, the special purpose GPIO pins are enabled using the Peripheral option of the PIN\_CNF[p].MCUSEL register. When activated, the SPIM PSEL settings are ignored, and the dedicated pins are used. The GPIO must use the high drive H0H1 configuration in the DRIVE field of the PIN\_CNF GPIO register.
- TRACE When using trace, the TRACEDATA[n] and TRACECLK GPIO pins must all use the extra high drive E0E1 configuration in the DRIVE field of the PIN\_CNF GPIO register. Also, the TND option of the PIN\_CNF[p].MCUSEL register must be used.

| GPIO pin        | Description                                                                                                                                      |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| P0.08 - P0.12   | Drive configuration E0E1 is available and must be used for TRACE. For 32 Mbps high-speed SPI using SPIM4, drive configuration H0H1 must be used. |
| P0.13 - P0.18   | The H0H1 drive configuration features the highest speeds of quad SPI using the direct connection of the QSPI peripheral.                         |
| P1.02 and P1.03 | The E0E1 drive configuration activates a 20 mA open-drain driver specifically designed for high-speed TWI.                                       |
| Remaining pins  | The E0E1 drive configuration is not supported. Using the E0E1 drive configuration will cause incorrect operation.                                |

Table 209: Special GPIO considerations

**Note:** The extra high drive E0E1 drive configuration has limited availability. It is only available for the dedicated TRACE pins on P0.08 through P0.12. For the dedicated, high-speed TWIM pins on P1.02 and P1.03, the E0E1 drive configuration activates a powerful 20 mA *open-drain* driver specifically designed for high-speed TWI.

For all high-speed signals, the printed circuit board (PCB) layout must ensure that connections are made using short PCB traces. Refer to the manufacturer's PCB design recommendations for additional information.



# 9.1.1 aQFN94 pin assignments

The aQFN94 package has 94 pins in addition to four corner pads and a die pad.



Figure 253: aQFN pin assignments, top view. Corner and die pad is not illustrated.



| Pin | Name   | Function     | Description                           | Recommended usage |
|-----|--------|--------------|---------------------------------------|-------------------|
| A5  | VBUS   | Power        | 5 V input for USB 3.3 V regulator     |                   |
| A13 | DECA   | Power        | Analog regulator supply decoupling    |                   |
| A15 | DECD   | Power        | Digital regulator supply decoupling   |                   |
| A17 | P1.13  | Digital I/O  | General purpose I/O                   |                   |
| A19 | VDD    | Power        | Power supply                          |                   |
| A21 | DCC    | Power        | DC/DC converter output                |                   |
| A23 | DECN   | Power        | Regulator supply decoupling           |                   |
| A25 | N.C.   |              |                                       |                   |
| A27 | DECR   | Power        | Regulator supply decoupling           |                   |
| B2  | D+     | USB          | USB D+                                |                   |
| B4  | D-     | USB          | USB D-                                |                   |
| В6  | DECUSB | Power        | USB 3.3 V regulator supply decoupling |                   |
| В8  | VDD    | Power        | Power supply                          |                   |
| B10 | DCCD   | Power        | DC/DC converter output                |                   |
| B12 | N.C.   |              |                                       |                   |
| B14 | P1.15  | Digital I/O  | General purpose I/O                   |                   |
| B16 | P1.14  | Digital I/O  | General purpose I/O                   |                   |
| B18 | P1.12  | Digital I/O  | General purpose I/O                   |                   |
| B20 | P1.11  | Digital I/O  | General purpose I/O                   |                   |
| B22 | P0.31  | Digital I/O  | General purpose I/O                   |                   |
| B24 | P0.30  | Digital I/O  | General purpose I/O                   |                   |
| B26 | N.C.   |              |                                       |                   |
| B28 | VDD    | Power        | Power supply                          |                   |
| B30 | XC2    | Analog input | Connection for 32 MHz crystal         |                   |
| C1  | VDD    | Power        | Power supply                          |                   |
| C31 | XC1    | Analog input | Connection for 32 MHz crystal         |                   |
| D2  | N.C.   |              |                                       |                   |
| E1  | VDDH   | Power        | Power supply                          |                   |
| E31 | VDD    | Power        | Power supply                          |                   |
| F2  | N.C.   |              |                                       |                   |
| G1  | N.C.   |              |                                       |                   |
| G31 | DECRF  | Power        | RADIO power supply decoupling         |                   |
| H2  | N.C.   |              |                                       |                   |
| J1  | DCCH   | Power        | DC/DC converter output                |                   |



| Pin  | Name          | Function                    | Description                                             | Recommended usage |
|------|---------------|-----------------------------|---------------------------------------------------------|-------------------|
| J31  | N.C.          |                             |                                                         |                   |
| K2   | N.C.          |                             |                                                         |                   |
| L1   | VDD           | Power                       | Power supply                                            |                   |
| L31  | ANT           | RF                          | Single-ended antenna connection                         |                   |
| M2   | P1.00         | Digital I/O                 | General purpose I/O                                     |                   |
| N1   | P0.00<br>XL1  | Digital I/O<br>Analog input | General purpose I/O<br>Connection for 32 kHz crystal    |                   |
| N31  | VDD           | Power                       | Power supply                                            |                   |
| P2   | P1.01         | Digital I/O                 | General purpose I/O                                     |                   |
| R1   | P0.01<br>XL2  | Digital I/O<br>Analog input | General purpose I/O<br>Connection for 32 kHz crystal    |                   |
| R31  | P1.10         | Digital I/O                 | General purpose I/O                                     |                   |
| T2   | N.C.          |                             |                                                         |                   |
| U1   | VDD           | Power                       | Power supply                                            |                   |
| U31  | P0.29         | Digital I/O                 | General purpose I/O                                     |                   |
| V2   | P0.04<br>AIN0 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| W1   | P0.02<br>NFC1 | Digital I/O<br>NFC input    | General purpose I/O<br>NFC antenna connection           |                   |
| W31  | SWDCLK        | Debug                       | Serial wire debug clock input for debug and programming |                   |
| Y2   | P0.05<br>AIN1 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| AA1  | P0.03<br>NFC2 | Digital I/O<br>NFC input    | General purpose I/O NFC antenna connection              |                   |
| AA31 | SWDIO         | Debug                       | Serial wire debug I/O for debug and programming         |                   |
| AB2  | P0.06<br>AIN2 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| AC1  | VDD           | Power                       | Power supply                                            |                   |
| AC31 | nRESET        | Reset                       | Pin RESET with internal pull-up resistor                |                   |
| AD2  | P0.07<br>AIN3 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| AE1  | P1.02<br>TWI  | Digital I/O<br>TWI 1 Mbps   | General purpose I/O<br>High-speed pin for 1 Mbps TWI    | TWI               |
| AE31 | P0.28<br>AIN7 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| AF2  | P1.03         | Digital I/O                 | General purpose I/O                                     | TWI               |



| Pin  | Name                        | Function                                    | Description                                                                    | Recommended usage |
|------|-----------------------------|---------------------------------------------|--------------------------------------------------------------------------------|-------------------|
|      | TWI                         | TWI 1 Mbps                                  | High-speed pin for 1 Mbps TWI                                                  |                   |
| AG1  | VDD                         | Power                                       | Power supply                                                                   |                   |
| AG31 | N.C.                        |                                             |                                                                                |                   |
| AH2  | PO.08<br>TRACEDATA3<br>SCK  | Digital I/O<br>Trace data<br>SCK for SPIM4  | General purpose I/O Trace buffer TRACEDATA[3] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| AJ1  | P0.09<br>TRACEDATA2<br>MOSI | Digital I/O<br>Trace data<br>MOSI for SPIM4 | General purpose I/O Trace buffer TRACEDATA[2] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| AJ31 | VDD                         | Power                                       | Power supply                                                                   |                   |
| AK2  | P0.10<br>TRACEDATA1<br>MISO | Digital I/O<br>Trace data<br>MISO for SPIM4 | General purpose I/O Trace buffer TRACEDATA[1] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| AK4  | P0.11<br>TRACEDATAO<br>CSN  | Digital I/O<br>Trace data<br>CSN for SPIM4  | General purpose I/O Trace buffer TRACEDATA[0] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| AK6  | P0.12<br>TRACECLK<br>DCX    | Digital I/O<br>Trace clock<br>DCX for SPIM4 | General purpose I/O Trace buffer clock Dedicated pin for high-speed SPI        | Trace, SPIM4      |
| AK8  | P0.14<br>IO1                | Digital I/O<br>IO1 for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| AK10 | P0.15<br>IO2                | Digital I/O<br>IO2 for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| AK12 | P0.17<br>SCK                | Digital I/O<br>SCK for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| AK14 | P0.18<br>CSN                | Digital I/O<br>CSN for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| AK16 | P0.20                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK18 | P0.22                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK20 | P0.23                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK22 | P1.05                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK24 | P1.07                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK26 | P1.09                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| AK28 | P0.25<br>AIN4               | Digital I/O<br>Analog input                 | General purpose I/O<br>Analog input                                            |                   |
| AK30 | P0.27<br>AIN6               | Digital I/O<br>Analog input                 | General purpose I/O<br>Analog input                                            |                   |
| AL3  | VDD                         | Power                                       | Power supply                                                                   |                   |
| AL5  | P0.13<br>IO0                | Digital I/O<br>IOO for QSPI                 | General purpose I/O<br>Dedicated pin for Quad SPI                              | QSPI              |



| Pin        | Name          | Function                    | Description                                                                                | Recommended usage |
|------------|---------------|-----------------------------|--------------------------------------------------------------------------------------------|-------------------|
| AL7        | VDD           | Power                       | Power supply                                                                               |                   |
| AL9        | P0.16<br>IO3  | Digital I/O<br>IO3 for QSPI | General purpose I/O Dedicated pin for Quad SPI                                             | QSPI              |
| AL11       | VDD           | Power                       | Power supply                                                                               |                   |
| AL13       | P0.19         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL15       | P0.21         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL17       | VDD           | Power                       | Power supply                                                                               |                   |
| AL19       | P1.04         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL21       | P1.06         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL23       | P1.08         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL25       | VDD           | Power                       | Power supply                                                                               |                   |
| AL27       | P0.24         | Digital I/O                 | General purpose I/O                                                                        |                   |
| AL29       | P0.26<br>AIN5 | Digital I/O<br>Analog input | General purpose I/O Analog input                                                           |                   |
| Corner     | pads          |                             |                                                                                            |                   |
| A1         | N.C.          |                             |                                                                                            |                   |
| A31        | N.C.          |                             |                                                                                            |                   |
| AL1        | N.C.          |                             |                                                                                            |                   |
| AL31       | N.C.          |                             |                                                                                            |                   |
| Bottom     | of chip       |                             |                                                                                            |                   |
| Die<br>pad | VSS           | Power                       | Ground pad. Exposed die pad must be connected to ground (VSS) for proper device operation. |                   |

Table 210: aQFN pin assignments

### 9.1.2 WLCSP pin assignments



Figure 254: WLCSP pin assignments, top view



| Pin | Name   | Function     | Description                           | Recommended usage |
|-----|--------|--------------|---------------------------------------|-------------------|
| A1  | XC1    | Analog input | Connection for 32 MHz crystal         |                   |
| A2  | XC2    | Analog input | Connection for 32 MHz crystal         |                   |
| А3  | VDD    | Power        | Power supply                          |                   |
| A5  | VSS    | Power        | Ground                                |                   |
| A7  | DECD   | Power        | Regulator supply decoupling           |                   |
| A9  | DCCD   | Power        | DC/DC converter output                |                   |
| A11 | D-     | USB          | USB D-                                |                   |
| A12 | D+     | USB          | USB D+                                |                   |
| B1  | DECRF  | Power        | RADIO power supply decoupling         |                   |
| B2  | VSS    | Power        | Ground                                |                   |
| B4  | DECR   | Power        | Regulator supply decoupling           |                   |
| B5  | DECN   | Power        | Regulator supply decoupling           |                   |
| В6  | DCC    | Power        | DC/DC converter output                |                   |
| В7  | VDD    | Power        | Power supply                          |                   |
| В8  | DECA   | Power        | Regulator supply decoupling           |                   |
| В9  | VSS    | Power        | Ground                                |                   |
| B10 | VDD    | Power        | Power supply                          |                   |
| B11 | VBUS   | Power        | Power                                 |                   |
| B12 | VDDH   | Power        | Power supply                          |                   |
| C2  | VSS    | Power        | Ground                                |                   |
| C4  | P0.30  | Digital I/O  | General purpose I/O                   |                   |
| C5  | P0.31  | Digital I/O  | General purpose I/O                   |                   |
| C6  | P1.11  | Digital I/O  | General purpose I/O                   |                   |
| C7  | P1.12  | Digital I/O  | General purpose I/O                   |                   |
| C8  | P1.13  | Digital I/O  | General purpose I/O                   |                   |
| С9  | P1.14  | Digital I/O  | General purpose I/O                   |                   |
| C10 | P1.15  | Digital I/O  | General purpose I/O                   |                   |
| C11 | DECUSB | Power        | USB 3.3 V regulator supply decoupling |                   |
| D1  | ANT    | RF           | Single-ended antenna connection       |                   |
| D2  | VDD    | Power        | Power supply                          |                   |
| D10 | P1.00  | Digital I/O  | General purpose I/O                   |                   |
| D11 | DCCH   | Power        | DC/DC converter output                |                   |
| D12 | VSS    | Power        | Ground                                |                   |
| E2  | P0.29  | Digital I/O  | General purpose I/O                   |                   |



| Pin | Name          | Function                    | Description                                             | Recommended usage |
|-----|---------------|-----------------------------|---------------------------------------------------------|-------------------|
| E3  | P0.28<br>AIN7 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| E4  | P1.10         | Digital I/O                 | General purpose I/O                                     |                   |
| E5  | VSS           | Power                       | Ground                                                  |                   |
| E6  | VSS           | Power                       | Ground                                                  |                   |
| E7  | VSS           | Power                       | Ground                                                  |                   |
| E8  | VSS           | Power                       | Ground                                                  |                   |
| E10 | P1.01         | Digital I/O                 | General purpose I/O                                     |                   |
| E11 | VDD           | Power                       | Power supply                                            |                   |
| F1  | SWDIO         | Debug                       | Serial wire debug I/O for debug and programming         |                   |
| F2  | SWDCLK        | Debug                       | Serial wire debug clock input for debug and programming |                   |
| F3  | P1.08         | Digital I/O                 | General purpose I/O                                     |                   |
| F5  | VSS           | Power                       | Ground                                                  |                   |
| F6  | VSS           | Power                       | Ground                                                  |                   |
| F7  | VSS           | Power                       | Ground                                                  |                   |
| F8  | VSS           | Power                       | Ground                                                  |                   |
| F10 | P0.05<br>AIN1 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| F11 | P0.00<br>XL1  | Digital I/O<br>Analog input | General purpose I/O<br>Connection for 32 kHz crystal    |                   |
| F12 | P0.01<br>XL2  | Digital I/O<br>Analog input | General purpose I/O<br>Connection for 32 kHz crystal    |                   |
| G2  | nRESET        | Reset                       | Pin RESET with internal pull-up resistor                |                   |
| G3  | P1.07         | Digital I/O                 | General purpose I/O                                     |                   |
| G5  | AVSS          | Power                       | Ground                                                  |                   |
| G6  | VSS           | Power                       | Ground                                                  |                   |
| G7  | VSS           | Power                       | Ground                                                  |                   |
| G8  | VSS           | Power                       | Ground                                                  |                   |
| G10 | P0.04<br>AIN0 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| G11 | P0.02<br>NFC1 | Digital I/O<br>NFC input    | General purpose I/O NFC antenna connection              |                   |
| H1  | P0.27<br>AIN6 | Digital I/O<br>Analog input | General purpose I/O<br>Analog input                     |                   |
| H2  | P1.09         | Digital I/O                 | General purpose I/O                                     |                   |



| Pin | Name                        | Function                                    | Description                                                                    | Recommended usage |
|-----|-----------------------------|---------------------------------------------|--------------------------------------------------------------------------------|-------------------|
| Н3  | P0.23                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| H10 | P0.06<br>AIN2               | Digital I/O<br>Analog input                 | General purpose I/O<br>Analog input                                            |                   |
| H11 | VDD                         | Power                                       | Power supply                                                                   |                   |
| H12 | P0.03<br>NFC2               | Digital I/O<br>NFC input                    | General purpose I/O NFC antenna connection                                     |                   |
| J2  | P0.26<br>AIN5               | Digital I/O<br>Analog input                 | General purpose I/O Analog input                                               |                   |
| J3  | P1.06                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| J4  | P0.21                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| J5  | P0.19                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| J6  | P0.12<br>TRACECLK<br>DCX    | Digital I/O<br>Trace clock<br>DCX for SPIM4 | General purpose I/O Trace buffer clock Dedicated pin for high-speed SPI        |                   |
| J7  | P0.11<br>TRACEDATAO<br>CSN  | Digital I/O<br>Trace data<br>CSN for SPIM4  | General purpose I/O Trace buffer TRACEDATA[0] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| 18  | P0.10<br>TRACEDATA1<br>MISO | Digital I/O<br>Trace data<br>MISO for SPIM4 | General purpose I/O Trace buffer TRACEDATA[1] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| 19  | P0.09<br>TRACEDATA2<br>MOSI | Digital I/O<br>Trace data<br>MOSI for SPIM4 | General purpose I/O Trace buffer TRACEDATA[2] Dedicated pin for high-speed SPI | Trace, SPIM4      |
| J10 | P0.07<br>AIN3               | Digital I/O<br>Analog input                 | General purpose I/O Analog input                                               |                   |
| J11 | P1.02<br>TWI                | Digital I/O<br>TWI 1 Mbps                   | General purpose I/O<br>High-speed pin for 1 Mbps TWI                           | TWI               |
| K1  | VDD                         | Power                                       | Power supply                                                                   |                   |
| K2  | P0.24                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| К3  | P1.04                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| K4  | P0.22                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| К5  | P0.20                       | Digital I/O                                 | General purpose I/O                                                            |                   |
| К6  | AVSS                        | Power                                       | Ground                                                                         |                   |
| K7  | P0.18<br>CSN                | Digital I/O<br>CSN for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| К8  | P0.16<br>IO3                | Digital I/O<br>IO3 for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| К9  | P0.14<br>IO1                | Digital I/O<br>IO1 for QSPI                 | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |



| Pin | Name                       | Function                                   | Description                                                                    | Recommended usage |
|-----|----------------------------|--------------------------------------------|--------------------------------------------------------------------------------|-------------------|
| K10 | P0.13<br>IO0               | Digital I/O<br>IO0 for QSPI                | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| K11 | AVSS                       | Power                                      | Ground                                                                         |                   |
| K12 | P1.03<br>TWI               | Digital I/O<br>TWI 1 Mbps                  | General purpose I/O<br>High-speed pin for 1 Mbps TWI                           | TWI               |
| L1  | P0.25<br>AIN4              | Digital I/O<br>Analog input                | General purpose I/O<br>Analog input                                            |                   |
| L3  | P1.05                      | Digital I/O                                | General purpose I/O                                                            |                   |
| L5  | VDD                        | Power                                      | Power supply                                                                   |                   |
| L7  | P0.17<br>SCK               | Digital I/O<br>SCK for QSPI                | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| L9  | P0.15<br>IO2               | Digital I/O<br>IO2 for QSPI                | General purpose I/O Dedicated pin for Quad SPI                                 | QSPI              |
| L11 | VDD                        | Power                                      | Power supply                                                                   |                   |
| L12 | P0.08<br>TRACEDATA3<br>SCK | Digital I/O<br>Trace data<br>SCK for SPIM4 | General purpose I/O Trace buffer TRACEDATA[3] Dedicated pin for high-speed SPI | Trace, SPIM4      |

Table 211: WLCSP pin assignments

## 9.2 Mechanical specifications

The mechanical specifications for the packages show the dimensions in millimeters.

### 9.2.1 aQFN94 7 x 7 mm package

Dimensions in millimeters for the aQFN94 7 x 7 mm package.







Figure 255: aQFN94 7 x 7 mm package

|      | A    | A1   | A2    | А3   | b    | b1  | D, E | е   | e1  | e2    | J   | K   |
|------|------|------|-------|------|------|-----|------|-----|-----|-------|-----|-----|
| Min. |      | 0.02 |       |      | 0.15 |     |      |     |     |       | 5.3 | 4.9 |
| Nom. |      | 0.05 | 0.675 | 0.13 | 0.20 | 0.4 | 7.00 | 0.4 | 2.8 | 0.447 | 5.4 | 5.0 |
| Max. | 0.85 | 0.08 |       |      | 0.25 |     |      |     |     |       | 5.5 | 5.1 |

Table 212: aQFN94 dimensions in millimeters

### 9.2.2 WLCSP package

Dimensions in millimeters for the WLCSP package.





Figure 256: WLCSP 4.4 x 4.0 mm package

|      | Α     | A1    | А3    | b    | D     | E     | D2   | E2  | е    | К     | L      |
|------|-------|-------|-------|------|-------|-------|------|-----|------|-------|--------|
| Min. | 0.361 | 0.095 | 0.244 | 0.12 |       |       |      |     |      |       |        |
| Nom. | 0.404 |       | 0.269 |      | 4.390 | 3.994 | 3.85 | 3.5 | 0.35 | 1.683 | 1.9907 |
| Max. | 0.447 | 0.125 | 0.294 | 0.18 |       |       |      |     |      |       |        |

Table 213: WLCSP dimensions in millimeters

### 9.3 Reference circuitry

To ensure good RF performance when designing PCBs, it is highly recommended to use the PCB layouts and component values provided by Nordic Semiconductor.

Documentation for the different package reference circuits, including Altium Designer files, PCB layout files, and PCB production files can be downloaded from www.nordicsemi.com.

In this section, there are reference circuits for QKAA aQFN94 and CLAA WLCSP, showing the components and component values to support on-chip features in a design.

Some general guidance is summarized here:

- External supply from VDD is only available when power is supplied to VDDH.
- When supplying power from a USB source only, VBUS pin must be connected to VDDH pin if USB is to be used.
- Components required for DC/DC function are only needed if DC/DC mode is enabled for that regulator.
- NFC can be used in any configuration.
- USB can be used in any configuration as long as VBUS is supplied by the USB host.
- The schematics include an optional, but recommended, series resistor on the USB supply for improved immunity to transient over-voltage during VBUS connection.

| Config no. | Supply configura          | tion                      | Enabled features |                  |                                         |     |     |  |
|------------|---------------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                      | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 1  | Battery/Ext.<br>regulator | N/A                       | Yes              | Yes              | Yes                                     | Yes | No  |  |
| Config. 2  | N/A                       | Battery/Ext.<br>regulator | No               | No               | Yes                                     | Yes | Yes |  |
| Config. 3  | N/A                       | Battery/Ext.<br>regulator | No               | No               | Yes                                     | No  | No  |  |
| Config. 4  | USB (VDDH = VBUS)         | N/A                       | No               | No               | No                                      | Yes | No  |  |

Table 214: Circuit configurations for QKAA aQFN94

| Config no. | Supply configura          | ation                     | Enabled features |                  |                                         |     |     |  |
|------------|---------------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                      | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 1  | Battery/Ext.<br>regulator | N/A                       | Yes              | Yes              | Yes                                     | Yes | No  |  |
| Config. 2  | N/A                       | Battery/Ext.<br>regulator | No               | No               | Yes                                     | Yes | Yes |  |
| Config. 3  | N/A                       | Battery/Ext.<br>regulator | No               | No               | Yes                                     | No  | No  |  |
| Config. 4  | USB (VDDH =<br>VBUS)      | N/A                       | No               | No               | No                                      | Yes | No  |  |

Table 215: Circuit configurations for CLAA WLCSP

### 9.3.1 Circuit configuration no. 1 for QKAA aQFN94

Circuit configuration number 1 for QKAA aQFN94 is showing the schematic and the bill of materials table.

| Config no. | Supply configuration      |     | Enabled features |                  |                                         |     |     |  |
|------------|---------------------------|-----|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                      | VDD | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 1  | Battery/Ext.<br>regulator | N/A | Yes              | Yes              | Yes                                     | Yes | No  |  |

Table 216: Configuration summary for circuit configuration no. 1





Figure 257: Circuit configuration no. 1 schematic



| Designator                                  | Value            | Description                                                                                                                                    | Footprint |
|---------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                                          | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C16                         | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                                          | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C10, C11,<br>C12, C13, C14, C15 | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C17, C20                                    | 4.7 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C18                                         | 4.7 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C19                                         | 2.2 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C21                                         | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1                                          | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L2, L3                                      | 10 μΗ            | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| L4                                          | 10 μΗ            | Inductor, 80 mA, ±20%                                                                                                                          | 0603      |
| R1                                          | 2.2 Ω            | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                                          | nRF5340-<br>QKAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | AQFN-94   |
| X1                                          | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                                          | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 217: Bill of material for circuit configuration no. 1

### 9.3.2 Circuit configuration no. 2 for QKAA aQFN94

Circuit configuration number 2 for QKAA aQFN94 is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |                           | Enabled features |                  |                                         |     |     |  |
|------------|----------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                 | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 2  | N/A                  | Battery/Ext.<br>regulator | No               | No               | Yes                                     | Yes | Yes |  |

Table 218: Configuration summary for circuit configuration no. 2





Figure 258: Circuit configuration no. 2 schematic



| Designator                                  | Value                | Description                                                                                                                                    | Footprint |
|---------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                                          | 0.7 pF               | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C16                         | 1.0 μF               | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                                          | 2.2 nF               | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C10, C11,<br>C12, C13, C14, C15 | 100 nF               | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C17                                         | 4.7 μF               | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C18                                         | 4.7 μF               | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C21                                         | N.C.                 | Not mounted                                                                                                                                    | 0201      |
| CT1, CT2, CT3, CT4                          | Antenna<br>dependent | Capacitor, NPO, ±5%                                                                                                                            | 0201      |
| L1                                          | 2.2 nH               | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L2, L3                                      | 10 μΗ                | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| R1                                          | 2.2 Ω                | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                                          | nRF5340-<br>QKAA     | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | AQFN-94   |
| X1                                          | 32 MHz               | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                                          | 32.768 kHz           | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 219: Bill of material for circuit configuration no. 2

### 9.3.3 Circuit configuration no. 3 for QKAA aQFN94

Circuit configuration number 3 for QKAA aQFN94 is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |                           | Enabled features |                  |                                         |     |     |  |
|------------|----------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                 | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 3  | N/A                  | Battery/Ext.<br>regulator | No               | No               | Yes                                     | No  | No  |  |

Table 220: Configuration summary for circuit configuration no. 3





Figure 259: Circuit configuration no. 3 schematic



| Designator                                  | Value            | Description                                                                                                                                    | Footprint |
|---------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                                          | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C16                         | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                                          | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C10, C11,<br>C12, C13, C14, C15 | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C21                                         | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1                                          | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L2, L3                                      | 10 μΗ            | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| U1                                          | nRF5340-<br>QKAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | AQFN-94   |
| X1                                          | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                                          | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 221: Bill of material for circuit configuration no. 3

### 9.3.4 Circuit configuration no. 4 for QKAA aQFN94

Circuit configuration number 4 for QKAA aQFN94 is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |     | Enabled features |                  |                                         |     |     |  |
|------------|----------------------|-----|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                 | VDD | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 4  | USB (VDDH = VBUS)    | N/A | No               | No               | No                                      | Yes | No  |  |

Table 222: Configuration summary for circuit configuration no. 4





Figure 260: Circuit configuration no. 4 schematic



| Designator                                  | Value            | Description                                                                                                                                    | Footprint |
|---------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                                          | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7                              | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                                          | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C10, C11,<br>C12, C13, C14, C15 | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C17                                         | 4.7 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C18                                         | 4.7 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C19                                         | 2.2 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C21                                         | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1                                          | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| R1                                          | 2.2 Ω            | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                                          | nRF5340-<br>QKAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | AQFN-94   |
| X1                                          | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                                          | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 223: Bill of material for circuit configuration no. 4

### 9.3.5 Circuit configuration no. 1 for CLAA WLCSP

Circuit configuration number 1 for CLAA WLCSP is showing the schematic and the bill of materials table.

| Config no. | Supply configuration      |     | Enabled features |                  |                                         |     |     |  |
|------------|---------------------------|-----|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                      | VDD | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 1  | Battery/Ext.<br>regulator | N/A | Yes              | Yes              | Yes                                     | Yes | No  |  |

Table 224: Configuration summary for circuit configuration no. 1





Figure 261: Circuit configuration no. 1 schematic

NORDIC\*

| Designator                       | Value            | Description                                                                                                                                    | Footprint |
|----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                               | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C10, C14,<br>C17 | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                               | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C11, C12, C13        | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C15, C18                         | 4.7 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C16                              | 4.7 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C19                              | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1, L2                           | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L3, L4                           | 10 μΗ            | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| L5                               | 10 μΗ            | Inductor, 80 mA, ±20%                                                                                                                          | 0603      |
| R1                               | 2.2 Ω            | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                               | nRF5340-<br>CLAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | WLCSP-95  |
| X1                               | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                               | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 225: Bill of material for circuit configuration no. 1

### 9.3.6 Circuit configuration no. 2 for CLAA WLCSP

Circuit configuration number 2 for CLAA WLCSP is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |                           | Enabled features |                  |                                         |     |     |  |
|------------|----------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                 | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 2  | N/A                  | Battery/Ext.<br>regulator | No               | No               | Yes                                     | Yes | Yes |  |

Table 226: Configuration summary for circuit configuration no. 2





Figure 262: Circuit configuration no. 2 schematic



| Designator                | Value                | Description                                                                                                                                    | Footprint |
|---------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                        | 0.7 pF               | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C10, C14  | 1.0 μF               | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                        | 2.2 nF               | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C11, C12, C13 | 100 nF               | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C15                       | 4.7 μF               | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C16                       | 4.7 μF               | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C19                       | N.C.                 | Not mounted                                                                                                                                    | 0201      |
| CT1, CT2, CT3, CT4        | Antenna<br>dependent | Capacitor, NPO, ±5%                                                                                                                            | 0201      |
| L1, L2                    | 2.2 nH               | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L3, L4                    | 10 μΗ                | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| R1                        | 2.2 Ω                | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                        | nRF5340-<br>CLAA     | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | WLCSP-95  |
| X1                        | 32 MHz               | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                        | 32.768 kHz           | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 227: Bill of material for circuit configuration no. 2

### 9.3.7 Circuit configuration no. 3 for CLAA WLCSP

Circuit configuration number 3 for CLAA WLCSP is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |                           | Enabled features |                  |                                         |     |     |  |
|------------|----------------------|---------------------------|------------------|------------------|-----------------------------------------|-----|-----|--|
|            | VDDH                 | VDD                       | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |  |
| Config. 3  | N/A                  | Battery/Ext.<br>regulator | No               | No               | Yes                                     | No  | No  |  |

Table 228: Configuration summary for circuit configuration no. 3





Figure 263: Circuit configuration no. 3 schematic



| Designator                | Value            | Description                                                                                                                                    | Footprint |
|---------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                        | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C10, C14  | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                        | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C11, C12, C13 | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C19                       | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1, L2                    | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| L3, L4                    | 10 μΗ            | Inductor, 50 mA, ±20%                                                                                                                          | 0603      |
| U1                        | nRF5340-<br>CLAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | WLCSP-95  |
| X1                        | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                        | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 229: Bill of material for circuit configuration no. 3

### 9.3.8 Circuit configuration no. 4 for CLAA WLCSP

Circuit configuration number 4 for CLAA WLCSP is showing the schematic and the bill of materials table.

| Config no. | Supply configuration |     | Enabled features |                  |                                         |     |     |
|------------|----------------------|-----|------------------|------------------|-----------------------------------------|-----|-----|
|            | VDDH                 | VDD | EXTSUPPLY        | DCDC on<br>VREGH | DCDC on<br>VREGMAIN<br>and<br>VREGRADIO | USB | NFC |
| Config. 4  | USB (VDDH = VBUS)    | N/A | No               | No               | No                                      | Yes | No  |

Table 230: Configuration summary for circuit configuration no. 4





Figure 264: Circuit configuration no. 4 schematic



| Designator                | Value            | Description                                                                                                                                    | Footprint |
|---------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| C1                        | 0.7 pF           | Capacitor, NPO, ±0.05 pF                                                                                                                       | 0201      |
| C2, C3, C5, C7, C10, C17  | 1.0 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0402      |
| C4                        | 2.2 nF           | Capacitor, X7R, ±10%                                                                                                                           | 0201      |
| C6, C8, C9, C11, C12, C13 | 100 nF           | Capacitor, X7S, ±10%                                                                                                                           | 0201      |
| C15                       | 4.7 μF           | Capacitor, X7S, ±10%                                                                                                                           | 0603      |
| C16                       | 4.7 μF           | Capacitor, X7R, ±10%                                                                                                                           | 0603      |
| C19                       | N.C.             | Not mounted                                                                                                                                    | 0201      |
| L1, L2                    | 2.2 nH           | High frequency chip inductor, ±5%                                                                                                              | 0201      |
| R1                        | 2.2 Ω            | Resistor, ±1%, 0.05 W                                                                                                                          | 0201      |
| U1                        | nRF5340-<br>CLAA | Multiprotocol Bluetooth Low Energy, IEEE 802.15.4, ANT, and 2.4GHz proprietary System on Chip                                                  | WLCSP-95  |
| X1                        | 32 MHz           | Crystal SMD 2016, 32 MHz, Cl=8 pF, Total Tol: ±30 ppm. For frequency tolerance requirements, see 32 MHz crystal oscillator (HFXO) on page 102. | XTAL_2016 |
| X2                        | 32.768 kHz       | Crystal SMD 2012, 32.768 kHz, Cl=9 pF, Total Tol: ±50 ppm                                                                                      | XTAL_2012 |

Table 231: Bill of material for circuit configuration no. 4

### 9.3.9 PCB layout example

The PCB layout in the following figure is a reference layout for Circuit configuration no. 1 for QKAA aQFN94.

**Note:** Pay attention to how the capacitor C1 is grounded. It is not directly connected to the ground plane, but grounded via pin J31 and to the VSS die pad. This is done to create additional filtering of harmonic components.

For all available reference layouts, see the product page for nRF5340 on www.nordicsemi.com.



Figure 265: Top silk layer





Figure 266: Top layer



Figure 267: Mid layer 1



Figure 268: Mid layer 2





Figure 269: Bottom layer

## 9.4 Package thermal characteristics

A summary of the thermal characteristics for the different packages available for the IC can be found below.

| Symbol                      | Package | Тур.  | Unit |
|-----------------------------|---------|-------|------|
| $\theta_{JA,aQFN94}$        | aQFN94  | 20.74 | °C/W |
| $\theta_{JB,aQFN94}$        | aQFN94  | 8.10  | °C/W |
| $\theta_{\text{JC,aQFN94}}$ | aQFN94  | 8.75  | °C/W |
| $\theta_{JA,WLCSP}$         | WLCSP   | 28.51 | °C/W |
| $\theta_{JB,WLCSP}$         | WLCSP   | 8.73  | °C/W |
| $\theta_{\text{JC,WLCSP}}$  | WLCSP   | 4.04  | °C/W |

Table 232: Package thermal characteristics

Values obtained by simulation following the EIA/JESD51-2 for still air condition using JEDEC PCB.



# 10 Recommended operating conditions

The operating conditions are the physical parameters that the chip can operate within.

| Symbol | Parameter                                       | Min. | Nom. | Max. | Units |
|--------|-------------------------------------------------|------|------|------|-------|
| VDD    | VDD supply voltage, independent of DCDC enable  | 1.7  | 3.0  | 3.6  | V     |
| VDDH   | VDDH supply voltage, independent of DCDC enable | 2.5  | 3.7  | 5.5  | V     |
| VBUS   | VBUS USB supply voltage                         | 4.35 | 5.0  | 5.5  | V     |
| TA     | Operating temperature                           | -40  | 25   | 105  | °C    |

Table 233: Recommended operating conditions

## 10.1 WLCSP light sensitivity

All WLCSP package variants are sensitive to visible and close-range infrared light. This means that a final product design must shield the chip properly, either by final product encapsulation or by shielding/coating of the WLCSP device.

Some WLCSP package variants have a backside coating, where the marking side of the device is covered with a light absorbing film, while the side edges and the ball side of the device are still exposed and need to be protected. Other WLCSP package variants do not have any such protection.

The WLCSP package variant CLAA has a backside coating.



# 11 Absolute maximum ratings

Maximum ratings are the extreme limits to which the chip can be exposed for a limited amount of time without permanently damaging it. Exposure to absolute maximum ratings for prolonged periods of time may affect the reliability of the device.

For accelerated lifetime testing (HTOL, etc.), supply voltage should not exceed the recommended operating conditions max value, see Recommended operating conditions on page 821.

|      | Min. | Max. | Unit |
|------|------|------|------|
| VDD  | -0.3 | 3.9  | V    |
| VDDH | -0.3 | 5.8  | V    |
| VBUS | -0.3 | 5.8  | V    |
| vss  | -0.3 | 0    | ٧    |

Table 234: Supply voltage

|                                | Min. | Max.      | Unit |
|--------------------------------|------|-----------|------|
| V <sub>I/O</sub> , VDD ≤ 3.6 V | -0.3 | VDD + 0.3 | V    |
| V <sub>I/O</sub> , VDD > 3.6 V | -0.3 | 3.9       | V    |

Table 235: I/O pin voltage

|                     | Min. | Max. | Unit |
|---------------------|------|------|------|
| I <sub>NFC1/2</sub> |      | 80   | mA   |

Table 236: NFC antenna pin current

|                | Min. | Max. | Unit |
|----------------|------|------|------|
| RF input level |      | 10   | dBm  |

Table 237: Radio



|                                  | Min. | Max.                                       | Unit |
|----------------------------------|------|--------------------------------------------|------|
| Storage temperature              | -40  | +125                                       | °C   |
| Moisture Sensitivity Level (MSL) |      | 2                                          |      |
| ESD Human Body Model<br>(HBM)    |      | 2 Pins <b>DECR</b> and <b>DECN</b> are 1.4 | kV   |
| ESD Charged Device Model (CDM)   |      | 500                                        | V    |

Table 238: Environmental aQFN package

|                                  | Min. | Max.                                       | Unit |
|----------------------------------|------|--------------------------------------------|------|
| Storage temperature              | -40  | +125                                       | °C   |
| Moisture Sensitivity Level (MSL) |      | 1                                          |      |
| ESD Human Body Model<br>(HBM)    |      | 2 Pins <b>DECR</b> and <b>DECN</b> are 1.4 | kV   |
| ESD Charged Device Model (CDM)   |      | 500                                        | V    |

Table 239: Environmental WLCSP package

|           | Min.                      | Max. | Unit |
|-----------|---------------------------|------|------|
| Endurance | 10,000 write/erase cycles |      |      |
| Retention | 10 years at 40°C          |      |      |

Table 240: Flash memory





# 12 Ordering information

This chapter contains information on device marking, ordering codes, and container sizes.

### 12.1 Device marking

The nRF5340 package is marked as shown in the following figure.

| N                                                                                                               | 5  | 3                                                                         | 4           | 0                             |         |
|-----------------------------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------------|-------------|-------------------------------|---------|
| <p< td=""><td>P&gt;</td><td><v< td=""><td><b>&gt;</b></td><td>\<br/>\<br/>\</td><td><p></p></td></v<></td></p<> | P> | <v< td=""><td><b>&gt;</b></td><td>\<br/>\<br/>\</td><td><p></p></td></v<> | <b>&gt;</b> | \<br>\<br>\                   | <p></p> |
| <y< td=""><td>Y&gt;</td><td><w< td=""><td>W&gt;</td><td><l< td=""><td>L&gt;</td></l<></td></w<></td></y<>       | Y> | <w< td=""><td>W&gt;</td><td><l< td=""><td>L&gt;</td></l<></td></w<>       | W>          | <l< td=""><td>L&gt;</td></l<> | L>      |

Figure 270: Device marking

### 12.2 Box labels

The following figures show the box labels used for nRF5340.



Figure 271: Inner box label





Figure 272: Outer box label

### 12.3 Order code

The following are the order codes and definitions for nRF5340.

| n | R | F | 5 | 3 | 4 | 0 | - | <p< th=""><th>P&gt;</th><th><v< th=""><th>V&gt;</th><th>-</th><th><c< th=""><th>C&gt;</th><th></th></c<></th></v<></th></p<> | P> | <v< th=""><th>V&gt;</th><th>-</th><th><c< th=""><th>C&gt;</th><th></th></c<></th></v<> | V> | - | <c< th=""><th>C&gt;</th><th></th></c<> | C> |  |
|---|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------|----|---|----------------------------------------|----|--|
|---|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------|----|---|----------------------------------------|----|--|

Figure 273: Order code



| Abbreviation                | Definition and implemented codes                                                                                                                                       |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N53/nRF53                   | nRF53 series product                                                                                                                                                   |
| 40                          | Part code                                                                                                                                                              |
| <pp></pp>                   | Package variant code                                                                                                                                                   |
| <vv></vv>                   | Function variant code                                                                                                                                                  |
| <h><p><f></f></p></h>       | Build code  H - Hardware version code  P - Production configuration code (production site, etc.)  F - Firmware version code (only visible on shipping container label) |
| <yy><ww><ll></ll></ww></yy> | Tracking code  YY - Year code  WW - Assembly week number  LL - Wafer lot code                                                                                          |
| <cc></cc>                   | Container code                                                                                                                                                         |

Table 241: Abbreviations

## 12.4 Code ranges and values

Defined here are nRF5340 code ranges and values.

| <pp></pp> | Package | Size (mm)     | Pin/Ball count | Pitch (mm) |
|-----------|---------|---------------|----------------|------------|
| QK        | AQFN    | 7 x 7         | 94             | 0.4        |
| CL        | WLCSP   | 4.390 x 3.994 | 95             | 0.35       |

Table 242: Package variant codes

| <vv></vv> | Flash (kB) | RAM (kB) |
|-----------|------------|----------|
| AA        | 1024       | 512      |

Table 243: Function variant codes

| <h></h> | Description                                        |
|---------|----------------------------------------------------|
| [A Z]   | Hardware version/revision identifier (incremental) |

Table 244: Hardware version codes



| <p></p> | Description                                 |
|---------|---------------------------------------------|
| [09]    | Production device identifier (incremental)  |
| [A Z]   | Engineering device identifier (incremental) |

Table 245: Production configuration codes

| <f></f>    | Description                              |
|------------|------------------------------------------|
| [A N, P Z] | Version of preprogrammed firmware        |
| [0]        | Delivered without preprogrammed firmware |

Table 246: Production version codes

| <yy></yy> | Description                   |
|-----------|-------------------------------|
| [1699]    | Production year: 2016 to 2099 |

Table 247: Year codes

| <ww></ww> | Description        |
|-----------|--------------------|
| [152]     | Week of production |

Table 248: Week codes

| <ll></ll> | Description                     |
|-----------|---------------------------------|
| [AA ZZ]   | Wafer production lot identifier |

Table 249: Lot codes

| <cc></cc> | Description |
|-----------|-------------|
| R7        | 7" Reel     |
| R         | 13" Reel    |

Table 250: Container codes

## 12.5 Product options

Defined here are the nRF5340 product options.

The following table lists the ordering code, as well as the minimum ordering quantity (MOQ).



| Order code      | MOQ  |
|-----------------|------|
| nRF5340-QKAA-R7 | 800  |
| nRF5340-QKAA-R  | 3000 |
| nRF5340-CLAA-R7 | 1500 |
| nRF5340-CLAA-R  | 7000 |

Table 251: nRF5340 order codes

| Order code | Description             |
|------------|-------------------------|
| nRF5340-DK | nRF5340 Development Kit |

Table 252: Development tools order code



# 13 Legal notices

By using this documentation you agree to our terms and conditions of use. Nordic Semiconductor may change these terms and conditions at any time without notice.

#### **Liability disclaimer**

Nordic Semiconductor ASA reserves the right to make changes without further notice to the product to improve reliability, function, or design. Nordic Semiconductor ASA does not assume any liability arising out of the application or use of any product or circuits described herein.

Nordic Semiconductor ASA 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. If there are any discrepancies, ambiguities or conflicts in Nordic Semiconductor's documentation, the Product Specification prevails.

Nordic Semiconductor ASA reserves the right to make corrections, enhancements, and other changes to this document without notice.

Customer represents that, with respect to its applications, it has all the necessary expertise to create and implement safeguards that anticipate dangerous consequences of failures, monitor failures and their consequences, and lessen the likelihood of failures that might cause harm, and to take appropriate remedial actions.

Nordic Semiconductor ASA assumes no liability for applications assistance or the design of customers' products. Customers are solely responsible for the design, validation, and testing of its applications as well as for compliance with all legal, regulatory, and safety-related requirements concerning its applications.

Nordic Semiconductor ASA's products are not designed for use in life-critical medical equipment, support appliances, devices, or systems where malfunction of Nordic Semiconductor ASA's products can reasonably be expected to result in personal injury. Customer may not use any Nordic Semiconductor ASA's products in life-critical medical equipment unless adequate design and operating safeguards by customer's authorized officers have been made. Customer agrees that prior to using or distributing any life-critical medical equipment that include Nordic Semiconductor ASA's products, customer will thoroughly test such systems and the functionality of such products as used in such systems.

Customer will fully indemnify Nordic Semiconductor ASA and its representatives against any damages, costs, losses, and/or liabilities arising out of customer's non-compliance with this section.

#### **RoHS and REACH statement**

Refer to www.nordicsemi.com for complete hazardous substance reports, material composition reports, and latest version of Nordic's RoHS and REACH statements.

#### **Trademarks**

All trademarks, service marks, trade names, product names, and logos appearing in this documentation are the property of their respective owners.

#### **Copyright notice**

© 2022 Nordic Semiconductor ASA. All rights are reserved. Reproduction in whole or in part is prohibited without the prior written permission of the copyright holder.





